src\dayday\JDBCTestTest

package dayday;

import com.sun.org.apache.xalan.internal.xsltc.compiler.Template;
import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import org.springframework.jdbc.core.BeanPropertyRowMapper;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.core.RowMapper;
import org.springframework.jdbc.core.namedparam.BeanPropertySqlParameterSource;
import org.springframework.jdbc.core.namedparam.NamedParameterJdbcTemplate;
import org.springframework.jdbc.core.namedparam.SqlParameterSource; import javax.sql.DataSource; import java.sql.Connection;
import java.sql.SQLException;
import java.util.*; import static javafx.scene.input.KeyCode.S;
import static javafx.scene.input.KeyCode.T;
import static org.junit.Assert.*; /**
* Created by I am master on 2016/12/5.
*/
public class JDBCTestTest {
private ApplicationContext ctx=null;
private JdbcTemplate jdbcTemplate=null;
private UserDao userDao=null;
private NamedParameterJdbcTemplate namedParameterJdbcTemplate=null;
{
ctx=new ClassPathXmlApplicationContext("beans.xml");
jdbcTemplate=ctx.getBean("template",JdbcTemplate.class);
userDao=ctx.getBean(UserDao.class);
namedParameterJdbcTemplate=ctx.getBean("namedParameterJdbcTemplate",NamedParameterJdbcTemplate.class);
} @Test
public void testDataSource() throws SQLException {
DataSource dataSource=ctx.getBean(DataSource.class);
System.out.println(dataSource.getConnection());
}
@Test
/*
数据库的增删改查操作
*/
public void testUpdate(){
String sql="update bankuser set password=? where name=? ";
jdbcTemplate.update(sql,"daydayup01","dayday");
}
/*
执行批量处理
*/
@Test
public void testbatchUpdate(){
String sql="insert into bankuser values(?,?,?)";
List<Object[]> batcharrays=new ArrayList<>();
batcharrays.add(new Object[]{"A","1","100"});
batcharrays.add(new Object[]{"B","2","200"});
batcharrays.add(new Object[]{"C","3","300"});
jdbcTemplate.batchUpdate(sql,batcharrays);
}
/*
*从数据库中读取一条记录,并实际返回一个对象
*注意不是调用 queryForObject(String sql, Class<Employee> requiredType, Object... args) 方法!
**/
@Test
public void testqueryForObject(){
String sql="select password , property from bankuser where name=?";
RowMapper<User>rowMapper=new BeanPropertyRowMapper<>(User.class);
User user=jdbcTemplate.queryForObject(sql,rowMapper,"dayday");
System.out.println(user);
}
/*
* 查到实体类的集合
*/
@Test
public void testqueryForList(){
String sql="select password , name from bankuser where property>?";
RowMapper<User> rowMapper=new BeanPropertyRowMapper<>(User.class);
List<User> users=jdbcTemplate.query(sql,rowMapper,200);
System.out.println(users); }
/*
* 查询单列的值,或做统计查询
* */
@Test
public void testqueryForObject1(){
String sql="select count(name) from bankuser";
long count=jdbcTemplate.queryForObject(sql,long.class);
System.out.println(count);
}
@Test
public void testUserDao(){
System.out.println(userDao.get("dayday"));
}
/*
* 测试JdbcTemplate的具名参数
* 好处:若有多个参数,则不用再去对应位置,直接对应参数名
* 坏处:较为麻烦*/
@Test
public void testNamedParameterJdbcTemplate(){
String sql="insert into bankuser value(:name,:password,:property)";
Map<String,Object> paramMap=new HashMap<>();
paramMap.put("name","DD");
paramMap.put("password","4");
paramMap.put("property","400");
namedParameterJdbcTemplate.update(sql,paramMap);
}
/*
* 使用具名参数时可以使用update(String sql,SqlParameterSource paramSource)方法进行更新操作
* 1.sql语句中的参数名和类的属性一致
* 2.使用SqlParameterSource的BeanPropertySqlParameterSource实现类作为参数
* */
@Test
public void testNamedParameterJdbcTemplate2(){
String sql="insert into bankuser value(:name,:password,:property)";
User user=new User();
user.setName("E");
user.setPassword("5");
user.setProperty("500");
SqlParameterSource sqlParameterSource=new BeanPropertySqlParameterSource(user);
namedParameterJdbcTemplate.update(sql,sqlParameterSource);
}
}

src\dayday\UserDAO.java

src\dayday\User.java

package dayday;

/**
* Created by I am master on 2016/12/5.
*/
public class User {
private String name;
private String password;
private String property;
public void setName(String name){
this.name=name;
}
public void setPassword(String password){
this.password=password;
}
public void setProperty(String property){
this.property=property;
}
public String getName(){
return name;
}
public String getPassword(){
return password;
}
public String getProperty(){
return property;
}
public String toString(){
return "[ name="+name+" password="+password+" property="+property+"]";
}
}

src\jdbc.property

jdbc.user=root
jdbc.password=root
jdbc.jdbcUrl=jdbc:mysql://localhost:3306/bank
jdbc.driverClass=com.mysql.jdbc.Driver jdbc.initPoolSize=5
jdbc.maxPoolSize=10

src\beans.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd">
<!--导入资源文件-->
<context:property-placeholder location="classpath:jdbc.properties"/>
<!--配置c3p0数据源-->
<bean id="datasource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<property name="user" value="${jdbc.user}"></property>
<property name="password" value="${jdbc.password}"></property>
<property name="jdbcUrl" value="${jdbc.jdbcUrl}"></property>
<property name="driverClass" value="${jdbc.driverClass}"></property>
<property name="initialPoolSize" value="${jdbc.initPoolSize}"></property>
<property name="maxPoolSize" value="${jdbc.maxPoolSize}"></property>
</bean>
<!--配置Spring中的jdbcTemplate-->
<bean id="template" class="org.springframework.jdbc.core.JdbcTemplate">
<property name="dataSource" ref="datasource"></property>
</bean>
<context:component-scan base-package="dayday"></context:component-scan>
<!--配置NamedParameterJdbcTemplate,该对象可以使用具名参数,其无无参构造器,所以必须为其构造器指定参数-->
<bean id="namedParameterJdbcTemplate" class="org.springframework.jdbc.core.namedparam.NamedParameterJdbcTemplate">
<constructor-arg ref="datasource"></constructor-arg>
</bean>
</beans>

Spring中的JDBCTemplate的更多相关文章

  1. (六)Spring 中的 JdbcTemplate

    目录 概念 配置数据库 创建 JdbcTemplate 对象 增删改查代码 概念 JdbcTemplate : 是 Spring 中对持久层(JDBC 技术)一个封装 : 使用起来和 Dbutuis ...

  2. Spring中的JdbcTemplate使用

    1.引出SpringJDBC的概念 在学习JDBC编程时我们会感觉到JDBC的操作是多么繁琐,那么当我们学习的Hibernate框架时,我们感觉到数据库的操作也变非常简单,提高了开发效率.但是当使用H ...

  3. Spring中的JdbcTemplate的使用

    一.jdbcTemplate的作用 它就是用于和数据库交互的,实现对表的crud.与dbutils相似 二.JdbcTemplate的使用 <dependency> <groupId ...

  4. Spring 中的 JDBCTemplate

    新建一个java工程 写好spring配置文件,直接上代码 <?xml version="1.0" encoding="UTF-8"?> <b ...

  5. Spring中的设计模式学习

    Spring提供了一种Template的设计哲学,包含了很多优秀的软件工程思想. 1. 简单工厂 又叫做静态工厂方法(StaticFactory Method)模式,但不属于23种GOF设计模式之一. ...

  6. Spring中的设计模式

    [Spring中的设计模式] http://www.uml.org.cn/j2ee/201301074.asp [详解设计模式在Spring中的应用]    [http://www.geek521.c ...

  7. spring 中的设计模式

    https://mp.weixin.qq.com/s?__biz=MzU0MDEwMjgwNA==&mid=2247485205&idx=1&sn=63455d2313776d ...

  8. Spring中使用的设计模式

    目录 Spring使用的设计模式 1.单例模式 2.原型模式 3.模板模式 4.观察者模式 5.工厂模式 简单工厂模式 工厂方法模式 6.适配器模式 7.装饰者模式 8.代理模式 9.策略模式   S ...

  9. 详解设计模式在Spring中的应用

    设计模式作为工作学习中的枕边书,却时常处于勤说不用的尴尬境地,也不是我们时常忘记,只是一直没有记忆. 今天,在IT学习者网站就设计模式的内在价值做一番探讨,并以spring为例进行讲解,只有领略了其设 ...

随机推荐

  1. matplotlib总结

    主要使用matplot.pyplot import matplot.pyplot as plt plt.figure(1) plt.subplot(211) plt.plot(x,y, 'rs') p ...

  2. 关于layui

    之前用layer用了很长时间,感觉很好用,最近看到了layui的发布很想尝试尝试. 加入了挺多的功能,比如编辑器,上传,form表单等等.

  3. cf#382div2

    A. 题意:字符串长度n,每次可向左向右跳k个格子.要求不能在障碍物处停留('#'),可以在空地处停留(' . ').给出字符串,从G开始,问能不能到达T. 分析:直接从G处开始向两边搜,如果能到T则 ...

  4. DevExpress实现为TextEdit设置水印文字

    本文实例展示了DevExpress实现为TextEdit设置水印文字的方法,是一个很实用的技巧.分享给大家供大家参考. 转自 http://blog.csdn.net/yh0503/article/d ...

  5. 给libpcap增加一个新的捕包方法

    libpcap是一个网络数据包捕获函数库,功能非常强大,提供了系统独立的用户级别网络数据包捕获接口,Libpcap可以在绝大多数类unix 平台下工作.大多数网络监控软件都以它为基础,著名的tcpdu ...

  6. Java EE : 三、图解Session(会话)

    目录 Java EE : 一.图解Http协议 Java EE : 二.图解 Cookie(小甜饼) Java EE : 三.图解Session(会话) 概述 一.Session由来 二.Sessio ...

  7. django模板里循环变量<table>里想要两个一行如何控制

    2016-8-3 周三 做项目时遇到的问题: 每个div由循环变量输出: {% for key,value in formextenddetail %} <div id="div_id ...

  8. 数位DP入门

    HDU 2089 不要62 DESC: 问l, r范围内的没有4和相邻62的数有多少个. #include <stdio.h> #include <string.h> #inc ...

  9. 让ie6对png透明图片支持起来

    [声明:此文仅是对低版本ie使用透明图片的一个研究,当时出于工作要求,所以花费了一番心思在兼容旧版本ie上,现在对ie8都是做降级处理了.不培养用户坏习惯.引导用户跟随潮流体验新技术应是我们前端开发者 ...

  10. Socket Receive 避免 Blocking

    我们知道 Socket Blocking 属性默认true . 表明Socket 处于同步调用 , Connect , 或 Send , Receive 需等待动作 完成才能继续执行. 有一种应用场景 ...