hibernate对数据库的查询其实有很多种方法,下面我来介绍我知道的两种方法,以及它们可能会遇到的问题,这里前两种都是查询所有结果

最后一种是 使用hibernate查询一条记录。

第一种方法

public void queryTest() {
Configuration configuration = new Configuration();//默认就是加载hibernate.cfg.xml
configuration.configure();
//获得会话工厂,创建会话
SessionFactory buildSessionFactory = configuration.buildSessionFactory();
//获得session
Session session = buildSessionFactory.openSession(); //开启事务
Transaction tx = session.beginTransaction();

         //注意这个地方,直接from 就行,from后面跟的是自己建的bean类名,不是表名
Query createQuery = session.createQuery("from Student");
List<Student> students = createQuery.list();
for(Student student:students) {
System.out.println(student);
} //关闭资源
session.close();
buildSessionFactory.close();
}

!!!!!!! 这种查询方式大家注意了,这里我的bean名字是Student,所以上面是from Student

第二种方法:

package com.cidp.test;

import java.util.List;

import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import org.junit.Test; import com.cidp.pojo.Student; public class MyTest { //测试插入数据
@Test
public void queryTest() {
Configuration configuration = new Configuration();//默认就是加载hibernate.cfg.xml
configuration.configure();
//获得会话工厂,创建会话
SessionFactory buildSessionFactory = configuration.buildSessionFactory();
//获得session
Session session = buildSessionFactory.openSession(); //开启事务
Transaction tx = session.beginTransaction();

          //这种主要就是自己写sql语句,这里就是sql怎么写就是怎样的了。
Query query = session.createSQLQuery("select * from stu_info").addEntity(Student.class);
List<Student> list = (List<Student>)query.list(); for(Student student:list) {
System.out.println(student);
} //关闭资源
session.close();
buildSessionFactory.close();
}
}

第三种:

package com.cidp.test;

import java.util.List;

import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import org.junit.Test; import com.cidp.pojo.Student; public class MyTest { //测试插入数据
@Test
public void queryOneTest() {
Configuration configuration = new Configuration();//默认就是加载hibernate.cfg.xml
configuration.configure();
//获得会话工厂,创建会话
SessionFactory buildSessionFactory = configuration.buildSessionFactory();
//获得session
Session session = buildSessionFactory.openSession(); //开启事务
Transaction tx = session.beginTransaction(); Query query = session.createSQLQuery("select * from stu_info where id = 2");           //返回的是Object[], 存放的是一条数据中,的每一列元素,例如2 李四 123456
Object[] uniqueResult = (Object[]) query.uniqueResult();
for(Object object : uniqueResult) {
System.out.print(object + " ");
}
System.out.println();
//关闭资源
session.close();
buildSessionFactory.close();
}
}

hibernate对数据库查询的坑的更多相关文章

  1. 2018.11.13 Hibernate 中数据库查询中的Criteria查询实例

    Criteria是面向对象的无语句查询 Demo.java package com.legend.b_criteria; import java.util.List; import org.hiber ...

  2. Hibernate自定义数据库查询(排序、输出条数)

    Hibernate数据库操作类(eg:TexDAO.java) /* * queryString HQL语句,first开始条数, max输出条数 ,norder排序 * 例: List lis = ...

  3. hibernate框架之-查询结果集返回类型

    Hibernate支持HQL和SQL的查询,返回结果支持POJO类型或字段/数组的形式. 开发中用Hibernate进行数据库查询,用的是SQL.原来需要查询一个表的几乎所有字段,所以我使用了addE ...

  4. [转载]Hibernate如何提升数据库查询的性能

    目录(?)[-] 数据库查询性能的提升也是涉及到开发中的各个阶段在开发中选用正确的查询方法无疑是最基础也最简单的 SQL语句的优化 使用正确的查询方法 使用正确的抓取策略 Hibernate的性能优化 ...

  5. 各数据库查询前N条记录的SQL语句

    sql在不同数据库查询前几条数据 1. ORACLE SELECT * FROM TABLE_NAME WHERE ROWNUM <= N;  HQL: from table_name t or ...

  6. Hibernate原生SQL查询

    最近在做一个较为复杂的查询,hibernate基本的查询不能满足,只好使用其提供的原生sql查询.参考网上的一些资料,做一些总结. 对原生SQL查询执行的控制是通过SQLQuery接口进行的,通过执行 ...

  7. [转]Hibernate不能自动建表解决办法及Hibernate不同数据库的连接及SQL方言

    最近开始学Hibernate,看的是李刚的那本<轻量级java ee企业应用实战>.头一个hibernate程序,我原原本本的按照书上例子写下来,同时只是改动了些mysql的连接参数,并且 ...

  8. Hibernate之HQL查询

    一.Hibernate 提供了以下几种检索对象的方式: 导航对象图检索方式: 根据已经加载的对象导航到其他对象 OID 检索方式: 按照对象的 OID 来检索对象 HQL 检索方式:使用面向对象的 H ...

  9. 使用hibernate更新数据库记录的信息的相关学习记录

    截选代码(可能遗漏标点符号): package name.sql; import java.util.List; import name.session.HibernateSessionFactory ...

随机推荐

  1. Mybatis学习(2)原始dao开发和使用mapper接口代理开发

    基础知识: 1).SqlSessionFactoryBuilder: 通过SqlSessionFactoryBuilder创建会话工厂SqlSessionFactory.将SqlSessionFact ...

  2. 关于pycharm导入其他项目时出现找不到python无法运行的问题

    之前拿到一个别的人用scrapy写的一个爬虫想运行看看,然后就出了类似于这种错误(类似的,这个是网上找的),一直提示找不到XXX路径下的python,然后无法运行执行文件... 我一看这个简单,这种就 ...

  3. selenium除错

    1.使用命令行启动selenium 下载selenium jar包 http://selenium-release.storage.googleapis.com/index.html 此处下载的是se ...

  4. 1036 Boys vs Girls (25 分)

    1036 Boys vs Girls (25 分) This time you are asked to tell the difference between the lowest grade of ...

  5. mavenProfile文件配置和简单入门

    1什么是MavenProfile 在我们平常的java开发中,会经常使用到很多配制文件(xxx.properties,xxx.xml),而当我们在本地开发(dev),测试环境测试(test),线上生产 ...

  6. 5.用 CSS 创作一个立体滑动 toggle 交互控件

    原文地址:https://segmentfault.com/a/1190000014638655 HTML代码: <html> <head> <link rel=&quo ...

  7. svn使用---在CentOS 7上搭建SVN服务器 及windows搭建svn步骤

    svn搭建方法: https://blog.csdn.net/helijie92902/article/details/51935122?foxhandler=RssReadRenderProcess ...

  8. JS转义解码方法

    之前只知道可以解决传值乱码问题,今天刚好看到,从新补充下: JavaScript中有三个可以对字符串编码的函数,分别是: 转义方法: escape();//函数可对字符串进行编码 encodeURI( ...

  9. java msgbox

    JAVA import javax.swing.JOptionPane; JOptionPane.showMessageDialog( null,"sample dialog !" ...

  10. myeclipse配置gradle插件

    首先,到Gradle官网下载最新版的gradle,已经到了2.13了 下载地址是 http://gradle.org/gradle-download/ 下载下来解压到任意目录 然后配置Windows环 ...