在上一章中已经搭建好了一个hibernate的环境,那么这一章我们就使用这个环境来进行基本CRUD。在这之前我们先了解一个东西:主键生成策略。就是当向数据库表中插入记录的时候,这个记录的主键该如何生成.用法:将hbm.xml文件中<id>节点下的 <generator/>节点中的class 改成以下关键字即可。以下是简介版。推荐使用uuid

01 assigned
主键由外部程序负责生成,在 save() 之前必须指定一个,Hibernate不负责维护主键生成。也就是可以每次指定主键。该方式不推荐

02 increment
这种方式在每次插入前,需要通过“select max(主键) from 表名 ”这种方式先查询最大ID,然后通过ID+1来作为新的主键值。这种方式也不推荐,因为这样会出现线程安全问题。

03 identity
identity由底层数据库生成标识符。identity是由数据库自己生成的,但这个主键必须设置为自增长,使用identity的前提条件是底层数据库支持自动增长字段类型,如DB2、SQL Server、MySQL、Sybase和HypersonicSQL等,Oracle这类没有自增字段的则不支持。

04 sequence
采用数据库提供的sequence机制生成主键,需要数据库支持sequence。如oralce、DB、SAP DB、PostgerSQL、McKoi中的sequence。MySQL这种不支持sequence的数据库则不行

05 hilo
hilo(高低位方式high low)是hibernate中最常用的一种生成方式,需要一张额外的表保存hi的值。保存hi值的表至少有一条记录(只与第一条记录有关),否则会出现错误。可以跨数据库。

06 native
native由hibernate根据使用的数据库自行判断采用identity、hilo、sequence其中一种作为主键生成方式,灵活性很强。如果能支持identity则使用identity,如果支持sequence则使用sequence。

07 uuid
UUID:Universally Unique Identifier,是指在一台机器上生成的数字,它保证对在同一时空中的所有机器都是唯一的。按照开放软件基金会(OSF)制定的标准计算,用到了以太网卡地址、纳秒级时间、芯片ID码和许多可能的数字,标准的UUID格式为:xxxxxxxx-xxxx-xxxx-xxxxxx-xxxxxxxxxx (8-4-4-4-12)

好了,接下来开始这章的主要内容。hibernate的三种方式实现CRUD。首先在src/test/java文件夹下新建package(com.test),新建类 Test.类中写一个方法叫做temp,加上@Test标记

@Test
public void temp() { }

我们可以在cfg.xml中的<session-factory>节点中添加如下代码,以便在控制台来查看我们提交的sql语句。方便修改错误。

      <!--显示sql语句 -->
<property name="show_sql">true</property>
<!--格式化Hibernate的SQL输出语句。 -->
<property name="format_sql">true</property>

在temp方法中写上如下代码:代码写完后选择项目鼠标右键Run As ->Junit Test 运行

第一种:Hibernate提供的Query By Criteria API来查询对象 即QBC。

增加:

        //添加一条数据
// 获取配置信息
Configuration configuration = new Configuration().configure();
// 得到Session工厂
SessionFactory factory = configuration.buildSessionFactory();
// 得到Session
Session session = factory.openSession();
// 开启事物
Transaction transaction = session.beginTransaction();
// 实例化对象
Student st = new Student();
st.setName("王五");
st.setSex("男");
st.setAddress("长沙");
//提交数据
session.save(st);
// 提交事物
transaction.commit();
// 关闭seeion
session.close();
// 关闭SessionFactory
factory.close();

查询单个:

        // 获取配置信息
Configuration configuration = new Configuration().configure();
// 得到Session工厂
SessionFactory factory = configuration.buildSessionFactory();
// 得到Session
Session session = factory.openSession();
// 开启事物
//Transaction transaction = session.beginTransaction();
// 根据主键得到对象(查询单个记录)
Student st = session.get(Student.class, );
System.out.println(st);
// 提交数据
// session.save(st);
// 提交事物
// transaction.commit();
// 关闭seeion
session.close();
// 关闭SessionFactory
factory.close();

修改:

      // 获取配置信息
Configuration configuration = new Configuration().configure();
// 得到Session工厂
SessionFactory factory = configuration.buildSessionFactory();
// 得到Session
Session session = factory.openSession();
// 开启事物
Transaction transaction = session.beginTransaction();
// 根据主键得到对象(查询单个记录)
Student st = session.get(Student.class, );
// 设置修改值
st.setName("李四");
// 提交数据 saveOrUpdate意为:存在修改,不存在增加 修改也可以用Update
session.saveOrUpdate(st);
System.out.println(st);
// 提交事物
transaction.commit();
// 关闭seeion
session.close();
// 关闭SessionFactory
factory.close();

查询所有:

    // 获取配置信息
Configuration configuration = new Configuration().configure();
// 得到Session工厂
SessionFactory factory = configuration.buildSessionFactory();
// 得到Session
Session session = factory.openSession();
// 开启事物
// Transaction transaction = session.beginTransaction();
// 查询所有记录
List<Student> ls = session.createCriteria(Student.class).list();
for (Student student : ls) {
System.out.println(student);
}
// 提交数据 saveOrUpdate意为:存在修改,不存在增加 修改也可以用Update
// session.saveOrUpdate(st);
// 提交事物
// transaction.commit();
// 关闭seeion
session.close();
// 关闭SessionFactory
factory.close();

删除:

    // 获取配置信息
Configuration configuration = new Configuration().configure();
// 得到Session工厂
SessionFactory factory = configuration.buildSessionFactory();
// 得到Session
Session session = factory.openSession();
// 开启事物
Transaction transaction = session.beginTransaction();
// 根据主键得到对象(查询单个记录)
Student st = session.get(Student.class, );
// 提交数据
session.delete(st);
// 提交事物
transaction.commit();
// 关闭seeion
session.close();
// 关闭SessionFactory
factory.close();

第二种:Hibernate官方推荐的标准查询Hibernate Query Language 即HQl查询

查询所有: 注意:用HQL查询from后面接的是实体类名

    // 获取配置信息
Configuration configuration = new Configuration().configure();
// 得到Session工厂
SessionFactory factory = configuration.buildSessionFactory();
// 得到Session
Session session = factory.openSession();

List<Student> ls = session.createQuery("from Student").list();
         for (Student student : ls) {
         System.out.println(student);
          }

// 关闭seeion
session.close();
// 关闭SessionFactory
factory.close();

查询单个属性:

// 获取配置信息
Configuration configuration = new Configuration().configure();
// 得到Session工厂
SessionFactory factory = configuration.buildSessionFactory();
// 得到Session
Session session = factory.openSession();
List<String> ls = session.createQuery("select name from Student").list();
for (String student : ls) {
System.out.println(student);
} // 关闭seeion
session.close();
// 关闭SessionFactory
factory.close();

查询多个属性:object[]实现

// 获取配置信息
Configuration configuration = new Configuration().configure();
// 得到Session工厂
SessionFactory factory = configuration.buildSessionFactory();
// 得到Session
Session session = factory.openSession(); List<Object[]> ls = session.createQuery("select name,sex,age from Student").list();
for (Object[] student : ls) {
System.out.println(student[] + "----" + student[] + "----" + student[]);
} // 关闭seeion
session.close();
// 关闭SessionFactory
factory.close();

查询多个属性:构造方法实现(先要在实体类中重载构造方法)

// 获取配置信息
Configuration configuration = new Configuration().configure();
// 得到Session工厂
SessionFactory factory = configuration.buildSessionFactory();
// 得到Session
Session session = factory.openSession();
List<Student> ls = session.createQuery("select new Student(name,sex) from Student").list();
for (Student student : ls) {
System.out.println(student);
} // 关闭seeion
session.close();
// 关闭SessionFactory
factory.close();

条件查询:

// 获取配置信息
Configuration configuration = new Configuration().configure();
// 得到Session工厂
SessionFactory factory = configuration.buildSessionFactory();
// 得到Session
Session session = factory.openSession();
// List<Student> ls = session.createQuery("from Student where age
// between ? and ?").setInteger(0, 10).setInteger(1, 50).list();
List<Student> ls = session.createQuery("from Student where age between :begin and :end")
.setParameter("begin", ).setParameter("end", ).list();
for (Student student : ls) {
System.out.println(student);
}
// 关闭seeion
session.close();
// 关闭SessionFactory
factory.close();

聚合函数:

// 获取配置信息
Configuration configuration = new Configuration().configure();
// 得到Session工厂
SessionFactory factory = configuration.buildSessionFactory();
// 得到Session
Session session = factory.openSession();
String parm = session.createQuery("select max(age) from Student").uniqueResult().toString();
System.out.println(parm);
// 关闭seeion
session.close();
// 关闭SessionFactory
factory.close();

排序:

// 获取配置信息
Configuration configuration = new Configuration().configure();
// 得到Session工厂
SessionFactory factory = configuration.buildSessionFactory();
// 得到Session
Session session = factory.openSession();
List<Student> ls = session.createQuery("from Student order by age desc").list();
for (Student student : ls) {
System.out.println(student);
}
// 关闭seeion
session.close();
// 关闭SessionFactory
factory.close();

分组:构造方法实现(先要在实体类中重载构造方法)

// 获取配置信息
Configuration configuration = new Configuration().configure();
// 得到Session工厂
SessionFactory factory = configuration.buildSessionFactory();
// 得到Session
Session session = factory.openSession();
// List<Student> ls = session.createQuery("select new
// Student(sex,max(age)) from Student group by sex").list();
List<Object[]> ls = session.createQuery("select sex,max(age) from Student group by sex").list();
for (Object[] student : ls) {
System.out.println(student[] + "--" + student[]);
}
// 关闭seeion
session.close();
// 关闭SessionFactory
factory.close();

Like:

// 获取配置信息
Configuration configuration = new Configuration().configure();
// 得到Session工厂
SessionFactory factory = configuration.buildSessionFactory();
// 得到Session
Session session = factory.openSession();
List<Student> ls = session.createQuery("from Student where name like ?").setParameter(, "%1%").list();
for (Student student : ls) {
System.out.println(student);
}
// 关闭seeion
session.close();
// 关闭SessionFactory
factory.close();

分页:

// 获取配置信息
Configuration configuration = new Configuration().configure();
// 得到Session工厂
SessionFactory factory = configuration.buildSessionFactory();
// 得到Session
Session session = factory.openSession();
List<Student> ls = session.createQuery("from Student").setFirstResult().setMaxResults().list();
for (Student student : ls) {
System.out.println(student);
}
// 关闭seeion
session.close();
// 关闭SessionFactory
factory.close();

修改:

// 获取配置信息
Configuration configuration = new Configuration().configure();
// 得到Session工厂
SessionFactory factory = configuration.buildSessionFactory();
// 得到Session
Session session = factory.openSession();
// 开启事物
Transaction transaction = session.beginTransaction();
session.createQuery("update Student set name = :name where age=10").setParameter("name", "哈哈").executeUpdate(); // 提交事物
transaction.commit();
// 关闭seeion
session.close();
// 关闭SessionFactory
factory.close();

删除:

// 获取配置信息
Configuration configuration = new Configuration().configure();
// 得到Session工厂
SessionFactory factory = configuration.buildSessionFactory();
// 得到Session
Session session = factory.openSession();
// 开启事物
Transaction transaction = session.beginTransaction();
session.createQuery("delete Student where age=?").setParameter(, ).executeUpdate();
// 提交事物
transaction.commit();
// 关闭seeion
session.close();
// 关闭SessionFactory
factory.close();

第三种:原生态sql

这种方式基本不常用,所以就简单介绍下,具体的自己百度吧

//获取所有查询结果
session.createSQLQuery("select * from note").list();
//仅获取第一条结果
session.createSQLQuery("select * from note where id = 1").uniqueResult();

初学者易上手的SSH-hibernate02 三种查询方式的更多相关文章

  1. Hibernate的Api以及三种查询方式

    Hibernate  Api |-- Configuration       配置管理类对象 config.configure();    加载主配置文件的方法(hibernate.cfg.xml) ...

  2. hibernate的三种查询方式

    hibernate的三种查询方式 目录 hibernate的三种查询方式 1.HQL查询 1.1.SQL概述 1.2.实体查询 1.3.带where的查询 1.3.属性查询 1.4.实体的更新和删除 ...

  3. SSH端口三种转发方式

    本地转发 假设有ssh服务器B,telnet服务器C被防火墙与外界隔离,此时外部主机A无法直接访问C服务器. 此时可以通过本地转发的方式让A与C借助B服务器通过ssh协议通信. client fire ...

  4. EF提供的三种查询方式

    這邊簡單介紹一下,ADO.Net Entity Framework 提供的三種查詢方式, Linq to Entities Query Builder Mothed Entity SQL Langua ...

  5. django 神奇的双下划线,通过外键的三种查询方式

    一,用于跨表操作 只要是object后面字符串都是用双下划线__.其它地方用点. 如:的values中的group_code__name.group_code是一个外键 def list(reques ...

  6. mybatis学习四 mybatis的三种查询方式

    <select id="selAll" resultType="com.caopeng.pojo.Flower"> select * from fl ...

  7. Hibernate的四种查询方式(主键查询,HQL查询,Criteria查询,本地sql查询)和修改和添加

    Hibernate的添加,修改,查询(三种查询方式)的方法: 案例演示: 1:第一步,导包,老生常谈了都是,省略: 2:第二步,创建数据库和数据表,表结构如下所示: 3:第三步创建实体类User.ja ...

  8. linux学习之centos(二):虚拟网络三种连接方式和SecureCRT的使用

    ---操作环境--- 虚拟机版本:VMware Workstation_10.0.3 Linux系统版本:CentOS_6.5(64位) 物理机系统版本:win10  一.虚拟网络三种连接方式 当在V ...

  9. Android平台中实现对XML的三种解析方式

    本文介绍在Android平台中实现对XML的三种解析方式. XML在各种开发中都广泛应用,Android也不例外.作为承载数据的一个重要角色,如何读写XML成为Android开发中一项重要的技能. 在 ...

随机推荐

  1. 团队作业4——第一次项目冲刺(Alpha版本)5th day

    一.Daily Scrum Meeting照片 二.燃尽图 三.项目进展 计时模式已经大致完成了 接下来是记录成绩的部分 四.困难与问题 1.新语言的学习与适应较慢,整体的开发进展达不到预期效果, 2 ...

  2. 201521123051《Java程序设计》第八周学习总结

    1. 本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结集合与泛型相关内容. 1.2 选做:收集你认为有用的代码片段 集合与泛型综合示例 import java.util.ArrayLis ...

  3. 201521123076 《Java程序设计》第9周学习总结

    1. 本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结异常相关内容. 2. 书面作业 本次PTA作业题集异常 1.常用异常 题目5-1 1.1 截图你的提交结果(出现学号) 1.2 自己 ...

  4. 201521123012 《Java程序设计》第十三周学习总结

    1. 本周学习总结 1.1 以你喜欢的方式(思维导图.OneNote或其他)归纳总结多网络相关内容. 2. 书面作业 1. 网络基础 1.1 比较ping www.baidu.com与ping cec ...

  5. Spring在JSP页面使用ServletContext

    在 JSP 页面使用Application 可以 看到使用的是WebApplicationContextUtils 而不是WebApplicationContext.ROOT_WEB_APPLICAT ...

  6. [AHOI2001]彩票摇奖

    [AHOI2001]彩票摇奖 题目描述 为了丰富人民群众的生活.支持某些社会公益事业,北塔市设置了一 项彩票.该彩票的规则是: (1) 每张彩票上印有 7 个各不相同的号码,且这些号码的取指范围为 1 ...

  7. 极化码之tal-vardy算法(2)

    上一节我们了解了tal-vardy算法的大致原理,对所要研究的二元输入无记忆对称信道进行了介绍,并着重介绍了能够避免输出爆炸灾难的合并操作,这一节我们来关注信道弱化与强化操作. [1]<Chan ...

  8. Musical Theme poj1743(后缀数组)

    Musical Theme Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 16757   Accepted: 5739 De ...

  9. GBDT(MART)概念简介

    GBDT(Gradient Boosting Decision Tree) 又叫 MART(Multiple Additive Regression Tree),是一种用于回归的机器学习算法,该算法由 ...

  10. 关于加载离线SHP文件、geodatabase文件所遇到的路径问题

    正文开始之前还是先吐槽一下,一行代码DEBUG了一天不知道怎么改,终于误打误撞弄出来了(以下以shp文件为例) 对于虚拟机测试 public String getPath(){ File sdDir ...