方法一(仅适用单个字段) 使用 not in ,容易理解,效率低
1 select A.ID from A where A.ID not in (select ID from B)
方法二(适用多个字段匹配) 使用 left join…on… , B.ID isnull 表示左连接之后在B.ID 字段为 null的记录
1 select A.ID from A left join B on A.ID=B.ID where B.ID is null
方法三(适用多个字段匹配) 1 select * from B where (select count (1 ) as num from A where A.ID = B.ID) = 0
方法四(适用多个字段匹配) 1 select * from A where not exists (select 1 from B where A.ID=B.ID)
1、FetchType.LAZY: 懒加载,加载一个实体时,定义懒加载的属性不会马上从数据库中加载。
2、FetchType.EAGER: 急加载,加载一个实体时,定义急加载的属性会立即从数据库中加载。
example:
比方User类有两个属性,name跟address,就像百度知道,登录后用户名是需要显示出来的,此属性用到的几率极大,要马上到数据库查,用急加载;
而用户地址大多数情况下不需要显示出来,只有在查看用户资料是才需要显示,需要用了才查数据库,用懒加载就好了。所以,并不是一登录就把用户的所有资料都加载到对象中;
于是有了这两种加载模式。
A、实体对象的延迟加载 如果想对实体对象使用延迟加载,必须要在实体的映射配置文件中进行相应的配置,如下所示:
1 2 3 4 5 <hibernate-mapping > <class name =”com.neusoft.entity.User” table =”user” lazy =”true” > …… </class > </hibernate-mapping >
一般是对整个实体对象进行设置是否是懒加载,而非单个属性。若该实体对象关联某个对象,如下面:
关联的实体对象通常是懒加载 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 @Entity @Table (name="t_company" )public class Company extends BaseEntity <Long > { private String companyName; private List<Flight> flights = new ArrayList<Flight>(); public String getCompanyName () { return companyName; } @OneToMany (cascade=CascadeType.ALL,mappedBy="company" ,fetch=FetchType.LAZY) public List<Flight> getFlights () { return flights; } public void setFlights (List<Flight> flights) { this .flights = flights; } public void setCompanyName (String companyName) { this .companyName = companyName; } }