C# と VB.NET の質問掲示板
ASP.NET、C++/CLI、Java 何でもどうぞ
掲示板トップ
C# と VB.NET 入門
新規作成
利用方法
ツリー表示
トピック表示
ランキング
記事検索
過去ログ
ログ内検索
キーワードを複数指定する場合は 半角スペース で区切ってください。
検索条件は、(AND)=[A かつ B] (OR)=[A または B] となっています。
[返信]をクリックすると返信ページへ移動します。
キーワード
/
検索条件
/
(AND)
(OR)
検索範囲
/
(現在のログ)
(全過去ログ)
(過去ログ1)
(過去ログ2)
(過去ログ3)
(過去ログ4)
(過去ログ5)
(過去ログ6)
(過去ログ7)
(過去ログ8)
(過去ログ9)
(過去ログ10)
(過去ログ11)
(過去ログ12)
(過去ログ13)
(過去ログ14)
(過去ログ15)
(過去ログ16)
(過去ログ17)
(過去ログ18)
(過去ログ19)
(過去ログ20)
(過去ログ21)
(過去ログ22)
(過去ログ23)
(過去ログ24)
(過去ログ25)
(過去ログ26)
(過去ログ27)
(過去ログ28)
(過去ログ29)
(過去ログ30)
(過去ログ31)
(過去ログ32)
(過去ログ33)
(過去ログ34)
(過去ログ35)
(過去ログ36)
(過去ログ37)
(過去ログ38)
(過去ログ39)
(過去ログ40)
(過去ログ41)
(過去ログ42)
(過去ログ43)
(過去ログ44)
(過去ログ45)
(過去ログ46)
(過去ログ47)
(過去ログ48)
(過去ログ49)
(過去ログ50)
(過去ログ51)
(過去ログ52)
(過去ログ53)
(過去ログ54)
(過去ログ55)
(過去ログ56)
(過去ログ57)
(過去ログ58)
(過去ログ59)
(過去ログ60)
(過去ログ61)
(過去ログ62)
(過去ログ63)
(過去ログ64)
(過去ログ65)
(過去ログ66)
(過去ログ67)
(過去ログ68)
(過去ログ69)
(過去ログ70)
(過去ログ71)
(過去ログ72)
(過去ログ73)
(過去ログ74)
(過去ログ75)
(過去ログ76)
(過去ログ77)
(過去ログ78)
(過去ログ79)
(過去ログ80)
(過去ログ81)
(過去ログ82)
(過去ログ83)
(過去ログ84)
(過去ログ85)
(過去ログ86)
(過去ログ87)
(過去ログ88)
(過去ログ89)
(過去ログ90)
(過去ログ91)
(過去ログ92)
(過去ログ93)
(過去ログ94)
(過去ログ95)
(過去ログ96)
(過去ログ97)
(過去ログ98)
(過去ログ99)
(過去ログ100)
(過去ログ101)
(過去ログ102)
(過去ログ103)
(過去ログ104)
(過去ログ105)
(過去ログ106)
(過去ログ107)
(過去ログ108)
(過去ログ109)
(過去ログ110)
(過去ログ111)
(過去ログ112)
(過去ログ113)
(過去ログ114)
(過去ログ115)
(過去ログ116)
(過去ログ117)
(過去ログ118)
(過去ログ119)
(過去ログ120)
(過去ログ121)
(過去ログ122)
(過去ログ123)
(過去ログ124)
(過去ログ125)
(過去ログ126)
(過去ログ127)
(過去ログ128)
(過去ログ129)
(過去ログ130)
(過去ログ131)
(過去ログ132)
(過去ログ133)
(過去ログ134)
(過去ログ135)
(過去ログ136)
(過去ログ137)
(過去ログ138)
(過去ログ139)
(過去ログ140)
(過去ログ141)
(過去ログ142)
(過去ログ143)
(過去ログ144)
(過去ログ145)
(過去ログ146)
(過去ログ147)
(過去ログ148)
(過去ログ149)
(過去ログ150)
(過去ログ151)
(過去ログ152)
(過去ログ153)
(過去ログ154)
(過去ログ155)
(過去ログ156)
(過去ログ157)
(過去ログ158)
(過去ログ159)
(過去ログ160)
(過去ログ161)
(過去ログ162)
(過去ログ163)
(過去ログ164)
(過去ログ165)
(過去ログ166)
(過去ログ167)
(過去ログ168)
(過去ログ169)
(過去ログ170)
(過去ログ171)
(過去ログ172)
(過去ログ173)
(過去ログ174)
(過去ログ175)
(過去ログ176)
(過去ログ177)
(過去ログ178)
(過去ログ179)
強調表示
/
ON
(自動リンクOFF)
結果表示件数
/
20件
30件
40件
50件
100件
記事No検索
/
ON
大文字と小文字を区別する
No.93575 の関連記事表示
ヒット / 9件
(1-9 を表示)
<<
0
>>
■93575
コードファーストでDBが作成されない
□投稿者/ QQ -
(2019/12/23(Mon) 18:02:55)
分類:[ASP.NET (C#)]
お世話になります。
VS2017にてASP.NET MVC+EntityFramework6のプロジェクトを作成しようとしているのですが、
コードファーストにてSQLServerにDBを作成しようと、モデルを作成しビルドをしているのですが、
DBが作成されない状態です。
特にビルドエラーも出ておりません。
どのような原因が考えられますでしょうか?
以下の3点では記述が足りないのでしょうか?
■モデル
public class User
{
public int UserId { get; set; }
public string UserName { get; set; }
}
■DBコンテキスト
public class TestContext: DbContext
{
public DbSet<User> Users { get; set; }
}
■Web.config
<connectionStrings>
<add name="TestContext"
connectionString="Data Source=localhost\SQLEXPRESS;
Initial Catalog=TestDb;
Persist Security Info=True;
User ID=sa;
Password=;
MultipleActiveResultSets=True;
Application Name=EntityFramework"
providerName="System.Data.SqlClient" />
</connectionStrings>
親記事 /過去ログ162より /
関連記事表示
削除チェック/
■93576
Re[1]: コードファーストでDBが作成されない
□投稿者/ WebSurfer -
(2019/12/23(Mon) 18:22:39)
■
No93575
(QQ さん) に返信
> どのような原因が考えられますでしょうか?
> 以下の3点では記述が足りないのでしょうか?
接続文字列が間違っているのですが、それが原因なのか断定できるの情報が
ないです。
一度以下のチュートリアルに従ってコンソールアプリで DB を作ってみてく
ださい。SQL Server Express がインストールしてあれば、Code First の既
定に従って DB が生成されるはずです。
新しいデータベースへの Code First
https://docs.microsoft.com/ja-jp/ef/ef6/modeling/code-first/workflows/new-database
記事No.93575 のレス /過去ログ162より /
関連記事表示
削除チェック/
■93577
Re[2]: コードファーストでDBが作成されない
□投稿者/ QQ -
(2019/12/23(Mon) 18:46:06)
2019/12/23(Mon) 19:08:44 編集(投稿者)
■
No93576
(WebSurfer さん) に返信
> 一度以下のチュートリアルに従ってコンソールアプリで DB を作ってみてく
> ださい。SQL Server Express がインストールしてあれば、Code First の既
> 定に従って DB が生成されるはずです。
やってみました。
SQLServerオブジェクトエクスプローラーの中のlocaldbの中にDBが作成されました。
となると接続情報の書き方の問題なのでしょうか?
一応、コードファーストではない別プロジェクトで接続できている記述内容でしたので
間違いがピンと来ない状況です。。
ちなみに、SQL Server 2012 Expressがインストール済みです。
記事No.93575 のレス /過去ログ162より /
関連記事表示
削除チェック/
■93580
Re[3]: コードファーストでDBが作成されない
□投稿者/ WebSurfer -
(2019/12/23(Mon) 19:55:01)
■
No93577
(QQ さん) に返信
> となると接続情報の書き方の問題なのでしょうか?
それだけが問題なのか分かりませんが、とにかく接続文字列が間違ってます。
そこをまず勉強した考えてみることをお勧めします。
接続文字列の書き方に自信ができたら、以下の記事を参考にコンテキストクラ
スの定義に接続文字列を指定して、指定した通りの場所に DB が生成されるか
調べてみてください。
接続文字列とモデル
https://docs.microsoft.com/ja-jp/ef/ef6/fundamentals/configuring/connection-strings
記事No.93575 のレス /過去ログ162より /
関連記事表示
削除チェック/
■93585
Re[3]: コードファーストでDBが作成されない
□投稿者/ WebSurfer -
(2019/12/24(Tue) 09:35:27)
■
No93577
(QQ さん) に返信
No93580
で紹介した「接続文字列とモデル」の記事の内容がある程度理解できたら
以下のチュートリアルを一通りやってみつことをお勧めします。(機械翻訳なので
日本語に難ありですが)
最初のチュートリアルで EF Code First による DB の生成の話が出てきます。
MVC 5 を使用する Entity Framework 6 Code First の概要
https://docs.microsoft.com/ja-jp/aspnet/mvc/overview/getting-started/getting-started-with-ef-using-mvc/
記事No.93575 のレス /過去ログ162より /
関連記事表示
削除チェック/
■93590
Re[4]: コードファーストでDBが作成されない
□投稿者/ QQ -
(2019/12/24(Tue) 12:00:39)
■
No93585
(WebSurfer さん) に返信
まず、接続文字列については、投稿の際に余計な「"」が追加されてしまってました。
こちらは実際にはありません。
> MVC 5 を使用する Entity Framework 6 Code First の概要
>
https://docs.microsoft.com/ja-jp/aspnet/mvc/overview/getting-started/getting-started-with-ef-using-mvc/
そして、教えて頂いた記事や、上記チュートリアルをやってみました。
どうやら勘違い(?)をしていたようで、モデル+DBコンテキスト+接続情報
の3つを作成してビルドすればDBが作られるものと思っていたのですが、
モデルをベースとしたコントローラー+ビューを作成してブラウザ表示したところDBが作成されました。
モデルが使用される機能を初めて実行した際にDBが作成されるという理解であっているのでしょうか?
(大抵の記事がCRUDありのビューまで作ってからの実行のようで、具体的なタイミングが分かりませんでした。)
記事No.93575 のレス /過去ログ162より /
関連記事表示
削除チェック/
■93591
Re[5]: コードファーストでDBが作成されない
□投稿者/ WebSurfer -
(2019/12/24(Tue) 14:06:18)
■
No93590
(QQ さん) に返信
> まず、接続文字列については、投稿の際に余計な「"」が追加されてしまってました。
> こちらは実際にはありません。
接続文字列ですが、まず localhost は (local) とするのが Microsoft の推奨です。
Windows 認証を使っていると理解していますが、その場合 SQL Server 認証で使う User ID,
Password は不要です。
Application Name というのも不要だと思います。
接続できたそうですので間違いとは言えないかもしれませんが、Microsoft のドキュメント
に従って書いた方がよさそうです。
> どうやら勘違い(?)をしていたようで、モデル+DBコンテキスト+接続情報
> の3つを作成してビルドすればDBが作られるものと思っていたのですが、
> モデルをベースとしたコントローラー+ビューを作成してブラウザ表示したところDBが作成されました。
接続文字列は指定してなければ EF Code First の規約にしたがって EF が生成しますが、
コンテキストクラスは必須です。
ただし、接続文字列をEF 任せにするのは問題あるはずで(特に運用環境に移す際)、
普通は web.config に書いてコン
テキストクラスのコンストラクタに指定しそれが使われるようにします。
> モデルが使用される機能を初めて実行した際にDBが作成されるという理解であっているのでしょうか?
その理解で良いと思います。一番最初に紹介した記事でもそれが分かると思います。
記事No.93575 のレス /過去ログ162より /
関連記事表示
削除チェック/
■93598
Re[5]: コードファーストでDBが作成されない
□投稿者/ WebSurfer -
(2019/12/25(Wed) 10:06:26)
■
No93590
(QQ さん) に返信
SQL Server の接続文字列に関する Microsoft のドキュメントを紹介しておきます。
日本語版もありますが機械翻訳で内容がメチャクチャなので英語版を読んでください。
SqlConnection.ConnectionString Property
https://docs.microsoft.com/en-us/dotnet/api/system.data.sqlclient.sqlconnection.connectionstring?redirectedfrom=MSDN&view=netframework-4.8#System_Data_SqlClient_SqlConnection_ConnectionString
記事No.93575 のレス /過去ログ162より /
関連記事表示
削除チェック/
■93601
Re[6]: コードファーストでDBが作成されない
□投稿者/ QQ -
(2019/12/25(Wed) 10:57:06)
2019/12/25(Wed) 11:03:27 編集(投稿者)
■
No93598
(WebSurfer さん) に返信
返信が遅くなりました。
ドキュメント、日本語、英語を合わせて読んでみました。
最終的に以下のようにしました。(SQL認証でした。)
<connectionStrings>
<add name="TestContext"
connectionString="Data Source=(local)\SQLEXPRESS;
Initial Catalog=TestDb;
User ID=sa;
Password=;"
providerName="System.Data.SqlClient" />
</connectionStrings>
勉強になりました!
ありがとうございました!
記事No.93575 のレス /過去ログ162より /
関連記事表示
削除チェック/
<<
0
>>
パスワード/
-
Child Tree
-