实际上前面已经实现了怎么insert数据,怎么update数据.现在了解怎么查询数据.在hibernate中叫加载数据.有两个方法,分别是get和load.
package net.knight.hibernate.test; import net.knight.hibernate.User; import net.knight.hibernate.utils.HibernateUtils; import org.hibernate.Session; import org.hibernate.Transaction; import junit.framework.TestCase; public class SessionTest extends TestCase { /** * 如果在能查询到数据的情况下正常,如果没有查询到数据的时候 * user对象会返回null,所以只需要判断user是否为null就可以了. */ public void testSelectByGet() { Session session = null; Transaction ts = null; User user = null; try { session = HibernateUtils.getSession(); ts = HibernateUtils.getTransaction(session); // 使用session的get接口,ID参数是实现了序列化的对象,只有实现序列化的对象才能存在磁盘上. // 在这个接口传入需要加载的类,后面则是传入的ID值(只支持主键),get方法就会自动生成SQL语句. // 返回的是一个对象,直接强制转换就可以了. user = (User)session.get(User.class, "40284b8120516a1b0120516a1dac0001"); System.out.println("Username= " + user.getName()); ts.commit(); }catch(Exception e) { e.printStackTrace(); ts.rollback(); }finally { HibernateUtils.closeSession(session); } } /** * 使用的是一个代理类,使用的第三方的类CGlib * 如果查询没有数据的时候不会有任何反应, * 只有在真正使用的时候会抛出ObjectNotFoundException */ public void testSelectByLoad() { Session session = null; Transaction ts = null; User user = null; try { session = HibernateUtils.getSession(); ts = HibernateUtils.getTransaction(session); // load使用了lazy(延迟加载或称懒加载)的方式加载数据. user = (User)session.load(User.class, "40284b8120516a1b0120516a1dac0001"); // 也就是只有执行这条语句的时候才会加载(发出SQL语句). System.out.println("Username= " + user.getName()); ts.commit(); }catch(Exception e) { e.printStackTrace(); ts.rollback(); }finally { HibernateUtils.closeSession(session); } } }
update数据还可以手工建立一个对象,再更新数据.但是这个方法会有问题,更新数据的时候把其他没有赋值的内容都清空.
public void testByUpdtae() { Session session = null; Transaction ts = null; try { session = HibernateUtils.getSession(); ts = HibernateUtils.getTransaction(session); // 现在这个对象是手动构造的Detached对象. // 在数据库中是有这个ID的,所以这个执行会成功. User user = new User(); user.setId("40284b8120516a1b0120516a1dac0001"); user.setName("张三"); // 但是其他没有更新的数据会被清空成NULL. session.update(user); ts.commit(); }catch(Exception e) { e.printStackTrace(); ts.rollback(); }finally { HibernateUtils.closeSession(session); } }
其他没有赋值的内容会被清空,所以不要这样更新数据.
最后看删除数据如何操作.
public void testByDelete() { Session session = null; Transaction ts = null; try { session = HibernateUtils.getSession(); ts = HibernateUtils.getTransaction(session); // 不要手工构造这个对象去删某条记录,应该先加载,再删除. User user = (User)session.load(User.class, "40284b8120516a1b0120516a1dac0001"); session.delete(user); ts.commit(); }catch(Exception e) { e.printStackTrace(); ts.rollback(); }finally { HibernateUtils.closeSession(session); } }
CRUD操作,加载Session,再调用Session的方法就可以了.这里只是查询到数据表中的某一条记录,再对这条记录进行操作.如果要处理一批数据应该要用HQL来处理.