步骤 2 : 模仿和排错 步骤 3 : 效果 步骤 4 : 通过ID获取一个对象
老规矩,先下载右上角的可运行项目,配置运行起来,确认可用之后,再学习做了哪些步骤以达到这样的效果。
在确保可运行项目能够正确无误地运行之后,再严格照着教程的步骤,对代码模仿一遍。
模仿过程难免代码有出入,导致无法得到期望的运行结果,此时此刻通过比较正确答案 ( 可运行项目 ) 和自己的代码,来定位问题所在。 采用这种方式,学习有效果,排错有效率,可以较为明显地提升学习速度,跨过学习路上的各个槛。 推荐使用diffmerge软件,进行文件夹比较。把你自己做的项目文件夹,和我的可运行项目文件夹进行比较。 这个软件很牛逼的,可以知道文件夹里哪两个文件不对,并且很明显地标记出来 这里提供了绿色安装和使用教程:diffmerge 下载和使用教程
获取到id=6的产品的名称
package com.how2java.test;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
import com.how2java.pojo.Product;
public class TestHibernate {
public static void main(String[] args) {
SessionFactory sf = new Configuration().configure().buildSessionFactory();
Session s = sf.openSession();
s.beginTransaction();
Product p =(Product) s.get(Product.class, 6);
System.out.println("id=6的产品名称是: "+p.getName());
s.getTransaction().commit();
s.close();
sf.close();
}
}
HOW2J公众号,关注后实时获知最新的教程和优惠活动,谢谢。
问答区域
2020-05-01
【除了id之外,还需要传递一个类对象,毕竟需要知道获取的是哪个对象】这句话我不理解
5 个答案
15779872975gy 跳转到问题位置 答案时间:2020-08-17 <class name="OrderEntity" table="sys_order">
实体类和数据库表之间的关系是我们在配置**.hbm.xml的时候自己配置的,万一这个关联映射文件很多<mapping resource="com/cn/entity/order.hbm.xml" />
的情况下,你就传一个id,我怎么知道你查那个表,so需要一个类,让框架知道是那个实体类对应哪张表
梦想黑客 跳转到问题位置 答案时间:2020-07-16 我觉得是数据库只保存了数据,比如 iphone6,6000,就这两个数据,你得告诉程序,你是哪个类的数据啊,然后通过反射实例化这个类,再把数据给这个类的属性进行赋值。
a74747474 跳转到问题位置 答案时间:2020-06-12 修改一下id的定义,id应该是对应是自增序列id。
a74747474 跳转到问题位置 答案时间:2020-06-12 可以尝试把数据库里的product表理解为了一个product实列对象数组,而数据库的每一行数据对应着一个product实列对象。id你可以理解为数据库里的product表的第几列(即对应着一个product实列对象),而接下来的操作就是对这个product实列对象的操作了,以上纯属个人理解。
铁锅炖猪脚 跳转到问题位置 答案时间:2020-05-04 没有Session.get(id)这个方法,有的话,如果pojo再多一个,他咋知道拿回来哪个
回答已经提交成功,正在审核。 请于 我的回答 处查看回答记录,谢谢
2019-03-25
为什么这里的class查找会默认去找id呢
2018-10-24
为什么我GET的时候,会报错呢?
2018-07-10
s.get()后面只能接数字吗?
2018-05-14
我发现插入的时候不进行事务提交也可以,这是为什么?
提问太多,页面渲染太慢,为了加快渲染速度,本页最多只显示几条提问。还有 5 条以前的提问,请 点击查看
提问之前请登陆
提问已经提交成功,正在审核。 请于 我的提问 处查看提问记录,谢谢
|