实际上前面已经实现了怎么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来处理.