Hibernate第04课:hibernate数据管理

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

你可能感兴趣的:(sql,Hibernate,.net,JUnit)