コンテンツにスキップ
メインメニュー
メインメニュー
サイドバーに移動
非表示
案内
メインページ
最近の更新
未作成ページ
おまかせ表示
ヘルプ
MonoBook
検索
検索
ログイン
個人用ツール
ログイン
ログアウトした編集者のページ
もっと詳しく
投稿記録
トーク
「
Fluent NHibernate/フルーエントマッピング
」を編集中
ページ
議論
日本語
閲覧
編集
ソースを編集
履歴表示
ツール
ツール
サイドバーに移動
非表示
操作
閲覧
編集
ソースを編集
履歴表示
全般
リンク元
関連ページの更新状況
特別ページ
ページ情報
2012年7月8日 (日) 10:36時点における
imported>Administrator
による版
(
差分
)
← 古い版
|
最新版
(
差分
) |
新しい版 →
(
差分
)
警告: このページの古い版を編集しています。
公開すると、この版以降になされた変更がすべて失われます。
警告:
ログインしていません。編集を行うと、あなたの IP アドレスが公開されます。
ログイン
または
アカウントを作成
すれば、あなたの編集はその利用者名とともに表示されるほか、その他の利点もあります。
スパム攻撃防止用のチェックです。 けっして、ここには、値の入力は
しない
でください!
[[Fluent NHibernate]]では[[Fluent NHibernate/オートマッピング|オートマッピング]]に加え'''フルーエントマッピング'''(fluent mappings)という手動マッピング機能を用意している。[[NHibernate]]と違い、マッピング設定に[[XML]]ファイルではなく[[C Sharp|C#]]の[[ソースコード]]を用いるというFluent NHibernateの主目的ともいえる機能である。 他サイトのサンプルを見る限り、大半の人は[[Fluent NHibernate/オートマッピング|オートマッピング]]よりも細かく設定できるこちらを使っているようだ。 細かく設定できる分、相当難しい。 日本語の情報もほとんどない。 == 超入門 == === エンティティを作る === まずエンティティとなるクラスを作る。 [[アプリケーション]]を作る[[プログラマー]]が直接操作するのはエンティティクラスとなる。 この[[アプリケーション]]を作る[[プログラマー]]がエンティティクラスをゴニョゴニョすることで、一般的なSELECT/UPDATE/INSERT/DELETE(俗にいう[[CRUD]])などのDB操作を実現することになる。 プロジェクトの中に「Entities」というディレクトリを作り、その中に格納しておくとわかりやすいと思う。 <source lang="csharp"> // 従業員エンティティクラス public class Employee { public virtual int Id { get; set; } public virtual string FirstName { get; set; } public virtual string LastName { get; set; } } </source> === マッピングを作る === 次にマッピングを記述するクラスを作る。 マッピングクラスはClassMap<>クラスを継承して作る。 マッピングクラスは、Fluent NHibernateがエンティティがどういう設定かを記述するクラスであり、エンティティを利用する[[プログラマー]]が直接参照するようなものではない。 [[Fluent NHibernate]]の99%は、このマッピングクラスの記述方法を覚えることだと思われる。 まったく理解は出来ていない。 プロジェクト内に「Mappings」というディレクトリを作り、その中に格納しておくとわかりやすいと思う。 <source lang="csharp"> // 従業員マッピングクラス public class EmployeeMap : ClassMap<Employee> { // デフォルトコンストラクタ // この中でマッピングの詳細を記述する。 public EmployeeMap() { // プライマリキー Id(x => x.Id); // 普通のマッピング Map(x => x.FirstName); Map(x => x.LastName); } } </source> === アプリを作る === 次に実際にアプリケーションを作る。 <source lang="csharp"> class AppMain { public static void Main(string[] args) { var config = Fluently.Configure() // 接続設定 .Database( SQLiteConfiguration.Standard .UsingFile("firstProject.db") ) // マッピングのありかを明示する。 // 適当なクラスを指定すると、そのクラスが属するアセンブリ内の // マッピングクラスを自動検知して、あとは全自動でやってくれる。 .Mappings(map => map.FluentMappings.AddFromAssemblyOf<AppMain>()) // マッピングからスキーマを自動生成する。 .ExposeConfiguration(cfg => new SchemaExport(cfg).Create(false, true)) ; var factory = config.BuildSessionFactory(); // 実際に使ってみる using (var session = factory.OpenSession()) using (var transaction = session.BeginTransaction()) { // insertしてみる var emp = new Expolyee(); emp.FirstName = "test"; emp.LastName = "tarou"; session.SaveOrUpdate(emp); transaction.Commit(); } } } </source> == 基本 == === Id === プライマリーキーとなる。 === Map === プロパティとマッピングする。 === References === 多対1(many to one)を表す。 === HasMany ==== 1対多(one to many)を表す。 === HasManyToMany === 多対多(many to many)を表す。 === HasOne === 1対1(one to one)を表す。 == 応用、その他 == * [[Fluent NHibernate/フルーエントマッピング/自己参照]] * [[Fluent NHibernate/フルーエントマッピング/複合主キー]] * [[Fluent NHibernate/フルーエントマッピング/オートインクリメント]] * [[Fluent NHibernate/フルーエントマッピング/テキスト長]] * [[Fluent NHibernate/フルーエントマッピング/日付型]] * [[Fluent NHibernate/フルーエントマッピング/列挙型]] <!-- {{stub}} 大雑把に言えばオートマッピングの記述例のAutoMappingsの部分がFluentMappingsになるような感じである。 <source lang="csharp"> .Mappings(map => map.FluentMappings .AddFromAssemblyOf<Product>() ) </source> --> == 関連項目 == * [[Fluent NHibernate]] * [[Fluent NHibernate/データベース接続設定]] * [[Fluent NHibernate/オートマッピング]] == 参考文献 == <references/> == 外部リンク == {{stub}}
編集内容の要約:
MonoBookへの投稿はすべて、他の投稿者によって編集、変更、除去される場合があります。 自分が書いたものが他の人に容赦なく編集されるのを望まない場合は、ここに投稿しないでください。
また、投稿するのは、自分で書いたものか、パブリック ドメインまたはそれに類するフリーな資料からの複製であることを約束してください(詳細は
MonoBook:著作権
を参照)。
著作権保護されている作品は、許諾なしに投稿しないでください!
このページを編集するには、下記の確認用の質問に回答してください (
詳細
):
1たす1は?(全角で入力してください)
キャンセル
編集の仕方
(新しいウィンドウで開きます)
このページで使用されているテンプレート:
テンプレート:Stub
(
編集
)
本文の横幅制限を有効化/無効化