4- ASP.NET Core 2.1 Full Stack Web App - Part3 ef初始化數(shù)據(jù)庫

一橙数、PostgreSQL 操作

1、將psql安裝目錄的 bin 目錄加入當(dāng)前用戶的path環(huán)境變量急但,并重啟電腦
例如我的 psql.exe 所在目錄為:

D:\PostgreSQL\pg10\bin

  1. 運行 cmder篮绰,連接數(shù)據(jù)庫
 psql --username=postgres
  1. 運行命令,創(chuàng)建數(shù)據(jù)庫
CREATE DATABASE archdb_dev;

然后命令 \l 查看數(shù)據(jù)庫

20180728162044.png

或者直接使用圖形界面工具 pgAdmin 進(jìn)行操作:


20180728162542.png
  1. 回到 Solution Folder缓升,Data 下面的 Migrations 目錄中包含的數(shù)據(jù)庫遷移文件是針對 sqlite 的,我們不用蕴轨,所以直接刪除該文件夾港谊。刪除后Data下只有一個DbContext類
    20180728163213.png

二、接下來添加自己的遷移文件:

  • 命令行進(jìn)入工程目錄橙弱,運行 dotnet ef 查看 ef 的安裝情況
    20180728164145.png
  • 運行以下命令封锉,生成 ApplicationDbContext 的 Migrations
dotnet ef migrations add initial_identity_migration -c ApplicationDbContext -o Data/Migrations/AspNetIdentity/ApplicationDb

成功后會生成我們剛才命令里面的 -o 目錄
并且這樣生成的 Migration 文件才是我們所需針對 PostgreSQL 的

  • 運行以下命令,生成 ConfigurationDbContext 的 Migrations
 dotnet ef migrations add initial_is4_server_config_migration -c ConfigurationDbContext -o Data/Migrations/IdentityServer/ConfigurationDb
  • 然后運行以下命令生成 PersistedGrantDbContext 的 Migrations
 dotnet ef migrations add initial_is4_persisted_grant_migration -c PersistedGrantDbContext -o Data/Migrations/IdentityServer/PersistedGrantDb

都完成后我們的 Migrations 目錄會是這樣:


20180728170421.png

三膘螟、Update Database

  • 運行命令,生成 ApplicationDbContext 相關(guān)表
dotnet ef database update --context ApplicationDbContext
20180728171301.png
  • 接下來運行命令碾局,生成 IdentityServer 需要的相關(guān)表
dotnet ef database update --context ConfigurationDbContext
20180728171453.png
  • 運行命令荆残,生成 PersistedGrantDbContext 相關(guān)表【一張:PersistedGrants】
 dotnet ef database update --context PersistedGrantDbContext

全部完成后數(shù)據(jù)庫中會有以下26張表


20180728171804.png

四、Seed Data -- ApplicationDbContext

SeedData包含一個方法EnsureSeedData净当,用來為新數(shù)據(jù)庫插入數(shù)據(jù)
查找引用發(fā)現(xiàn)其在 Program類的Main方法中被調(diào)用

        public static void Main(string[] args)
        {
            var seed = args.Any(x => x == "/seed");
            if (seed) args = args.Except(new[] { "/seed" }).ToArray();

            var host = BuildWebHost(args);

            if (seed)
            {
                SeedData.EnsureSeedData(host.Services);
                return;
            }

            host.Run();
        }

當(dāng)程序運行傳入?yún)?shù) /seed時内斯,運行初始數(shù)據(jù)庫操作
+運行命令dotnet run /seed,啟動程序執(zhí)行seed操作

20180728173300.png

完成后表【AspNetUsers】中生成 SeedData 中的兩條數(shù)據(jù)
20180728173441.png

表【AspNetUserClaims】會有數(shù)據(jù)
20180728174036.png

五像啼、SeedData -- ConfigurationDbContext & PersistedGrantDbContext

接下來用另一種方式實現(xiàn)SeedData

  • Startup.cs中編寫如下方法
        private void InitializeDatabase(IApplicationBuilder app)
        {
            // using a service scope
            using (var serviceScope = app.ApplicationServices.GetService<IServiceScopeFactory>().CreateScope())
            {
                // Create PersistedGrant database if not exist, then do migration
                serviceScope.ServiceProvider.GetRequiredService<PersistedGrantDbContext>().Database.Migrate();

                var configDbContext = serviceScope.ServiceProvider.GetRequiredService<ConfigurationDbContext>();
                configDbContext.Database.Migrate();

                // Seed data if not exist any
                if (!configDbContext.Clients.Any())
                {
                    foreach (var client in Config.GetClients())
                    {
                        configDbContext.Clients.Add(client.ToEntity());
                    }
                    configDbContext.SaveChanges();
                }

                if (!configDbContext.IdentityResources.Any())
                {
                    foreach (var res in Config.GetIdentityResources())
                    {
                        configDbContext.IdentityResources.Add(res.ToEntity());
                    }
                    configDbContext.SaveChanges();
                }

                if (!configDbContext.ApiResources.Any())
                {
                    foreach (var api in Config.GetApis())
                    {
                        configDbContext.ApiResources.Add(api.ToEntity());
                    }
                    configDbContext.SaveChanges();
                }
            }
        }

然后在Configure方法添加調(diào)用

  • 運行程序dotnet run
    20180728180226.png

    相關(guān)數(shù)據(jù)也已被初始化俘闯,并且IdentityServer也在正常運行
    按照提示瀏覽器輸入網(wǎng)址 http://localhost:5000 , 可以看到 IdentityServer 已正常運行
    20180728180455.png

六、IdentityServer 資料

Click here

七忽冻、github code changes

Click here

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末真朗,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子僧诚,更是在濱河造成了極大的恐慌遮婶,老刑警劉巖蝗碎,帶你破解...
    沈念sama閱讀 222,464評論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異旗扑,居然都是意外死亡蹦骑,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,033評論 3 399
  • 文/潘曉璐 我一進(jìn)店門臀防,熙熙樓的掌柜王于貴愁眉苦臉地迎上來眠菇,“玉大人,你說我怎么就攤上這事袱衷∩臃希” “怎么了?”我有些...
    開封第一講書人閱讀 169,078評論 0 362
  • 文/不壞的土叔 我叫張陵祟昭,是天一觀的道長缕坎。 經(jīng)常有香客問我,道長篡悟,這世上最難降的妖魔是什么谜叹? 我笑而不...
    開封第一講書人閱讀 59,979評論 1 299
  • 正文 為了忘掉前任,我火速辦了婚禮搬葬,結(jié)果婚禮上荷腊,老公的妹妹穿的比我還像新娘。我一直安慰自己急凰,他們只是感情好女仰,可當(dāng)我...
    茶點故事閱讀 69,001評論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著抡锈,像睡著了一般疾忍。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上床三,一...
    開封第一講書人閱讀 52,584評論 1 312
  • 那天一罩,我揣著相機(jī)與錄音,去河邊找鬼撇簿。 笑死聂渊,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的四瘫。 我是一名探鬼主播汉嗽,決...
    沈念sama閱讀 41,085評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼找蜜!你這毒婦竟也來了饼暑?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 40,023評論 0 277
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎撵孤,沒想到半個月后迈着,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,555評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡邪码,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,626評論 3 342
  • 正文 我和宋清朗相戀三年裕菠,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片闭专。...
    茶點故事閱讀 40,769評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡奴潘,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出影钉,到底是詐尸還是另有隱情画髓,我是刑警寧澤,帶...
    沈念sama閱讀 36,439評論 5 351
  • 正文 年R本政府宣布平委,位于F島的核電站奈虾,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏廉赔。R本人自食惡果不足惜肉微,卻給世界環(huán)境...
    茶點故事閱讀 42,115評論 3 335
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望蜡塌。 院中可真熱鬧碉纳,春花似錦、人聲如沸馏艾。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,601評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽琅摩。三九已至铁孵,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間房资,已是汗流浹背蜕劝。 一陣腳步聲響...
    開封第一講書人閱讀 33,702評論 1 274
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留志膀,地道東北人。 一個月前我還...
    沈念sama閱讀 49,191評論 3 378
  • 正文 我出身青樓鳖擒,卻偏偏與公主長得像溉浙,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子蒋荚,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,781評論 2 361

推薦閱讀更多精彩內(nèi)容