hibernate增删改查

package com.service;

import java.util.List;
import java.util.ListIterator;

import org.hibernate.Criteria;
import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.criterion.Expression;
import com.entity.HibernateSessionFactory;
import com.entity.Student;

public class AddService {
	Session sess = HibernateSessionFactory.getSession();
	Student stu = new Student();

	public void add() {

		stu.setId(1);
		stu.setUserName("丽萨");
		stu.setPwd("123456");
		stu.setAge(23);
		sess.beginTransaction();
		sess.save(stu);
		sess.getTransaction().commit();
	}

	public void select() {

		/*
		 * sess.beginTransaction(); sess.load(stu, new Integer(3));
		 * System.out.println(stu.getId());
		 * System.out.println(stu.getUserName());
		 * System.out.println(stu.getPwd()); stu.setUserName("xiao");
		 * sess.update(stu); sess.getTransaction().commit();
		 */
		// 需要先查询,然后在进行修改!
		// -------------------------------------------
		sess.beginTransaction();
		stu.setId(5);
		stu.setUserName("云母");
		stu.setPwd("123");
		sess.update(stu);
		sess.getTransaction().commit();
		// 这里如果不查询,则会全部更新……如果不把表中的字段写完,它会自动认为空

	}

	public void delete() {
		sess.beginTransaction();

		stu.setId(4);// 设定id,根据id进行删除
		sess.delete(stu);
		sess.getTransaction().commit();
		// 注意,只能通过id来删除数据,不能通过name或pwd来删除,会报缺少标示符错误。
	}

	
	// 批量查询
//如果我们要为查询设定条件,則可以透过net.sf.hibernate.expression.Expression设定查询条件,Expression拥有许多查询方法
	public void selectL() {
		Criteria cri = sess.createCriteria(Student.class);//
	   cri.add(Expression.gt("id", new Integer(8))); 
	    //Expression的gt()方法即great-equal,也就是大於等于(>=),在上例中我們設定查詢age属性大于等于25的User資料
		
	    cri.add(Expression.between("age",new Integer(10),new Integer(50)));
		//设置多个查询条件,age介于10岁与50之间
		
		/*cri.add(Expression.or(Expression.eq("age",new Integer(22)),
				Expression.isNull("age"))		
		);*/
    
	    
		//逻辑组合查询 or -- 语句为  where ( this_.age=? or this_.age is null )
 
	    List users = cri.list();
		for (ListIterator it = users.listIterator(); it.hasNext();) {
			Student stu = (Student) it.next();
			System.out.print("----------" + stu.getId());
			System.out.print("----------" + stu.getUserName());
			System.out.print("-----------"+stu.getPwd());
			System.out.println("----------"+stu.getAge());
			System.out.println("");

		}

	}

	public void selectEasy(){
		
		
	}
	public static void main(String[] args) {
		AddService add = new AddService();
		// add.select();
		// add.delete();
		// add.add();
		// add.deleteP();
		add.selectL();

	}

}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值