Java--Hibernate基本操作

关于Hibernate配置请查阅Java--Hibernate配置,基本原理,初体验

1、对象状态

package hibernate;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;

import entity.Product;

public class TestHibernate2 {
	public static void main(String[] args) {
		SessionFactory sf = new Configuration().configure().buildSessionFactory();
		
		Session session = sf.openSession();
		session.beginTransaction();
		
		/*实体类对象在Hibernate中有3种状态
分别是瞬时,持久和脱管
瞬时 指的是没有和hibernate发生任何关系,在数据库中也没有对应的记录,一旦JVM结束,这个对象也就消失了
持久 指得是一个对象和hibernate发生联系,有对应的session,并且在数据库中有对应的一条记录
脱管 指的是一个对象虽然在数据库中有对应的一条记录,但是它所对应的session已经关闭了
		 * */
		
		Product product = new Product();
		product.setName("华为Mate40");
		System.out.println("此时product是瞬时状态");
		session.save(product);
		System.out.println("此时product是持久状态");
		session.getTransaction().commit();
		session.close();
		System.out.println("此时product是脱管状态");
        sf.close();
	}
}

2、插入

package hibernate;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;

import entity.Product;

/* Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,它将POJO与数据库表建立映射关系,是一个全自动的orm框架,hibernate可以自动生成SQL语句,自动执行
 * hibernate的基本步骤是:
1. 获取SessionFactory
2. 通过SessionFactory 获取一个Session
3. 在Session基础上开启一个事务
4. 通过调用Session的save方法把对象保存到数据库
5. 提交事务
6. 关闭Session
7. 关闭SessionFactory
 * */
public class TestHibernate {
	public static void main(String[] args) {
		//1. 获取SessionFactory
		SessionFactory sf = new Configuration().configure().buildSessionFactory();

		//2. 通过SessionFactory 获取一个Session
		Session session = sf.openSession();
		//3. 在Session基础上开启一个事务
		session.beginTransaction();
		
		for (int i = 0; i < 10; i++) {
			Product product = new Product();
			product.setName("iPhone" + i);
			product.setPrice(8000 + i * 100);
			//4. 通过调用Session的save方法把对象保存到数据库
			session.save(product);
		}
		
		//5. 提交事务
		session.getTransaction().commit();
		//6. 关闭Session
		session.close();
		//7. 关闭SessionFactory
		sf.close();
	}
}

3、获取对象

package hibernate;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;

import entity.Product;

public class TestHibernateGet {
	public static void main(String[] args) {
		SessionFactory sf = new Configuration().configure().buildSessionFactory();
		
		Session session = sf.openSession();
		session.beginTransaction();
		
		Product p = (Product)session.get(Product.class,6);
		System.out.println("id=6的产品名称是: "+p.getName());
		
		session.getTransaction().commit();
		session.close();
		sf.close();
	}
}

4、删除

package hibernate;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;

import entity.Product;

public class TestHibernateDelete {
	public static void main(String[] args) {
		SessionFactory sf = new Configuration().configure().buildSessionFactory();
		
		Session session = sf.openSession();
		session.beginTransaction();
		
		Product p = (Product)session.get(Product.class,2);
		session.delete(p);
		session.getTransaction().commit();
		session.close();
		sf.close();
	}
}

5、修改

package hibernate;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;

import entity.Product;

public class TestHibernateUpdate {
	public static void main(String[] args) {
		SessionFactory sf = new Configuration().configure().buildSessionFactory();
		
		Session session = sf.openSession();
		session.beginTransaction();
		
		Product p = (Product)session.get(Product.class,12);
		System.out.println(p.getName());
		
		p.setName("iphone-modified");
		session.update(p);
		
		session.getTransaction().commit();
		session.close();
        sf.close();
	}
}

6、查询

(1)HQL查询

package hibernate;

import java.util.List;

import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;

import entity.Product;

public class TestHibernateSelectHql {
	public static void main(String[] args) {
		SessionFactory sf = new Configuration().configure().buildSessionFactory();
		 
        Session s = sf.openSession();
        s.beginTransaction();
 
        /*使用HQL,根据name进行模糊查询
1. 首先根据hql创建一个Query对象
2. 设置参数(和基1的PreparedStatement不一样,Query是基0的)
3. 通过Query对象的list()方法即返回查询的结果了。

注: 使用hql的时候,用的是类名Product,而不是表名product_
注: 使用hql的时候,不需要在前面加 select *
         * */
        String name = "iphone";
        Query q = s.createQuery("from Product p where p.name like ?");
        q.setString(0,"%"+name+"%");
        List<Product> ps = q.list();
        
        for (Product p : ps) {
            System.out.println(p.getName());
        }
         
        s.getTransaction().commit();
        s.close();
        sf.close();
	}
}

(2)Criteria查询

package hibernate;

import java.util.List;

import org.hibernate.Criteria;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
import org.hibernate.criterion.Restrictions;

import entity.Product;

public class TestHibernateCriteria {
	public static void main(String[] args) {
		SessionFactory sf = new Configuration().configure().buildSessionFactory();
		
		Session s = sf.openSession();
		s.beginTransaction();
		
		/*使用Criteria 查询数据
1. 通过session的createCriteria创建一个Criteria 对象
2. Criteria.add 增加约束。 在本例中增加一个对name的模糊查询(like)
3. 调用list()方法返回查询结果的集合
		 * */
		String name = "iphone";
		Criteria c = s.createCriteria(Product.class);
		c.add(Restrictions.like("name","%"+name+"%"));
		List<Product> ps = c.list();
		for (Product p : ps) {
            System.out.println(p.getName());
        }
        s.getTransaction().commit();
        s.close();
        sf.close();
	}
}

(3)标准SQL查询

package hibernate;

import java.util.List;

import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;

public class TestHibernateSQL {
	public static void main(String[] args) {
		SessionFactory sf = new Configuration().configure().buildSessionFactory();
		
		Session s = sf.openSession();
		s.beginTransaction();
		
		String name = "iphone";
		String sql = "select * from product_ p where p.name like '%" + name + "%'";
		Query q = s.createSQLQuery(sql);
		List<Object[]> list = q.list();
		/*因为标准SQL语句有可能返回各种各样的结果,比如多表查询,分组统计结果等等。 不能保证其查询结果能够装进一个Product对象中,所以返回的集合里的每一个元素是一个对象数组。 然后再通过下标把这个对象数组中的数据取出来
		 * */
		for (Object[] objects : list) {
			for (Object filed : objects) {
				System.out.println(filed+"\t");
			}
		}
		
		s.getTransaction().commit();
		s.close();
		sf.close();
	}
}

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值