DAO层的CRUD操作该使用getHibernateTemplate()下的方法

今天突然想总结下,DAO层继承了HibernateDaoSupport之后的查询是该使用哪个:

方式1:

Session session  = this.getSeesion();    在一个线程中可能get很多session 很可能导致数据库连接超过上限。所以推荐使用getHibernateTemplate

session.CreateQuery("hql"); 或者session.CreateSqlQuery("sql")  ;

方式2:

Session session  = this.getHibernateTemplate().getSessionFactory().openSession();

session.CreateQuery("hql"); 或者session.CreateSqlQuery("sql")  ;

方式3:

Session session  = this.getHibernateTemplate().getSessionFactory().getCurrentSession();

session.CreateQuery("hql"); 或者session.CreateSqlQuery("sql")  ;

方式4(以下都是Hql查询):

this.getHiernateTemplate().find(......);

this.getHiernateTemplate().save(......);

this.getHiernateTemplate().update(......);

this.getHiernateTemplate().merge(......);

this.getHiernateTemplate().saveOrUpdate(......);

this.getHiernateTemplate().executeFind(回调函数)  返回的是集合, 回调函数中可以使用sql或者hql查询关键点是回调函数内部的

session.CreateQuery("hql"); 或者session.CreateSqlQuery("sql")  ;来决定.  一般用来返回记录集合

this.getHiernateTemplate().execute(回调函数)  返回的是Object, 回调函数中可以使用sql或者hql查询关键点是回调函数内部的

session.CreateQuery("hql"); 或者session.CreateSqlQuery("sql")  ;来决定.  一般用来返回记录个数

=====================================

综合以上这么多的操作,分析后决定还是使用最后面的方式(方式4) 遇到带有多个查询条件的或者原生sql查询可以使用基于回调的操作实现.同样保证了session的自动提交和关闭.  个人愚见,还望多多交流.

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用JdbcTemplate实现用户表的CRUD操作非常简单和高效。JdbcTemplate是Spring框架提供的一个持久化框架,通过对JdbcTemplate进行配置和应用可以实现对数据库的访问和操作。 首先,我们需要创建一个User类来表示用户表的实体,包含用户名、密码、邮箱等属性。然后,在数据库中创建一个用户表,表结构与User类对应。接下来,在Spring配置文件中配置数据源和JdbcTemplate。在配置文件中指定数据源的连接信息,然后将数据源和JdbcTemplate配置为Spring容器的bean。 在代码中,我们可以通过@Autowired注解将JdbcTemplate注入到UserService类中,然后就可以使用JdbcTemplate对用户表进行CRUD操作了。例如,要插入一个新用户,可以使用JdbcTemplate的update方法执行SQL插入语句。要删除一个用户,可以使用JdbcTemplate的update方法执行SQL删除语句。要更新一个用户的信息,可以使用JdbcTemplate的update方法执行SQL更新语句。要查询一个用户的信息,可以使用JdbcTemplate的queryForObject方法执行SQL查询语句。 使用JdbcTemplate实现用户表的CRUD操作具有很多优势。首先,它可以将所有的JDBC操作封装在一个类中,简化了代码的编写。其次,它提供了丰富的方法来执行SQL语句,可以满足各种不同的数据库操作需求。同时,它还支持事务管理,可以保证数据库操作的一致性和完整性。 总的来说,通过使用JdbcTemplate实现用户表的CRUD操作可以提高代码的可读性和可维护性,同时还可以让开发者更加专注于业务逻辑的实现。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值