欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Java--Hibernate基本操作

程序员文章站 2022-09-21 13:15:15
关于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 m...

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

 

本文地址:https://blog.csdn.net/MinggeQingchun/article/details/109469822

相关标签: JavaEE Hibernate