HibernateTemplate、HibernateDaoSupport两种方法实现增删改查Good(转)
Spring+Hibernate两种方法实现增删改查
首先,定义一个Customer的bean类,设置好Customer.hbm.xml文件。再定义好一个Dao接口。准备好一个jdbc.properties文件。
第一种方法:
在dao类中定义一个HibernateTemplate类的对象,用该对象调用HibernateTemplate模板封装好的方法,如下:
/***
* hibernateTemplate的转配模式
*/
public class CustomerDaoImpl implements CustomerDao {
// 设置hibernateTemplate属性
private HibernateTemplate hibernateTemplate; // 必须设置set方法
public void setHibernateTemplate(HibernateTemplate hibernateTemplate) {
this.hibernateTemplate = hibernateTemplate;
} // 插入方法
@Override
public void insert(Customer entity) {
hibernateTemplate.save(entity);
} // 删除方法(按照试题删除)
@Override
public void delete(Customer entity) {
hibernateTemplate.delete(entity); } // 删除方法,按id删除,该方法不成功
@Override
public void deleteById(int id) {
// hibernateTemplate.
} // 查询所有记录
@Override
public List<Customer> selectAll() {
// TODO Auto-generated method stub
List<Customer> entities = hibernateTemplate.find("from Customer");
return entities;
} // 按照id查找记录
@Override
public Customer selectById(int id) {
// TODO Auto-generated method stub
List<Customer> entitise = hibernateTemplate
.find("from Customer where id=" + id);
if (entitise.size() > 0) {
Customer entity = entitise.get(0);
return entity;
}
return null;
} // 更新方法
@Override
public void update(Customer entity) {
// TODO Auto-generated method stub
hibernateTemplate.update(entity);
} }
xml中的部分代码如下:
<!-- 分散配置 -->
<context:property-placeholder location="jdbc.properties" /> <!-- c3p0数据源 -->
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<!-- 驱动程序 -->
<property name="driverClass">
<value>${jdbc.driverClass}</value>
</property> <!-- 连接的url地址 -->
<property name="jdbcUrl">
<value>${jdbc.url}</value>
</property> <!-- 连接的用户名 -->
<property name="user">
<value>${jdbc.user}</value>
</property> <!-- 连接的密码 -->
<property name="password">
<value>${jdbc.password}</value>
</property> <!-- 最大池数 -->
<property name="maxPoolSize">
<value>${c3p0.pool.max}</value>
</property> <!-- 最小池数 -->
<property name="minPoolSize">
<value>${c3p0.pool.min}</value>
</property>
<!-- 默认初始化的池数 -->
<property name="initialPoolSize">
<value>${c3p0.pool.init}</value>
</property>
</bean> <bean id="sessionFactory"
class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<!-- 设置数据源 -->
<property name="dataSource" ref="dataSource" />
<!-- 属性设置 -->
<property name="hibernateProperties">
<props>
<prop key="hibernate.show_sql">${hibernate.show_sql}</prop>
<prop key="hibernate.hbm2ddl.auto">${hibernate.hbm2ddl.auto}</prop>
</props>
</property>
<!-- 映射文件配置 -->
<property name="mappingResources">
<list>
<value>cn/csdn/domain/Customer.hbm.xml</value>
</list>
</property> </bean> <span style="background-color: #ff0000;"><!-- hibernate模板 -->
<bean id="hibernateTemplate" class="org.springframework.orm.hibernate3.HibernateTemplate">
<property name="sessionFactory" ref="sessionFactory" />
</bean></span> <!-- dao的操作的bean -->
<bean id="customerDaoImpl" class="cn.csdn.dao.CustomerDaoImpl">
<!-- 注入依赖模板 -->
<property name="hibernateTemplate" ref="hibernateTemplate" />
</bean>
第二种方法:
Dao实现类继承HibernateDaoSupport类,该类是抽象类,该类中有一个HibernateTemplate的属性,通过this.getHibernateTemplate()可获得一个HibernateTemplate类的对象。
Dao实现类中的代码如下:
/**
* 继承HibernateDaoSupport类,HibernateDaoSupport类中封装了一个hibernateTemplate变量
*/
public class CustomerDaoImpl1 extends HibernateDaoSupport implements
CustomerDao { // 添加记录
@Override
public void insert(Customer entity) {
this.getHibernateTemplate().save(entity);
} // 删除记录(按照实体删除)
@Override
public void delete(Customer entity) {
// TODO Auto-generated method stub
this.getHibernateTemplate().delete(entity); } // 删除记录(按id删除),不成功
//
@Override
public void deleteById(int id) {
// TODO Auto-generated method stub
// this.getHibernateTemplate().delete(entity);
} // 查询所有的记录
@Override
public List<Customer> selectAll() {
// TODO Auto-generated method stub
List<Customer> entities = this.getHibernateTemplate().find(
"from Customer");
return entities;
} // 按照id查找记录
@Override
public Customer selectById(int id) {
// TODO Auto-generated method stub
List<Customer> entities=this.getHibernateTemplate().find("from Customer where id="+id);
if(entities.size()>0){
Customer entity=entities.get(0);
return entity;
}
return null;
} // 更新的方法
@Override
public void update(Customer entity) {
// TODO Auto-generated method stub
this.getHibernateTemplate().update(entity);
} }
xml中的部分代码:
<!-- 分散配置 -->
<context:property-placeholder location="jdbc.properties" /> <!-- c3p0数据源 -->
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<!-- 驱动程序 -->
<property name="driverClass">
<value>${jdbc.driverClass}</value>
</property> <!-- 连接的url地址 -->
<property name="jdbcUrl">
<value>${jdbc.url}</value>
</property> <!-- 连接的用户名 -->
<property name="user">
<value>${jdbc.user}</value>
</property> <!-- 连接的密码 -->
<property name="password">
<value>${jdbc.password}</value>
</property> <!-- 最大池数 -->
<property name="maxPoolSize">
<value>${c3p0.pool.max}</value>
</property> <!-- 最小池数 -->
<property name="minPoolSize">
<value>${c3p0.pool.min}</value>
</property>
<!-- 默认初始化的池数 -->
<property name="initialPoolSize">
<value>${c3p0.pool.init}</value>
</property>
</bean> <bean id="sessionFactory"
class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<!-- 设置数据源 -->
<property name="dataSource" ref="dataSource" />
<!-- 属性设置 -->
<property name="hibernateProperties">
<props>
<prop key="hibernate.show_sql">${hibernate.show_sql}</prop>
<prop key="hibernate.hbm2ddl.auto">${hibernate.hbm2ddl.auto}</prop>
</props>
</property>
<!-- 映射文件配置 -->
<property name="mappingResources">
<list>
<value>cn/csdn/domain/Customer.hbm.xml</value>
</list>
</property> </bean> <!-- 设置HibernateDaoSupport抽象类-->
<bean id="hibernateDaoSupport"
class="org.springframework.orm.hibernate3.support.HibernateDaoSupport"
abstract="true">
<property name="sessionFactory" ref="sessionFactory" />
</bean> <!-- dao的操作的bean -->
<bean id="customerDaoImpl" class="cn.csdn.dao.CustomerDaoImpl1"
parent="hibernateDaoSupport" />
<bean id="adminDAO" class="com.haier.uhome.hr91.manager.dao.AdminDAO">
parent="hibernateDaoSupport"/>
或者如下:
<bean id="customerDaoImpl" class="cn.csdn.dao.CustomerDaoImpl1">
<property name="sessionFactory">
<ref local="sessionFactory" />
</property>
</bean> <bean id="adminDAO" class="com.haier.uhome.hr91.manager.dao.AdminDAO">
<property name="sessionFactory">
<ref local="sessionFactory" />
</property>
</bean>
HibernateTemplate、HibernateDaoSupport两种方法实现增删改查Good(转)的更多相关文章
- get,post,put,delete四种基础方法对应增删改查
PUT,DELETE,POST,GET四种基础方法对应增删改查 1.GET请求会向数据库发索取数据的请求,从而来获取信息,该请求就像数据库的select操作一样,只是用来查询一下数据,不会修改.增加数 ...
- Hibernate通过createSQLQuery( )方法实现增删改查
一.项目结构 二.hibernate核心配置文件: hibernate.cfg.xm <?xml version="1.0" encoding="UTF-8&q ...
- VS连接Access数据库--连接字符串及执行查询语句的方法(增删改查,用户名查重,根据用户获取密码查询)
ACCESS数据的连接及语句执行操作,不难,久不用会生疏,每次都要找资料,干脆自己整理下,记录下来,需要的时候,直接查看,提高效率.也供初学者参考 1.连接字符串 public static stri ...
- android 数据库的增删改查的另一种方式
老师笔记 # 3 Android下另外一种增删改查方式 1.创建一个帮助类的对象,调用getReadableDatabase方法,返回一个SqliteDatebase对象 2.使用Sq ...
- Day 18 :面向对象[基础,继承,组合]类的增删改查
有的人说,编程有3种范式: 1.面向过程:就是分析出解决问题所需要的步骤,然后用函数把这些步骤一步一步实现,使用的时候一个一个依次调用就可以了. 2.面向函数:面向函数是面向过程的升级版,也就是把每个 ...
- Android下数据库操作——增删改查
Android下数据库第一种方式增删改查 1.创建一个帮助类的对象,调用getReadableDatabase方法,返回一个SqliteDatebase对象 2.使用SqliteDat ...
- SSHE框架整合(增删改查)
1.前期准备:jar包(c3p0.jdbc ,各个框架) web.xml文件:spring的 转码的,和Struts2的过滤器 <?xml version="1.0" e ...
- MVC——数据库增删改查(aspx)
MVC: V(View) :视图→就是页面的模板 C(Control): 控制器→客户主要面对的就是控制器, M(Model):模板→在模板里面主要就是写关于数据库的各种增删改查的方法 它们之间的关系 ...
- 【DRP】-Dao层常用功能代码:增删改查
本系列博客内容为:做DRP系统中Dao层常用功能. 该项目采用MVC架构 C(Controller)控制器,主要职责;1.取得表单参数:2.调用业务逻辑:3.转向页面 M(Model)模型,主要职责: ...
随机推荐
- Linux 命令 - mkdir: 创建目录
命令格式 mkdir [OPTION]... DIRECTORY... 命令参数 -m, --mode=MODE 设置文件的模式,类似于 chmod 命令. -p, --parents 需要时创建指定 ...
- 第四节 使用XML
可扩展标记语言XML,是一种平台无关的数据表示格式,对特定数据表示需求的数据来说,比关系型格式有一定的优势. XML文档可以是计算机上的物理文件,网络上的数据流,或者仅仅是内存中的字符串.但是,XML ...
- Android实现双进程守护 (转)
做过android开发的人应该都知道应用会在系统资源匮乏的情况下被系统杀死!当后台的应用被系统回收之后,如何重新恢复它呢?网上对此问题有很多的讨论.这里先总结一下网上流传的各种解决方案,看看这些办法是 ...
- Android简单计算器
这是很久之前做的,方法很简单,都是一些基础的,不足的是还有很多功能不够. activity_main.xml布局: <LinearLayout xmlns:android="http: ...
- oracle是数据库的学习第一节:数据库的安装
一.本地oracle服务器 1.安装oracle服务器,可以到oracle官方网站上下载与自己电脑匹配的服务器,一般用10g,或者11g; 2.打开cmd,打开sql*plus,之后可以写SQL语句了 ...
- Commons-logging + Log4j
一.Commons-logging能帮我们做什么? 1.提供一个统一的日志接口,简单了操作,同时避免项目与某个日志实现系统紧密耦合 2.自动选择适当的日志实现系统 a.classpath下查找comm ...
- RSS订阅推荐
科技新闻 虎嗅网 http://www.huxiu.com/ 科技博客的新生力量,文章以观点鲜明出名: 36氪 http://www.36kr.com/ 科技博客,关注创业,可以免费发表创业公司新闻 ...
- OpenGL9-(FreeImage)加载图片-作为纹理
/*** 这个例子展示如何使用FreeImage加载图片作为纹理* 初学者,在学习OpenGL的时候,往往因为OpenGL读图片没有那么方便* 而浪费了大量的时间在研究图片格式上,其实大可不必. 1. ...
- 【leetcode】7. Reverse Integer
题目描述: Reverse digits of an integer. Example1: x = 123, return 321Example2: x = -123, return -321 解题思 ...
- Adobe Photoshop CS4 Extended CS4 激活序列号
Adobe Photoshop CS4 Extended CS4 激活序列号(SN):1330-1779-4488-2103-6954-09161330-1170-1002-7856-5023-077 ...