
1.首先先添加两个包:
c3p0-0.9.1.2.jar 和 mysql-connector-java-5.1.7-bin.jar
创建一个file jdbc.properties
DriverClass=com.mysql.jdbc.Driver
jdbcUrl=jdbc\:mysql\://localhost\:3306/0902?useUnicode\=true&characterEncoding\=UTF-8
user=root
pass=root
2.创建一个java类
Emp.java
package cn.nm.domain;
import java.io.Serializable;
import java.util.Date;
public class Emp implements Serializable{
private static final long serialVersionUID = 1L;
private Integer id;
private String name;
private String sex;
private String pass;
private Date hiredate;
public Emp() {
super();
// TODO Auto-generated constructor stub
}
public Emp(Integer id, String name, String sex, String pass, Date hiredate) {
super();
this.id = id;
this.name = name;
this.sex = sex;
this.pass = pass;
this.hiredate = hiredate;
}
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getSex() {
return sex;
}
public void setSex(String sex) {
this.sex = sex;
}
public String getPass() {
return pass;
}
public void setPass(String pass) {
this.pass = pass;
}
public Date getHiredate() {
return hiredate;
}
public void setHiredate(Date hiredate) {
this.hiredate = hiredate;
}
}
3.定义一个接口类
EmpDao.java
package cn.nm.dao;
import java.util.List;
import cn.nm.domain.Emp;
public interface EmpDao {
/*插入的操作*/
boolean insert(Emp entity);
/*更新操作*/
boolean update(Emp entity);
/*删除的操作*/
boolean delete(Emp entity);
/*根据主键id查询*/
Emp findById(Integer id);
/*查询所有*/
List<Emp> findAll();
}
4.创建一个EmpDaoImpl.java
package cn.nm.dao;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.core.RowMapper;
import cn.nm.domain.Emp;
public class EmpDaoImpl implements EmpDao {
/* 封装一个JdbcTemplate的模板对象 */
private JdbcTemplate jdbcTemplate;
/* 通过set方法注入进来即可 */
public void setJdbcTemplate(JdbcTemplate jdbcTemplate) {
this.jdbcTemplate = jdbcTemplate;
}
@Override
public boolean delete(Emp entity) {
// 定义返回结果
boolean flag = false;
/* 插入实现 */
int i = jdbcTemplate.update("delete from emp where id=? ",
new Object[] { entity.getId() });
if (i > 0) {
flag = true;
}
return flag;
}
@SuppressWarnings("unchecked")
@Override
public List<Emp> findAll() {
// 定义返回结果
List<Emp> entities =new ArrayList<Emp>();
entities = (List<Emp>) jdbcTemplate.query(
"select id,name,sex,pass,hiredate from emp", new RowMapper() {
@Override
public Object mapRow(ResultSet rs, int rowNum)
throws SQLException {
Emp emp = new Emp();
emp.setId(rs.getInt("id"));
emp.setName(rs.getString("name"));
emp.setSex(rs.getString("sex"));
emp.setPass(rs.getString("pass"));
emp.setHiredate(rs.getDate("hiredate"));
return emp;
}
});
return entities;
}
@Override
public Emp findById(Integer id) {
// 定义返回结果
Emp entity = null;
entity = (Emp) jdbcTemplate.queryForObject(
"select id,name,sex,pass,hiredate from emp where id=?",
new Object[] { id }, new RowMapper() {
@Override
public Object mapRow(ResultSet rs, int rowNum)
throws SQLException {
Emp emp = new Emp();
emp.setId(rs.getInt("id"));
emp.setName(rs.getString("name"));
emp.setSex(rs.getString("sex"));
emp.setPass(rs.getString("pass"));
emp.setHiredate(rs.getDate("hiredate"));
return emp;
}
});
return entity;
}
@Override
public boolean insert(Emp entity) {
// 定义返回结果
boolean flag = false;
/* 插入实现 */
int i = jdbcTemplate.update(
"insert into emp(name,sex,pass,hiredate) values(?,?,?,?)",
new Object[] { entity.getName(), entity.getSex(),
entity.getPass(), entity.getHiredate() });
if (i > 0) {
flag = true;
}
return flag;
}
@Override
public boolean update(Emp entity) {
// 定义返回结果
boolean flag = false;
/* 更新实现 */
int i = jdbcTemplate
.update(
"update emp set name=?,sex=?,pass=?,hiredate=? where id=?",
new Object[] { entity.getName(), entity.getSex(),
entity.getPass(), entity.getHiredate(),
entity.getId() });
if (i > 0) {
flag = true;
}
return flag;
}
}
5.修改配置文件
<!-- 配置数据源c3p0 -->
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<!-- 数据库驱动 -->
<property name="driverClass" value="${DriverClass}"/>
<!-- 数据库连接的URL -->
<property name="jdbcUrl" value="${jdbcUrl}"/>
<!-- 数据库连接的用户名 -->
<property name="user" value="${user}"/>
<!-- 数据库连接的用户密码 -->
<property name="password" value="${pass}"/>
</bean>
<!-- 配置jdbc的模板类JdbcTemplate -->
<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
<property name="dataSource" ref="dataSource"/>
</bean>
<!-- 配置操作的DaoImpl实现类 -->
<bean id="empDaoImpl" class="cn.redarmys.dao.EmpDaoImpl">
<!-- 注入模板类对象 -->
<property name="jdbcTemplate" ref="jdbcTemplate"/>
</bean>
<!-- 分散配置解析 -->
<context:property-placeholder location="jdbc.properties"/>
6.创建一个测试类
package cn.nm.dao;
import java.util.List;
import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import cn.nm.domain.Emp;
public class App {
@Test
public void app(){
ApplicationContext ac = new ClassPathXmlApplicationContext("classpath:app*.xml");
/*获取DaoImp的实体对象*/
EmpDao ed = (EmpDao) ac.getBean("empDaoImpl");
/*for (int i = 1; i <11; i++) {
插入验证
Emp emp = new Emp(null, "redarmy"+i, "男", "redarmy"+i+"@gmai.com", new Date());
boolean flag = ed.insert(emp);
if(flag){
System.out.println("插入成功");
}else{
System.out.println("插入失败");
}
}*/
/*根据主键查询ID*/
//Emp emp = ed.findById(11);
/*System.out.println(
"ID::"+emp.getId()+" Name::"+emp.getName()+" sex::"+emp.getSex()+" pass:::"+emp.getPass()+" hiredate::"+emp.getHiredate());
*/
/*更新操作*/
/*emp.setName("孙彤彤");
emp.setPass("123");
emp.setHiredate(new Date());
ed.update(emp);*/
/*删除操作*/
//ed.delete(emp);
List<Emp> emps = ed.findAll();
for(Emp emp:emps){
System.out.println(
"ID::"+emp.getId()+" Name::"+emp.getName()+" sex::"+emp.getSex()+" pass:::"+emp.getPass()+" hiredate::"+emp.getHiredate());
}
}
}
分享到:
相关推荐
通过DataSource、JdbcTemplate或NamedParameterJdbcTemplate,我们可以执行SQL查询,实现增删改查操作。这些工具类处理了打开和关闭连接、事务管理等繁琐工作,使代码更简洁。 3. **数据访问对象(DAO)**:在...
在“spring的增删改查”这个主题中,我们将深入探讨Spring如何与Oracle数据库配合,实现数据的CRUD(Create、Read、Update、Delete)操作。 1. **Spring JDBC模块** Spring提供了JDBC模块,使得开发者可以避免繁琐...
Spring JDBC是Spring框架的一部分,它提供了一种抽象层,使得我们能够更方便地使用Java数据库连接(JDBC)来处理数据库操作,如增删改查(CRUD)。在这个主题下,我们将深入探讨Spring JDBC的核心概念、配置、以及...
在Spring框架中,JdbcTemplate是用于简化数据库操作的重要工具,它是Spring JDBC模块的一部分。通过使用JdbcTemplate,开发者可以避免编写大量的重复代码,如手动管理连接、处理结果集等,从而专注于业务逻辑。本文...
本项目聚焦于Spring、Spring MVC和JDBC Template的集成应用,用于实现数据库的增删改查操作。这是一套常见的企业级应用开发模式,对于理解和掌握Java Web开发至关重要。 首先,Spring框架是一个开源的应用框架,它...
在本实例中,我们将深入探讨如何使用SpringBoot框架进行数据库操作,主要集中在增删改查(CRUD)功能。SpringBoot以其简洁的配置和强大的功能,成为Java开发中广泛采用的框架,尤其在构建微服务时更为突出。下面,...
在本项目中,我们主要探讨的是如何利用SpringMVC框架结合注解来实现一个完整的增删改查(CRUD)功能。SpringMVC是Spring框架的一部分,专门用于处理Web应用程序的请求和响应,通过注解的方式,我们可以使代码更加...
在这个实例中,我们将探讨如何利用这三个框架实现一个简单的登录功能,并通过Spring进行登录、增、删、改、查的完整操作。 首先,Struts2作为MVC模式中的Controller层,负责处理用户请求并转发到相应的Action。在...
在实际的"SSH案例(增删改查)"项目中,开发者可能还使用了JDBC或者Spring的JdbcTemplate进行数据库交互,这些工具可以帮助简化数据库操作。同时,为了增强用户体验,界面可能使用了JSP(Java Server Pages)和HTML...
在"Spring+Hibernate 增删改查等基本操作"这个主题中,我们主要探讨的是如何整合这两个框架来实现数据持久化。以下是一些关键的知识点: 1. **Spring**: - **依赖注入(DI)**:Spring的核心特性之一,通过XML...
在这个"ssh 框架增删改查小项目(CRUD)"中,我们可以深入学习SSH框架如何实现基本的数据操作,包括创建(Create)、读取(Read)、更新(Update)和删除(Delete)。 Spring框架作为基础,它是一个全面的后端应用...
在"Spring3.x MySql 增删改查"项目中,初学者可以学习如何配置Spring的JDBC支持。这通常涉及以下步骤: 1. 添加Spring JDBC的依赖到项目构建配置(如Maven或Gradle)。 2. 创建DataSource bean,配置数据库连接参数...
本文将详细介绍Spring使用JDBC进行增删改查的三种主要方法。 首先,让我们了解Spring JDBC的基础。Spring JDBC模块通过`JdbcTemplate`和`SimpleJdbcTemplate`类提供了数据库访问的抽象层,简化了数据库操作。这两种...
标题"Spring+Hibernate工具类所有增删改查"暗示了这是一个集合了Spring和Hibernate框架中用于基本数据库操作的工具类库。这些工具类通常包含了一系列静态方法,用于执行常见的数据库CRUD(创建、读取、更新、删除)...
在"增删改查"中,Spring可以提供数据访问对象(DAO)抽象,通过JdbcTemplate或MyBatis等工具与数据库交互,简化了数据库操作。 Hibernate是一个强大的对象关系映射(ORM)框架,它允许开发者用Java对象来操作数据库...
Spring Boot 使用 JdbcTemplate 实现数据库增删改查功能 概述 Spring Boot 是一个基于 Java 的框架,旨在简化企业级应用程序的开发。JdbcTemplate 是 Spring Framework 中的一个模板类,提供了简洁的数据库操作...
在这个“ssh_dome实现数据增删改查的示例”中,我们将深入理解如何使用这三个框架来实现数据库操作的核心功能。 首先,让我们从Struts开始。Struts是一个基于MVC(Model-View-Controller)设计模式的开源框架,它...
在增删改查操作中,Spring通过它的数据访问集成(Data Access/Integration)模块,如JdbcTemplate或JPA,与数据库进行交互。 2. **Struts框架**:Struts是MVC(Model-View-Controller)设计模式的实现,主要负责...
在这个"SSH增删改查+分页+图片上传"的项目中,我们将深入探讨这三个框架在实际应用中的结合以及它们如何协同工作来实现数据管理、页面展示和文件上传等功能。 首先,Struts1是一个基于MVC(Model-View-Controller)...
综上所述,`springjdbc.zip`文件中的示例可能展示了如何在Spring环境中配置和使用JDBC,包括数据源配置、事务管理、以及使用`JdbcTemplate`执行增删改查操作的完整流程。通过学习这些示例,开发者可以更好地理解和...