hibernate3.3.2学习笔记---CRUD_Cascade与fetch

一对多的情况,一个group中含有多个user,一个user属于一个group。

先给出两个类代码:

Group.java

@Entity
@Table(name="t_group")
public class Group {
	private int id;
	private String name;
	private Set<User> users = new HashSet<User>();
	@Id
	@GeneratedValue
	public int getId() {
		return id;
	}
	public void setId(int id) {
		this.id = id;
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	@OneToMany(mappedBy="group")
	
	public Set<User> getUsers() {
		return users;
	}
	public void setUsers(Set<User> users) {
		this.users = users;
	}
}


User.java

@Entity
@Table(name="t_user")
public class User {
	private int id;
	private String name;
	private Group group;
	@ManyToOne
	public Group getGroup() {
		return group;
	}
	public void setGroup(Group group) {
		this.group = group;
	}
	@Id
	@GeneratedValue
	public int getId() {
		return id;
	}
	public void setId(int id) {
		this.id = id;
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
}



先测试多对多双向关联,保存一个对象数据后,另一个对象是否会同步保存进去。

	@Test
	public void TestSave()
	{
		Group g=new Group();
		g.setName("g1");
		User u=new User();
		u.setName("u1");
		u.setGroup(g);
		
          new SchemaExport(new AnnotationConfiguration().configure()).create(false, true); 
	 SessionFactory sf=new AnnotationConfiguration().configure().buildSessionFactory();
	 Session sess=sf.getCurrentSession();   
	 sess.beginTransaction();
      
	 sess.save(u);
	 sess.getTransaction().commit();
	 sf.close();
	 
	}
这样会报错,故默认情况下并不会将g 顺便保存进数据库。

可以设置User.java   或  Group.java

@ManyToOne(cascade=CascadeType.ALL)


cascade不会影响读,会影响增删改。

fetch管读。

fetch的用法与cascade并无大的差别,FetchType.EAGER 表示读取一个数据时,与其相关联的对象也被读取。

FetchType.LAZY表示读取一个数据时,与其相关联的对象不会被读取。


笔记:

  • 如果你认为你会经常在某个事务中同时用到父对象与子对象,并且你希望少打点儿字,可以考虑使用cascade="persist,merge,save-update"

可以使用cascade="all"将一个关联关系(无论是对值对象的关联,或者对一个集合的关联)标记为父/子关系的关联。 这样对父对象进行save/update/delete操作就会导致子对象也进行save/update/delete操作。

此外,一个持久的父对象对子对象的浅引用(mere reference)会导致子对象被同步save/update。 不过,这个隐喻(metaphor)的说法并不完整。除非关联是<one-to-many>关联并且被标记为cascade="delete-orphan", 否则父对象失去对某个子对象的引用不会导致该子对象被自动删除。 父子关系的级联(cascading)操作准确语义如下:

  • 如果父对象被persist(),那么所有子对象也会被persist()

  • 如果父对象被merge(),那么所有子对象也会被merge()

  • 如果父对象被save()update()saveOrUpdate(),那么所有子对象则会被saveOrUpdate()

  • 如果某个持久的父对象引用了瞬时(transient)或者脱管(detached)的子对象,那么子对象将会被saveOrUpdate()

  • 如果父对象被删除,那么所有子对象也会被delete()

要想删除或者更新,先做load,除了精确知道ID之外,若是精确知道,直接用QL语句。

如果想消除关联关系,先设定关系为null,再删除对应记录,如果不删除记录,该记录就会变成垃圾数据。



gdal-3.3.2-cp37-cp37m-win_amd64.whl 是一个GDAL库的二进制文件,适用于使用Python 3.7版本的Windows 64位操作系统。GDAL是一个开源的地理数据抽象库,它为许多GIS(地理信息系统)应用程序提供了功能强大的地理数据处理能力。 这个特定的文件是用于Windows上的Python环境,具体为64位的操作系统和Python 3.7版本。cp37代表Python 3.7版本,win_amd64代表Windows 64位操作系统。这个二进制文件可以与相应的Python解释器一起使用,以在Windows上进行地理空间数据的处理和分析。 通过将这个.whl文件安装到Python环境中,您可以在您的Python项目中使用GDAL库的功能。GDAL库提供了一些基本和高级的地理数据处理功能,如读取、写入和转换各种地理数据格式,进行投影、分析和空间查询等。 要安装这个.whl文件,您首先需要确保您的系统满足相应的要求,包括64位的Windows操作系统和Python 3.7版本。然后使用pip命令来安装这个.whl文件。打开命令提示符或终端窗口,导航到包含.whl文件的目录,并运行以下命令: pip install gdal-3.3.2-cp37-cp37m-win_amd64.whl 安装完成后,您就可以在Python代码中使用import语句来导入和使用GDAL库的功能了。 总而言之,gdal-3.3.2-cp37-cp37m-win_amd64.whl是一个GDAL库的二进制文件,它适用于使用Python 3.7版本的Windows 64位操作系统,可以通过pip命令安装,并提供了处理地理空间数据的功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值