spring和jdbctemplate
1.spring与jdbc整合应用
a。增删改
-获取connection
-获取statement
-设置sql中?参数
-执行sql操作
-释放connection
b。查询
-获取connection
-获取statement
-设置sql中?参数
-执行sql操作获取resultset结果
-将resultset结果封装成实体对象
-释放connection
1.spring提供了JdbcTemplate,编写DAO的工具类
a。jdbcTemplate.update("insert。。。。。",参数);
b。提供了aop事务管理(不需要再方法中追加事务提交和回滚)
c。提供了统一的异常处理DataAccessException
2.spring整合jdbc步骤
a。引入spring(ioc,aop,dao),数据库驱动,添加src/applicationContext.xml
b.编写实体类
c。编写DAO
d.在applicationContext.xml中扫描EmpDAO,注入JdbcTemplate对象
dbcp注入jdbctemplate,jdbctemplate注入empdao。
dbcp和jdbctemplate用的(xml的bean定义),empdao用的自动扫描。
例子:
spring.xml:
<!-- 开启自动扫描,扫描DAO -->
<context:component-scan base-package="org.alexhe"></context:component-scan>
<!-- 定义JdbcTemplate -->
<bean id="template" class="org.springframework.jdbc.core.JdbcTemplate">
<!-- 注入连接信息 -->
<property name="dataSource" ref="dbcp"></property>
</bean>
<bean id="dbcp" class="org.apache.commons.dbcp.BasicDataSource">
<property name="username" value="root"></property>
<property name="password" value="19850319a"></property>
<property name="driverClassName" value="com.mysql.jdbc.Driver"></property>
<property name="url" value="jdbc:mysql://localhost:3306/danei?useSSL=false&useUnicode=true&characterEncoding=utf8"></property>
</bean>
empdao.java:
@Repository//扫描Dao
public class EmpDao {
@Resource//注入
private JdbcTemplate template;//注入
public void save(Emp emp){
String sql="insert into emp(name,salary,age) values(?,?,?)";
Object[] params={emp.getName(),emp.getSalary(),emp.getAge()};
template.update(sql,params);
}
public void delete(int id){
String sql="delete from emp where id=?";
Object[] params={id};
template.update(sql,params);
}
public List<Emp> findAll(){
String sql="select * from emp";
EmpRowMapper rowMapper=new EmpRowMapper();
List<Emp> list=template.query(sql, rowMapper);
return list;
}
public Emp findById(int id){
String sql="select * from emp where id=?";
Object[] params={id};
EmpRowMapper rowMapper=new EmpRowMapper();
Emp emp=template.queryForObject(sql, params,rowMapper);
return emp;
}
}
Emp.java:
public class Emp implements Serializable{
private Integer id;
private String name;
private Double salary;
private Integer age;
省略get,set方法
EmpRowMapper.java:
/**将emp记录封装成Emp对象*/
public class EmpRowMapper implements RowMapper<Emp>{
@Override
public Emp mapRow(ResultSet rs, int index) throws SQLException {
// TODO Auto-generated method stub
Emp emp=new Emp();
emp.setId(rs.getInt("id"));
emp.setName(rs.getString("name"));
emp.setSalary(rs.getDouble("salary"));
emp.setAge(rs.getInt("age"));
return emp;
}
}
Test类:
public class TestEmpDao {
public static void main(String[] args) {
ApplicationContext ac=new ClassPathXmlApplicationContext("applicationContext.xml");
EmpDao empDao=ac.getBean("empDao",EmpDao.class);
Emp emp=new Emp();
emp.setName("spring1");
emp.setAge(201);
emp.setSalary(100010.0);
List<Emp> list=empDao.findAll();
System.out.println(list);
}
}
spring和jdbctemplate的更多相关文章
- Spring利用JDBCTemplate实现批量插入和返回id
1.先介绍一下java.sql.Connection接口提供的三个在执行插入语句后可取的自动生成的主键的方法: //第一个是 PreparedStatement prepareStatement(St ...
- Spring 中jdbcTemplate 实现执行多条sql语句
说一下Spring框架中使用jdbcTemplate实现多条sql语句的执行: 很多情况下我们需要处理一件事情的时候需要对多个表执行多个sql语句,比如淘宝下单时,我们确认付款时要对自己银行账户的表里 ...
- spring使用jdbcTemplate和jdbcdaosupport和namedparameter
jdbcTemplate: 首先连接数据库 <!-- 导入外部文件 --> <context:property-placeholder location="classpat ...
- Spring之JDBCTemplate学习
一.Spring对不同的持久化支持: Spring为各种支持的持久化技术,都提供了简单操作的模板和回调 ORM持久化技术 模板类 JDBC org.springframework.jdbc.core. ...
- spring+spring mvc+JdbcTemplate 入门小例子
大家使用这个入门时候 最好能够去 搜一下 spring mvc 的 原理,我放一张图到这里,自己琢磨下,后面去学习就容易了 给个链接 (网上一把,千万不能懒) https://www.cnblo ...
- spring 学习(四): spring 的 jdbcTemplate 操作
spring 学习(四): spring 的 jdbcTemplate 操作 spring 针对 javaee 的每一层,都提供了相应的解决技术,jdbcTemplate 的主要操作在 dao 层. ...
- Spring的jdbcTemplate 与原始jdbc 整合c3p0的DBUtils 及Hibernate 对比 Spring配置文件生成约束的菜单方法
以User为操作对象 package com.swift.jdbc; public class User { private Long user_id; private String user_cod ...
- spring学习(四)spring的jdbcTemplate(增删改查封装)
Spring的jdbcTemplate操作 1.Spring框架一站式框架 (1)针对javaee三层,每一层都有解决技术 (2)到dao 层,使用 jdbcTemplate 2.Spring对不同的 ...
- Spring:JdbcTemplate使用指南
Spring:JdbcTemplate使用指南 Spring:JdbcTemplate使用指南 前言: 本文指在介绍Spring框架中的JdbcTemplate类的使用方法,涉及基本的Spring反转 ...
- Spring中JdbcTemplate的基础用法
Spring中JdbcTemplate的基础用法 1.在DAO中使用JdbcTemplate 一般都是在DAO类中使用JdbcTimplate,在XML配置文件中配置好后,可以在DAO中注入即可. 在 ...
随机推荐
- seq_file学习(2)—— seq_file
li {list-style-type:decimal;}ol.wiz-list-level2 > li {list-style-type:lower-latin;}ol.wiz-list-le ...
- 简易RPC框架-SPI
*:first-child { margin-top: 0 !important; } body > *:last-child { margin-bottom: 0 !important; } ...
- Unity中InitializeOnLoad属性的妙用
InitializeOnLoad 属性应用的对象是 静态构造函数,它可以保证在编辑器启动的时候调用此函数.根据这个特性,可以在编辑器中设置定期的回调(帧更新),来实现类似watchFile的功能.这里 ...
- eclipse实现代码块折叠-类似于VS中的#region……#endregion
背 景 刚才在写代码的时候,写了十几行可以说是重复的代码: 如果整个方法或类中代码多了,感觉它们太TM占地方了,给读者在阅读代码上造成很大的困难,于是想到能不能把他们“浓缩”成一行,脑子里第一个闪现出 ...
- ABAP表抛FTP通用程序
主要功能: 1.支持R3所有表(标准.自建)下传,下传方式为FTP 2.支持输出字段选择及顺序调整 3.支持动态条件,不同的表会有不同的选择条件,根据不同的条件选择需要下传的数据 4.支持单表.多表. ...
- Android、iOS、和Web如何做灰度发布?
主要参考了: https://www.zhihu.com/question/21714205 https://www.zhihu.com/question/28296375 一.概述 ...
- How to copy the contents of std::vector to c-style static array,safely?
[问题] I am getting warning when using the std copy function. I have a byte array that I declare. byte ...
- 禅道docker
64位电脑安装禅道,满足发送邮件功能 第一步: docker ps 查看docker中的容器是否有禅道(docker ps -a 这个指令看的是所有容器,包括未运行的)ps:登录服务器这个步骤没 ...
- iOS实现pdf文件预览,上下翻页、缩放,读取pdf目录
最近有个朋友想做一个pdf预览,要求能够上下滑动翻页.带缩放.目录跳转功能. 因为之前我只做过简单的预览,那时直接用uiwebview实现的,这次找了下资料,发现一个比较好的库. 其原理实现: 自定义 ...
- CentOS 6.5 x64下安装宝塔面板、阿里安骑士
一.安装宝塔: CentOS下命令(https://www.bt.cn/bbs/thread-1186-1-1.html) yum install -y wget && wget -O ...