<?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:mvc="http://www.springframework.org/schema/mvc"
xmlns:aop="http://www.springframework.org/schema/aop" xmlns:context="http://www.springframework.org/schema/context" xmlns:c="http://www.springframework.org/schema/c"
xmlns:cache="http://www.springframework.org/schema/cache" xmlns:jdbc="http://www.springframework.org/schema/jdbc" xmlns:tx="http://www.springframework.org/schema/tx"
xsi:schemaLocation="http://www.springframework.org/schema/jdbc http://www.springframework.org/schema/jdbc/spring-jdbc-4.0.xsd
http://www.springframework.org/schema/cache http://www.springframework.org/schema/cache/spring-cache-4.0.xsd
http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd
http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.0.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.0.xsd
http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.0.xsd
http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.0.xsd"> <context:component-scan base-package="com.icss.hr"></context:component-scan>
<!-- 1.配置数据源 -->
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<property name="jdbcUrl" value="jdbc:mysql://localhost:3306/hr"/>
<property name="driverClass" value="com.mysql.jdbc.Driver"/>
<property name="user" value="root" />
<property name="password" value="admin" />
<property name="initialPoolSize" value="3" />
<property name="maxPoolSize" value="10" />
<property name="minPoolSize" value="1" />
<property name="acquireIncrement" value="3" />
<property name="maxIdleTime" value="60" />
</bean>
<!-- 2.JDBCTemplate -->
<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
<property name="dataSource" ref="dataSource"></property>
</bean> <!-- 3.配置事务 -->
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"></property>
</bean>
<tx:advice id="txa" transaction-manager="transactionManager">
<tx:attributes>
<tx:method name="add*" isolation="DEFAULT" propagation="REQUIRED" read-only="false"/>
<tx:method name="update*" isolation="DEFAULT" propagation="REQUIRED" read-only="false"/>
<tx:method name="delete*" isolation="DEFAULT" propagation="REQUIRED" read-only="false"/>
<tx:method name="query*" read-only="true"/>
</tx:attributes>
</tx:advice>
<aop:config>
<aop:pointcut expression="execution(* com.icss.hr.*.service.*.*(..))" id="txCut"/>
<aop:advisor advice-ref="txa" pointcut-ref="txCut"/>
</aop:config> <!-- 配置视图解析器 -->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<!-- 跳转路径 字符串前面加上路径 --> <!-- view里面的字符串加上后缀 -->
<property name="suffix" value=".jsp"></property>
</bean>
</beans>

Dept.java

package com.icss.hr.dept.pojo;
/**
* 部门类
* @author Administrator
*
*/
public class Dept {
private int dept_id;
private String dept_name;
private String dept_loc; public Dept() {
super();
}
public Dept(int dept_id, String dept_name, String dept_loc) {
super();
this.dept_id = dept_id;
this.dept_name = dept_name;
this.dept_loc = dept_loc;
}
public int getDept_id() {
return dept_id;
}
public void setDept_id(int dept_id) {
this.dept_id = dept_id;
}
public String getDept_name() {
return dept_name;
}
public void setDept_name(String dept_name) {
this.dept_name = dept_name;
}
public String getDept_loc() {
return dept_loc;
}
public void setDept_loc(String dept_loc) {
this.dept_loc = dept_loc;
}
@Override
public String toString() {
return "Dept [dept_id=" + dept_id + ", dept_name=" + dept_name + ", dept_loc=" + dept_loc + "]";
}
}

Dao.java

package com.icss.hr.dept.dao;

import java.util.List;

import org.springframework.stereotype.Repository;

import com.icss.hr.dept.pojo.Dept;
@Repository
public interface DeptDao {
public boolean addDept(Dept dept);
public boolean updateDept(Dept dept);
public boolean deleteDept(int dept_id); public List<Dept> queryAllDept();
public Dept queryDeptById(int dept_id); }

DaoImpl.java

package com.icss.hr.dept.dao;

import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.List; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.core.RowMapper;
import org.springframework.stereotype.Repository; import com.icss.hr.dept.pojo.Dept;
@Repository
public class DeptDaoImpl implements DeptDao { @Autowired
private JdbcTemplate jdbcTemplate; public JdbcTemplate getJdbcTemplate() {
return jdbcTemplate;
} public void setJdbcTemplate(JdbcTemplate jdbcTemplate) {
this.jdbcTemplate = jdbcTemplate;
} @Override
public boolean addDept(Dept dept) {
StringBuilder sql = new StringBuilder()
.append("INSERT INTO dept ")
.append("VALUES(?,?,?)");
System.out.println(sql);
int res = jdbcTemplate.update(sql.toString(),dept.getDept_id(),dept.getDept_name(),dept.getDept_loc());
return res > 0 ? true : false;
} @Override
public boolean updateDept(Dept dept) {
StringBuilder sql = new StringBuilder()
.append("update dept ")
.append("SET dept_name=?,dept_loc=? ")
.append("WHERE dept_id=?");
System.out.println(sql);
int res = jdbcTemplate.update(sql.toString(),dept.getDept_name(),dept.getDept_loc(),dept.getDept_id());
return res > 0 ? true : false;
} @Override
public boolean deleteDept(int dept_id) {
StringBuilder sql = new StringBuilder()
.append("DELETE FROM dept ")
.append("WHERE dept_id=?");
System.out.println(sql);
int res = jdbcTemplate.update(sql.toString(),dept_id);
return res > 0 ? true : false;
} @Override
public List<Dept> queryAllDept() {
StringBuilder sql = new StringBuilder()
.append("SELECT * ")
.append("FROM dept"); return jdbcTemplate.query(sql.toString(), new RowMapper<Dept>() { @Override
public Dept mapRow(ResultSet rs, int arg1) throws SQLException {
//解析行
Dept d = new Dept(rs.getInt("dept_id"),rs.getString(2),rs.getString(3));
return d;
}
}); } @Override
public Dept queryDeptById(int dept_id) {
// TODO Auto-generated method stub
return null;
} }

DeptService.java

package com.icss.hr.dept.service;

import java.util.List;

import org.springframework.stereotype.Service;

import com.icss.hr.dept.pojo.Dept;
@Service
public interface DeptService {
public boolean addDept(Dept dept);
public boolean updateDept(Dept dept);
public boolean deleteDept(int dept_id);
public List<Dept> queryDepts();
}

DeptServiceImpl.java

package com.icss.hr.dept.service;

import java.util.List;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.stereotype.Service; import com.icss.hr.dept.dao.DeptDao;
import com.icss.hr.dept.pojo.Dept;
@Service
public class DeptServiceImpl implements DeptService {
@Autowired
@Qualifier(value="deptDaoImpl")
private DeptDao deptDao; public DeptDao getDeptDao() {
return deptDao;
} public void setDeptDao(DeptDao deptDao) {
this.deptDao = deptDao;
} @Override
public boolean addDept(Dept dept) {
//日志文件 return deptDao.addDept(dept);
} @Override
public boolean updateDept(Dept dept) {
// TODO Auto-generated method stub
return deptDao.updateDept(dept);
} @Override
public boolean deleteDept(int dept_id) {
// TODO Auto-generated method stub
return deptDao.deleteDept(dept_id);
} @Override
public List<Dept> queryDepts() {
// TODO Auto-generated method stub
return deptDao.queryAllDept();
} }

DeptAction.java

package com.icss.hr.dept.controller;

import java.util.List;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping; import com.icss.hr.dept.pojo.Dept;
import com.icss.hr.dept.service.DeptService; @Controller
@RequestMapping("/dept")
public class DeptAction {
@Autowired
@Qualifier(value="deptServiceImpl")
private DeptService deptService; public DeptService getDeptService() {
return deptService;
}
public void setDeptService(DeptService deptService) {
this.deptService = deptService;
} @RequestMapping("/add.action")
public String addDept(Model mo,Dept dept){
boolean res = deptService.addDept(dept);
return res ? "redirect:/dept/show.action" : "../error";
}
@RequestMapping("/show.action")
public String showDept(Model mo){
List<Dept> depts = deptService.queryDepts();
mo.addAttribute("depts",depts);
return "../show";
}
@RequestMapping("/delete.action")
public String deleteDept(int dept_id){
boolean res = deptService.deleteDept(dept_id);
return res ? "redirect:/dept/show.action" : "../error";
}
@RequestMapping("/update.action")
public String updateDept(Dept dept){
System.out.println(dept.getDept_id());
boolean res = deptService.updateDept(dept);
System.out.println(res);
return res ? "redirect:/dept/show.action" : "../error";
}
}

TestDept.java

package com.icss.hr.dept.test;

import java.util.List;

import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext; import com.icss.hr.dept.pojo.Dept;
import com.icss.hr.dept.service.DeptService; public class TestDept {
@Test
public void test(){
ApplicationContext ac = new ClassPathXmlApplicationContext("applicationContext.xml");
DeptService service = (DeptService)ac.getBean("deptServiceImpl");
boolean b = service.updateDept(new Dept(7,"国防部","北京"));
System.out.println(b);
} }

  

  

  

Spring抽象JDBC,使用JdbcTemplate的更多相关文章

  1. Spring之JDBC模板jdbcTemplate

    要使用Jdbctemplate 对象来完成jdbc 操作.通常情况下,有三种种方式得到JdbcTemplate 对象.           第一种方式:我们可以在自己定义的DAO 实现类中注入一个Da ...

  2. Java学习笔记43(Spring的jdbc模板)

    在之前的学习中,我们执行sql语句,需要频繁的开流,关流比较麻烦,为了更加的简化代码,我们使用Spring 的jdbc模板jdbcTemplate来简化我们的代码量:需要导入的包有: 我们在之前的dr ...

  3. [原创]java WEB学习笔记109:Spring学习---spring对JDBC的支持:使用 JdbcTemplate 查询数据库,简化 JDBC 模板查询,在 JDBC 模板中使用具名参数两种实现

    本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱 ...

  4. 【Java EE 学习 52】【Spring学习第四天】【Spring与JDBC】【JdbcTemplate创建的三种方式】【Spring事务管理】【事务中使用dbutils则回滚失败!!!??】

    一.JDBC编程特点 静态代码+动态变量=JDBC编程. 静态代码:比如所有的数据库连接池 都实现了DataSource接口,都实现了Connection接口. 动态变量:用户名.密码.连接的数据库. ...

  5. Spring对 JDBC 的支持,JdbcTemplate类的使用

    导包:spring框架的包 和 连接数据库连接池的c3p0包 连接mysql数据库的包; 在src目录下建立jdbc.properties文件:存放连接数据库的属性值 jdbc.user=root j ...

  6. Spring 对JDBC的支持(JdbcTemplate)

    Spring对数据库的操作,使用JdbcTemplate对象 需要引入相关的jar文件 如版本:(Spring核心jar包就不列了) spring-jdbc-3.2.5.RELEASE.jar spr ...

  7. Spring JDBC模板类—org.springframework.jdbc.core.JdbcTemplate(转)

    今天看了下Spring的源码——关于JDBC的"薄"封装,Spring 用一个Spring JDBC模板类来封装了繁琐的JDBC操作.下面仔细讲解一下Spring JDBC框架. ...

  8. 【Spring JDBC】JdbcTemplate(三)

    传统Jdbc API与Spring jdbcTemplate比较 //JDBC API Statement statement = conn.createStatement(); ResultSet ...

  9. Spring对Jdbc的封装——JdbcTemplate的使用

    链接:https://pan.baidu.com/s/15luDElW4oeEaP0nvEQ_40w 提取码:i2r1 JdbcTemplate是Spring对JDBC的封装,目的是使JDBC更加易于 ...

随机推荐

  1. kibana启动--nohup在关闭终端后无效&&守护进程详解

    https://blog.csdn.net/ty_0930/article/details/70184705 https://blog.csdn.net/Dream_Flying_BJ/article ...

  2. hadoop(2)hadoop配置

    hadoop入门(二) hadoop的配置 1.本地模式 2.伪分布式 3.分布式     一.配置linux环境: 1打开虚拟网络编辑器,选择 VMnet1 仅主机模式, 子网 IP 设为 192. ...

  3. maven项目互相dependcy依赖问题

    1.自己编写的maven项目,在编译后,也会在.m2文件夹下生成jar包,可以供第三方引用使用. 2.比如几个项目互相依赖对方的jar包,就要首先选择编译哪个jar包,编译完成后生成jar,再编译依赖 ...

  4. 获取select 选中的option中自定义的名称的之

    <select style="width: 220px;height: 20px;margin: 0 0 0 20px;" id="invest_ticket&qu ...

  5. SAS编程基础 - 菜鸟入门常用操作

    1. SAS9.4添加和取消注释的快捷键? Ctrl+/:添加注释 Ctrl+Shift+/:取消注释 2. 如何强制终止程序运行? 看到那个圆圈里带叹号的图标了吗?没错,就是它 - 中断! 3. 如 ...

  6. Jmeter执行java脚本结束时提示:The JVM should have exited but did not.

    使用jmeter对dubbo进行压测时,需要使用jmeter的sampler里的java请求 使用./jmeter.sh -n -t test.jmx -l test.jmx -o -e test后台 ...

  7. C语言事实上不简单:数组与指针

    之前在写C的时候,没怎么留意数组.就这么定义一个.然后颠来倒去的使用即可了.只是后来碰到了点问题.解决后决定写这么一篇博客,数组离不开指针.索性就放一起好了. 如今我定义了一个数组:int cc[10 ...

  8. 我怎么在AD里面找到已经改名的Administrator账户?

    近期有博友问我一个问题,他是一个企业里面的IT管理员,他非常苦恼.他是一个新手,之前管理员交接的时候,没有交接更改的管理员username和password.他如今不知道哪个才是系统之前内置的admi ...

  9. 通过android XML 创建图形,降低对美工的依赖

    在开发中总会须要自己定义各种View的样式,假设总是依赖美工作图弄出须要的UI样式图片(比方:一个button要选中和默认两张图片),不但时间上会浪费.往往也会有适配问题. 尽管能够通过.9图来解决一 ...

  10. JavaScript 获得代码行号和脚本文件名

    如果你使用的是 V8 引擎,Chrome 和 Node.js 所用的,那么你可以利用 JavaScriptStackTraceApi 来获得行号信息,有两个 API: Error.captureSta ...