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