1.beans.xml配置
~~~
//db.properties文件
jdbc.user=root
jdbc.password=root
jdbc.driverClass=com.mysql.jdbc.Driver
jdbc.jdbcUrl=jdbc:mysql:///goods
jdbc.initPoolSize=5
jdbc.maxPoolSize=10
<!-- 导入资源文件 -->
<context:property-placeholder location="classpath:db.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="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
<property name="dataSource" ref="dataSource"></property>
</bean>
~~~
2.jdbcTemplate的增删改查以及批量操作
~~~
public class MainTest {
private ApplicationContext ac = null;
private JdbcTemplate jdbcTemplate;
{
ac = new ClassPathXmlApplicationContext("beans.xml");
jdbcTemplate = (JdbcTemplate) ac.getBean("jdbcTemplate");
}
/*
* insert,update,delete的sql语句都需要调用jdbcTemplate的update方法
*
*/
@Test
public void testUpdate(){
String sql="update user set u_name=? where u_id=?";
jdbcTemplate.update(sql, "张三",3);
}
/*
* 批量操作 insert update delete
*/
@Test
public void test2(){
// String sql="insert into user(u_name,u_jifen) values(?,?)";
// List<Object[]> list=new ArrayList();
// list.add(new Object[]{"王五1",20});
// list.add(new Object[]{"王五2",20});
// list.add(new Object[]{"王五3",20});
// jdbcTemplate.batchUpdate(sql, list);
//批量删除
String sql="delete from user where u_id=?";
List<Object[]> list=new ArrayList();
list.add(new Object[]{4});
list.add(new Object[]{5});
list.add(new Object[]{6});
jdbcTemplate.batchUpdate(sql, list);
}
/*
* 测试查询单行操作
* 要使用RowMapper 指定封装规则
*/
@Test
public void testSelectOne(){
String sql="select * from user where u_id=?";
RowMapper<User> mapper=new BeanPropertyRowMapper<>(User.class);
User user=jdbcTemplate.queryForObject(sql, mapper, 1);
System.out.println(user);
}
/*
* 测试查询多条数据
*/
@Test
public void testQueryList(){
String sql="select * from user where u_id>?";
RowMapper<User> mapper=new BeanPropertyRowMapper<>(User.class);
List<User> list=jdbcTemplate.query(sql, mapper, 1);
System.out.println(list);
}
/*
* 测试查询单一(一个)数据
*/
@Test
public void testSelectOneColumn(){
String sql="select u_jifen from user where u_id=?";
int jifen=jdbcTemplate.queryForObject(sql, Integer.class, 2);
System.out.println(jifen);
}
@Test
public void test1() {
// spring整合JDBC之后,使用JdbcTemplate对象 ,去完成对数据库的各种操作 。
// 注意:JdbcTemplate对象中需要注入 DataSource对象 。。。
// JdbcTemplate 是由Spring框架提供,这个类对象JDBC操作,进行了封装 。
// 使用者 只需要编写SQL语句 ,处理数据封装就可以了 。。。
// JdbcTemplate 多表操作的时候比较麻烦 并不是ORM框架,而是jdbc
//System.out.println(jdbcTemplate);
DataSource ds = (DataSource) ac.getBean("dataSource");
//System.out.println(ds);
}
}
~~~
[代码位置](https://gitee.com/limiao11/springframework/tree/master/spring_jdbc)
~~~
附:
Spring使用dbcp数据源
导入两个jar包:
commons-pool-1.5.6jar / commons-dbcp-1.4jar
配置文件修改如下:
<!-- 配置dbcp数据源 -->
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName" value="com.mysql.jdbc.Driver"></property>
<property name="url" value="jdbc:mysql://localhost:3306/demo1"></property>
<property name="username" value="root"></property>
<property name="password" value="root"></property>
</bean>
~~~
- spring
- 1.spring第一天
- 1.1 安装spring插件(spring tool suite)
- 1.2 spring概述
- 1.3 控制反转&依赖注入
- 1.4 springIOC容器
- 1.5 依赖注入的四种方式
- 1.6 配置bean的细节
- 1.7 bean之间的关系
- 1.8 bean作用域
- 1.9 补充:创建对象的几种方法
- 1源代码位置
- 2.spring第二天
- 2.1 使用外部属性文件
- 2.2 spEL
- 2.3 bean的生命周期
- 2.4 通过工厂方式配置bean
- 2.5 基于注解的方式配置bean
- 2.6 组件装配
- 2.7 静态代理
- 2.8 动态代理
- 2.9 Cglib代理
- 2源代码位置
- 3. spring第三天
- 3.1 springAOP
- 3.1.1 AOP简介
- 3.1.2 为什么使用AOP
- 3.1.3 AOP关键术语
- 3.1.4 AOP图解
- 3.1.5 springAOP实现步骤
- 3.1.6 SpringAOP实现原理:
- 3.1.7 AOP的好处
- 3.1.8 AOP在实际项目中的主要应用
- 3代码地址
- 3.1.9 纯注解版配置aop的方式
- 3.2 maven环境搭建
- 附IDEA激活码
- 4. spring第四天
- 4.1 c3p0事务
- 4.2 命令窗口事务
- 4.3 c3p0连接池设置
- 4.4 事务中的一些基本概念
- 4.5 事务的传播行为
- 4.6 自定义异常
- 4.7 spring整合Junit单元测试
- 4.8 JdbcTemplate(附源代码)
- 事务源代码
- 4.9 纯注解tx
- 4.10 基于xml配置事务
- 0. jsp页面修改编码方式
- 0.1 eclipse配置tomcat
- 0.单例模式-饱汉模式
- 0.单例模式-饥汉模式
- springMVC
- 1. springmvc第一天
- 1.1 springMVC概述
- 1.2 springmvc框架搭建及第一个应用程序
- 1.3 @RequestMapping
- 1.4 RequestMapping修饰类
- 1.5 RequestMapping精准化映射
- 1.6 Ant风格URL
- 1.7 带有占位符的url映射
- 1.8 REST风格
- 1.9 RequerstParam获取请求正文
- 2. springmvc第二天
- 2.1 优化
- 2.2 POJO绑定请求参数
- 2.3 RequestHeader获取请求报头信息
- 2.4 CookieValue获取Cookie信息
- 2.5 获取原生ServletAPI
- 2.6 ModelAndView处理模型数据
- 2.7 Map、Model、ModelMap处理模型数据
- 2.8 @SessionAttributes注解
- 2.9 @ModelAttribute无返回值方法及方法入参
- 2.10 @ModelAttribute修饰有返回值类型的方法
- 代码地址
- 3. springmvc补充
- 3-1 springmvc工作原理
- 3-2 springmvc form表单提交中文乱码
- 3-3 数据的格式化
- 3-4 自定义类型转换器
- 3-5 其他知识点
- 3-6 crud代码
- 3-7 @DateTimeFormat日期格式化
- 3-8 数据验证的概念及JSR303验证
- 3-9 Hibernate-Validator验证框架
- 3-10 Controller捕获错误消息
- 3-11 errors标签在页面中获取错误消息
- 3-12 错误消息的定制及国际化
- 3-13 自定义拦截器
- 3-14 Java代码中获取国际化信息
- 3-15 超级链接设置国际化
- 3-16 AJAX支持之@RequestBody
- mybatis
- 1. mybatis第一天
- 1. 为什么使用mybatis
- 2. 下载地址
- 3. hello
- 4. mybatis三种开发模式
- 5. 全局配属属性内容
- 6. DTD设置
- 7. Mapper中的CRUD
- 8. 8.mybatis使用主键自增
- 9. #{}中的参数处理
- 10. #{}与${}区别
- 11. 集合数据的查询
- 12 动态sql
- 12.1 if
- 12.2 choose, when, otherwise
- 12.3 trim, where, set
- 12.4 foreach
- 代码位置
- 2. mybatis第二天
- 1.封装map类型的数据
- 2. resultMap自定义封装规则
- 0代码位置
- 3. mybatis缓存机制
- ssm整合
- 1.maven
- 2.ssm基础环境搭建
- 2-1 引入项目依赖的jar包
- 2-2 引入bootstrap,jquery
- 2-3 创建项目包结构
- 2-4 编写web.xml配置文件
- 2-5 编写sping,springmvc,mybatis配置文件
- 2-6 逆向工程mbg.xml
- shiro安全框架
- 1.shiro简介
- 易购Buy商城
- 第一天
- 1.课程计划
- 2.电商行业背景
- 3.易购Buy介绍
- 4.易购Buy架构
- 5.工程搭建
- 6.工程启动和测试
- 7.ssm框架整合
- 8.整合测试
- 9.svn
- 9.1 svn服务端
- 9.2 svn客户端
- 第二天
- 1.SOA架构分析
- 2.dubbo使用方法
- 3.注册中心
- 4.工程改造
- 5.easyUI
- maven
- 1.maven介绍
- 2.idea配置maven和服务器
- 3.创建web工程
- 4.分模块构建工程
- 5. 代码位置
- 6. nexus
- Luence搜索
- 1.了解搜索技术
- 2.Lucene的基本使用
- solr
- SolrCloud
