您所在位置: 网站首页 / 文档列表 / 数据库 / 文档详情
在hibernate中的数据库操作.doc 立即下载
上传人:yy****24 上传时间:2024-09-03 格式:DOC 页数:10 大小:51KB 金币:16 举报 版权申诉
预览加载中,请您耐心等待几秒...

在hibernate中的数据库操作.doc

在hibernate中的数据库操作.doc

预览

在线预览结束,喜欢就下载吧,查找使用更方便

16 金币

下载文档

如果您无法下载资料,请参考说明:

1、部分资料下载需要金币,请确保您的账户上有足够的金币

2、已购买过的文档,再次下载不重复扣费

3、资料包下载后请先用软件解压,在使用对应软件打开

session.save()把对象持久化,让内存的数据进入缓存,我个人认为相当于数据库中的insert插入Teachert=newTeacher();t.setName("s1");t.setTitle("yy");t.setDate(newDate());Configurationcfg=newAnnotationConfiguration();SessionFactorysf=cfg.configure().buildSessionFactory();Sessionsession=sf.getCurrentSession();session.beginTransaction();session.save(t);session.getTransaction().commit();sf.close();session.get()先从缓存中读取数据,缓存没有就向数据库读取Configurationcfg=newAnnotationConfiguration();SessionFactorysf=cfg.configure().buildSessionFactory();Sessionsession=sf.getCurrentSession();session.beginTransaction();Teachert=(Teacher)session.get(Teacher.class,1)//get(class,id的值),数据库表必须有相应id值,不然报错,最最主要是它是直接把sql语句传给了t,这点与load不同system.out.println(t.getName());//若id不匹配就会报错,t.getClass也一样,因为无论如何它都要写sql语句,一写就错了session.getTransaction().commit();system.out.println(t.getName());sf.close();注意:system.out.println(t.getName());位置放哪里都没有影响,因为其已经把值直接存到t里面了,虽然缓存commit提交消失,但其t的内存没消失session.load()先从缓存中读取数据,缓存没有就向数据库读取Configurationcfg=newAnnotationConfiguration();SessionFactorysf=cfg.configure().buildSessionFactory();Sessionsession=sf.getCurrentSession();session.beginTransaction();Teachert=(Teacher)session.get(Teacher.class,1)//get(class,id的值),数据库表必须有相应id值,不然报错,它与get不同的是,它只是把代理给了t而已,比较其t.getClass,可以知道,具体调用到t.getName()时,才写SQL语句system.out.println(t.getName());//id匹配,在数据库中有,那么,commit之前不会报错,之后会报错,因为session关闭,但是t.getClass(),不管id是否匹配,session是否关闭,它都不报错,能显示名字session.getTransaction().commit();system.out.println(t.getName());sf.close();注意:system.out.println(t.getName());位置放哪里都没有影响,因为其已经把值直接存到t里面了,虽然session的缓存commit提交消失,但其t的内存没消失,t.getClass()中,load的值与id,commit无关,随时能读取,get的值会受id影响。猜测:load把代理的名或者说地址,传给了t,所以不管它session是否关闭,id是否匹配,你只读名字不受影响,但是读数据库sql受id和session影响,否则指不到对应的值。get和load主要区别是一个直接把sql值传给t,一个只是把代理,后者真正调用才用session.delete()从数据库中的delete中可以看出,delete需要有属性来确认,一般我们选用id这个主键属性,所以先用get或load从数据库中读取,再delete删除@Testpublicvoidtestdelete(){Sessionsession=sf.getCurrentSession();session.beginTransaction();Teachert=(Teacher)session.get(Teacher.class,119)
单篇购买
VIP会员(1亿+VIP文档免费下)

扫码即表示接受《下载须知》

在hibernate中的数据库操作

文档大小:51KB

限时特价:扫码查看

• 请登录后再进行扫码购买
• 使用微信/支付宝扫码注册及付费下载,详阅 用户协议 隐私政策
• 如已在其他页面进行付款,请刷新当前页面重试
• 付费购买成功后,此文档可永久免费下载
年会员
99.0
¥199.0

6亿VIP文档任选,共次下载特权。

已优惠

微信/支付宝扫码完成支付,可开具发票

VIP尽享专属权益

VIP文档免费下载

赠送VIP文档免费下载次数

阅读免打扰

去除文档详情页间广告

专属身份标识

尊贵的VIP专属身份标识

高级客服

一对一高级客服服务

多端互通

电脑端/手机端权益通用

手机号注册 用户名注册
我已阅读并接受《用户协议》《隐私政策》
已有账号?立即登录
我已阅读并接受《用户协议》《隐私政策》
已有账号?立即登录
登录
手机号登录 微信扫码登录
微信扫一扫登录 账号密码登录

首次登录需关注“豆柴文库”公众号

新用户注册
VIP会员(1亿+VIP文档免费下)
年会员
99.0
¥199.0

6亿VIP文档任选,共次下载特权。

已优惠

微信/支付宝扫码完成支付,可开具发票

VIP尽享专属权益

VIP文档免费下载

赠送VIP文档免费下载次数

阅读免打扰

去除文档详情页间广告

专属身份标识

尊贵的VIP专属身份标识

高级客服

一对一高级客服服务

多端互通

电脑端/手机端权益通用