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();
}
}