`
endual
  • 浏览: 3560913 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

hibernate 增删改查

 
阅读更多

mysql中库表News,字段如下

id      |  int     |  auto_increment  |  primary key

title   |  varchar

content |  varchar

date    |  varchar

 

1:Hibernate的insert操作

        Session session = HibernateSessionFactory.getSession();

 

        News news = new News();

        news.setContent("my content");

        news.setTitle("my title");

        news.setDate("my date"); //news是VO

 

        Transaction trans = session.beginTransaction();

        session.save(news); //news是PO

        trans.commit();     //任何有关数据库更新的操作都是commit后进数据库的

        HibernateSessionFactory.closeSession();

 

2:Hibernate的update操作

        Session session = HibernateSessionFactory.getSession();

 

        News news = new News();

        news.setId(103);  //id不可少,Hibernate只通过id来查找数据库

        news.setContent("update content");

        news.setTitle("update title");

 

        Transaction trans = session.beginTransaction();

        session.update(news);

        trans.commit();

        HibernateSessionFactory.closeSession();

 

注意这里我们更新数据不想对date进行更新,所以没写 setDate ,但Hibernate会认为我们是想把date设置为null,所以如果要更新表中一些字段,最好用下面的方法。

 

        Session session = HibernateSessionFactory.getSession();

 

        Transaction trans = session.beginTransaction();

        News news = (News)session.get(News.class, 103);  //*****(1)

        news.setDate("update date");  //*****(2)

        session.save(news);  //*****(3)

        trans.commit();

        HibernateSessionFactory.closeSession();

 

这里其实对数据库进行了两次操作,(1)时从数据库中把相应纪录查找出来,这里news是一个PO,(2)对PO进行date的更新,其他数据没 变,然后(3)保存,由于(1)查出的数据就有title,content,所以保存时候title和content都不会是null。

 

3:Hibernate的delete操作

        Session session = HibernateSessionFactory.getSession();

 

        Transaction trans = session.beginTransaction();

        News news = new News();

        news.setId(8);  //用下面那句效果一样,只是多了句select

//      News news = (News)session.get(News.class, 8);

 

        session.delete(news);

        trans.commit();

        HibernateSessionFactory.closeSession();

注意,只能通过id来删除数据,不能通过title或content来删除,会报缺少标示符错误。

 

使用hql来删除(可作批量删除)

        Session session = HibernateSessionFactory.getSession();

        String hql = "delete Billdetail where name>'detailName1'";

        Query query = session.createQuery(hql);

        int ref = query.executeUpdate();

        session.beginTransaction().commit();

        System.out.println("delete dates=>"+ref); //操作条数

 

        session.close();

 

 

4:Hibernate的select操作

 

Hibernate的select操作非常丰富,这里写常用的:

 

1.criteria查询

        Session session = HibernateSessionFactory.getSession();

 

        Criteria c = session.createCriteria(News.class);//News是类,所以N大写

        c.add(Expression.lt("date", "date5"));

        c.add(Expression.between("date", "date1", "date8"));

        c.addOrder(Order.desc("date"));

 

        List<News> list = c.list();

        for(int i=0;i<list.size();i++)

        {

            System.out.println(list.get(i).getId()+":"+list.get(i).getDate());

        }

        HibernateSessionFactory.closeSession();

 

比较符合面向对象的概念,因为库表和JAVA类已经作了映射关系,注意Hibernate的所有操作都是针对JAVA类的,而不是库表,所以要区分大小写。

上面的查询相当于sql是: select * from news where date < 'date5' and date BETWEEN 'date1' and 'date8' ORDER by date desc;

 

2.HQL查询

        Query query = session.createQuery("from News ");

        List<News> list = query.list();  //遍历同上

 

HQL是Hibernate主推的查询方式,和普通SQL语句也比较接近,但很重要一点不同就是HQL中from后面的是JAVA类名,不是库表名,切忌!!!其它就是如果查询全字段 "select *" 可以省略不写。

 

当不是查询全字段,或者是从两张表中联合查询数据时,返回的是一个数组:

        Session session = HibernateSessionFactory.getSession();

 

        Query query = session.createQuery("select n.id,n.title,u.username from News as n,User u");

        List list = query.list();//这里每一行都是一个1维数组

        for(int i=0;i<list.size();i++)

        {

            Object []o = (Object[])list.get(i);  //转型为数组

            int id = (Integer)o[0];  //和select中顺序的类型相对应,可以是类

            String title = (String)o[1];

            String username = (String)o[2];

            System.out.println("id:"+id+" , "+"title"+title+" , "+username);

        }

        HibernateSessionFactory.closeSession();

 

查询结果集的大小(和Hibernate2中稍微有点不同)

(Integer)session.createQuery("select count(*) from User").iterate().next();

 

 

3.SqlQuery查询

        List<News> list = session.createSQLQuery("select * from News").addEntity(News.class).list(); 

 

addEntity 不能忘记,这种查询方式是把查询好的结果放到一个实体中,再遍历操作,不推荐使用。

 

SqlQuery查询一些字段时候用addScalar:

SQLQuery query = session.createSQLQuery("select id,title from News");

        query.addScalar("id", Hibernate.INTEGER);  //注册字段类型,同下

        query.addScalar("title",new org.hibernate.type.StringType());

        List list = query.list();

        for(int i=0;i<list.size();i++)

        {

            Object[] o = (Object[])list.get(i);

            int id = (Integer)o[0];

            String title = (String)o[1];

            System.out.println("id:"+id+" , title:"+title);

        }

 

javabean的属性可以作为命名的查询参数(HQL)

        Session session = HibernateSessionFactory.getSession();

        Transaction trans = session.beginTransaction()

 

        Query query = session.createQuery("from room in class Room where room.name=:a")

        query.setParameter("a", "room1");  //和prepareStatement相似

 

//     Room room1 = new Room(); 

//     room1.setName("room1");    

//     Query query = session.createQuery("from room in class Room where room.name=:name");  //如果用javabean设置参数来查询,=:name的name一定和Room中对应

//     query.setProperties(room1);

 

        List<Room> list = query.list();

        for(int i=0;i<list.size();i++)

        {

            System.out.println(list.get(i).getName()+":"+list.get(i).getDescription());

        }

 

        trans.commit();

        HibernateSessionFactory.closeSession()

分享到:
评论

相关推荐

    hibernate增删改查

    hibernate增删改查

    Struts+Hibernate增删改查

    因项目还在开发,所以本人只拿出一块单独的struts+hibernate增、删、改、查来演示,具体的一些包一看就知道; 项目直接在MyEclipse6.0运行,环境是里面自带的,用过的人都知道。本人测试没有问题。 具体的页面...

    hibernate增删改查小例子

    【hibernate增删改查小例子】是一个基础的教程,旨在帮助初学者理解如何使用Hibernate框架进行数据库操作。Hibernate是Java开发中的一个强大的对象关系映射(ORM)框架,它简化了数据库交互,使开发者可以更专注于...

    封装了一个Hibernate增删改查的工具类

    在提供的压缩包中,`Hibernate增删改查的工具类`实现了这些基本功能,使得在项目中调用这些方法即可完成数据库操作。工具类通常包含静态方法,以便在不创建实例的情况下直接调用,减少了内存消耗。这些方法可能包括...

    hibernate增删改查事例的web工程

    【hibernate增删改查事例的web工程】是一个基于Hibernate框架的Web应用程序,旨在帮助开发者通过实际操作来理解和掌握Hibernate在数据库操作中的基本功能,包括插入(Insert)、删除(Delete)、更新(Update)和...

    struts hibernate增删改查

    基于Struts 2+Hibernate实现员工管理系统。一个单位有多个部门,每个部门有多名员工,每个员工只属于一个部门。基于该要求,实现员工和部门的管理(包括添加、查询、删除和修改等操作),并且要实现部门与员工之间的...

    struts2+hibernate增删改查demo

    这个"struts2+hibernate增删改查demo"是一个完整的实例,展示了如何将这两个框架集成来实现对数据库的基本操作:添加(Add)、删除(Delete)、修改(Update)和查询(Query)。下面,我们将深入探讨这两个框架及其...

    hibernate增删改查和动态sql

    “hibernate增删改查和动态sql”这个标题涵盖了两个主要的Hibernate使用场景。首先,"增删改查"(CRUD操作)是任何数据库操作的基础,包括创建(Create)、读取(Read)、更新(Update)和删除(Delete)。在...

    spring+struts2+hibernate 增删改查

    本篇文章将详细探讨这三大框架如何协同工作,实现数据的增删改查(CRUD)功能。 首先,Spring框架是一个全面的后端应用程序开发框架,它提供了依赖注入(DI)和面向切面编程(AOP)等核心特性。在"Spring+Struts2+...

    Hibernate 增删改查

    **Hibernate 增删改查全面指南** 在Java开发中,Hibernate是一个强大的对象关系映射(ORM)框架,它极大地简化了数据库操作。本指南将深入探讨Hibernate如何进行增、删、改、查(CRUD)操作,这些是任何数据库应用...

    struts2+hibernate增删改查+分页

    综上所述,"struts2+hibernate增删改查+分页"是一个基础的Java Web开发示例,它涵盖了MVC架构下,如何利用Struts2处理用户请求,通过Hibernate进行数据库操作,以及实现简单的分页功能。这种组合在实际项目中非常...

    Hibernate增删改查

    在"Hibernate增删改查"这个小实例中,可能包含以下步骤: 1. 创建实体类,例如一个User类,包含id、name、email等属性,并使用`@Entity`注解标记为持久化类。 2. 定义属性的映射,使用`@Id`、`@GeneratedValue`、`@...

    hibernate增删改查代码

    本篇文章将详细解析标题"hibernate增删改查代码"所涵盖的知识点,并结合描述,为初学者提供深入理解Hibernate的基础。 首先,让我们了解Hibernate的核心概念。Hibernate是一个Object-Relational Mapping(ORM)框架...

    SpringMVC+Spring+HIbernate增删改查

    在这个MyEclipse项目中,我们将深入探讨这三大框架如何协同工作,实现数据库的增删改查操作。 SpringMVC是Spring框架的一个模块,专门用于处理Web请求。它遵循Model-View-Controller(MVC)设计模式,将业务逻辑、...

    Spring+Hibernate 增删改查等基本操作

    在"Spring+Hibernate 增删改查等基本操作"这个主题中,我们主要探讨的是如何整合这两个框架来实现数据持久化。以下是一些关键的知识点: 1. **Spring**: - **依赖注入(DI)**:Spring的核心特性之一,通过XML...

Global site tag (gtag.js) - Google Analytics