三种查询方式

时间:2022-04-27 05:59:24

标签:

Hibernate  Api

|-- Configuration       配置管理类对象

config.configure();    加载主配置文件的方法(hibernate.cfg.xml) 默认加载src/hibernate.cfg.xml

config.configure(“cn/config/hibernate.cfg.xml”);   加载指定路径下指定名称的主配置文件

config.buildSessionFactory();   创建session的工厂对象

|-- SessionFactory     session的工厂(或者说代表了这个hibernate.cfg.xml配置文件)

sf.openSession();   创建一个sesison对象

sf.getCurrentSession();  创建session或取出session对象

|--Session       session对象维护了一个连接(Connection), 代表了与数据库连接的会话。Hibernate最重要的对象: 只用使用hibernate与数据库操作,都用到这个对象

session.beginTransaction(); 开启一个事务; hibernate要求所有的与数据库的操作必须有事务的环境,否则报错!

写一个代码测试,如下:

写一个测试类,先将配置管理对象类和session的工厂类加载进来

private static SessionFactory sf; static{ /* * //1、创建配置管理对象 【Configuration:配置管理类对象】 Configuration config=new Configuration(); //加载配置文件(默认加载src/hibernate.cfg.xml)、 config.configure(); //2、根据加载的配置管理类对象,创建sessionFactory对象(代表了整个hibernate.cdg.xml配置文件) SessionFactory sf=config.buildSessionFactory(); */ sf=new Configuration().configure().buildSessionFactory(); }

(1)保存对象(插入数据)

@Test public void testInsert() { //对象 User user=new User(); user.setName("test"); user.setPassword("666"); //根据session工厂,创建session对象(维护了一个连接Connection,代表了数据库连接的会话) Session session=sf.openSession(); //开启事物 Transaction transaction=session.beginTransaction(); /*************执行操作*********/ session.save(user); //提交事物/关闭 transaction.commit(); session.close(); sf.close(); }

(2)、更新对象

/* * 更新对象 */ @Test public void testUpdate() { //对象 User user=new User(); user.setId(4); user.setName("test5"); user.setPassword("666"); //根据session工厂,创建session对象(维护了一个连接Connection,代表了数据库连接的会话) Session session=sf.openSession(); //开启事物 Transaction transaction=session.beginTransaction(); /*************执行操作*********/ //session.update(user); //主键查询 //User user2=(User) session.get(User.class, 1); //User user2=(User) session.load(User.class, 1); //同上 //没有设置主键,执行保存操作(插入数据);设置了主键,执行更新操作(若主键设置的值不存在也会报错) session.saveOrUpdate(user); //System.out.println(user2); //提交事物/关闭 transaction.commit(); session.close(); sf.close(); }

三种查询方式

(1)、HQL查询:

HQL查询与SQL查询区别:

SQL: (结构化查询语句)查询的是表以及字段;  不区分大小写。

HQL: hibernate  query  language 即hibernate提供的面向对象的查询语言

查询的是对象以及对象的属性。区分大小写。

如下:

//HQL查询 Hibernate query language @Test public void testHQL() { Session session=sf.openSession(); //开启事物 Transaction transaction=session.beginTransaction(); //HQL查询,查询全部(注意:查询的是对象以及对象的属性,不是表,,区分大小写) Query query=session.createQuery("from User where id=1 or id=2"); List<User> users=query.list(); System.out.println(users); transaction.commit(); session.close(); sf.close(); }

(2)、Criteria查询:

完全面向对象的查询。

如下:

//QBC查询 query by Criteria @Test public void testQBC() { Session session=sf.openSession(); //开启事物 Transaction transaction=session.beginTransaction(); Criteria criteria=session.createCriteria(User.class); //查询条件 criteria.add(Restrictions.eq("id", 1)); List<User> list=criteria.list(); System.out.println(list); transaction.commit(); session.close(); sf.close(); }

(3)、SQL查询

本地SQL查询:

复杂的查询,就要使用原生态的sql查询,也可以,就是本地sql查询的支持!

(缺点: 不能跨数据库平台!)

//SQL查询 @Test public void testSQL() { Session session=sf.openSession(); //开启事物 Transaction transaction=session.beginTransaction(); //把每一行记录指定为的喜爱那个类型 SQLQuery sqlQuery=session.createSQLQuery("select * from users").addEntity(User.class); List list=sqlQuery.list(); System.out.println(list); transaction.commit(); session.close(); sf.close(); }

js:获取指定class兼容性问题、