第九章 關係映射 集合關聯映射
基本上所有集合關聯映射都是在一對多,多對多操作的時候使用。
1、set
我們之前在做一對多操作的時候,多的一方就是一個set.
一對多的例子:https://blog.csdn.net/p_3er/article/details/9036921
實體類中:
private Set<Employee> employees;
對應的映射文件:
<set name="employees" inverse="false" cascade="all"> <key column="department_id"></key> <one-to-many /> </set>
2、有序的List
數據庫的employee表中多了一個e_index字段,用以表示順序。
實體類中:
private List<Employee> employees;
對應的映射文件:
<list name="employees" cascade="save-update"> <key column="department_id"></key> <index column="e_index"></index> <one-to-many /> </list>
增加操作與set一樣
List集合是有順序的,"index"標簽,是用於記錄順序,List的順序將表現在"e_index"列上,其餘設置,與Set集合類似。注意:List映射中"inverse"中的值不能設置為"true",不然,"e_index "的列值將不會被賦值。
3、無序的List
數據庫的employee表中無e_index字段。無序的List和Set使用起來是一樣的。隻是無序的List使用的映射標簽是<bag>
實體類中:
privateList<Employee> employees;
對應的映射文件:
<bag name="employees" cascade="all"> <key column="department_id"></key> <one-to-many /> </bag>
增加操作與set一樣
4、Map
表設計與set的時候一樣。
實體類中:
privateMap<String, Employee> employees;
這裏的鍵值對中的鍵應該是唯一的(不重複),我們設置為員工的名字。
對應的映射文件:
<map name="employees" cascade="all"> <key column="department_id"></key> <map-key type="string" column="name"></map-key> <one-to-many /> </map>
增加操作:
transaction = session.beginTransaction(); Department department = new Department(); department.setName("m"); Map<String, Employee> employees = new HashMap<String, Employee>(); for(int i = 0;i < 10; i++){ Employee employee = new Employee(); employee.setName("m"+i); employees.put(employee.getName(), employee); } department.setEmployees(employees); session.save(department); transaction.commit();
5、注意
5.1HashMap<String,Employee> employees = newHashMap<String,Employee>();
這樣子的寫法在Java中語法上和使用上是沒有任何問題的。
因為懶加載的需要,我們使用所有集合對象都應該用接口來定義。而且在我們寫程序的過程中也盡可能得使用接口。
5.2cascade缺省為不級聯。
cascade的值有:none,all,save-update,delete...
many-to-one many-to-many一般不設置級聯
one-to-one one-to-many可設置級聯
5.3inverse是否要放棄維護關聯關係
true為放棄,false為不放棄(缺省)
一般不設置放棄
最後更新:2017-04-03 18:52:08