首先使用mysql建立数据库,并建立表如下:
CREATE TABLE `login` (
`username` varchar(10) default NULL,
`passwd` varchar(10) default NULL,
`address` varchar(10) default NULL
) ENGINE=InnoDB DEFAULT CHARSET=gb2312;
Spring的JDBC框架承担了资源管理和错误处理的重担,使你的JDBC代码非常干净,这就是spring为我们提供的模板类- JdbcTemplate,他是线程安全的
首先,我们编写配置文件,这里数据库链接部队使用了apache的pool和DBCP作为连接池
我们为PersonDAO这个数据库操作类,注入JdbcTemplate
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/spring-beans.dtd" >
<beans>
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName">
<value>com.mysql.jdbc.Driver</value>
</property>
<property name="url">
<value>jdbc:mysql://localhost:3306/javaee</value>
</property>
<property name="username">
<value>root</value>
</property>
<property name="password">
<value>1234</value>
</property>
</bean>
<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
<property name="dataSource">
<ref local="dataSource"/>
</property>
</bean>
<bean id="personDAO" class="SpringJDBCSupport.WriteData.PersonDAO">
<property name="jdbcTemplate">
<ref local="jdbcTemplate"/>
</property>
</bean>
</beans>
下面是我们的javaBean
package SpringJDBCSupport.WriteData;
import com.mysql.jdbc.Driver;
public class Person ...{
private String name;
private String password;
private String address;
public Person(String name,String password,String address)...{
this.name=name;
this.password=password;
this.address=address;
}
public String getAddress() ...{
return address;
}
public void setAddress(String address) ...{
this.address = address;
}
public String getName() ...{
return name;
}
public void setName(String name) ...{
this.name = name;
}
public String getPassword() ...{
return password;
}
public void setPassword(String password) ...{
this.password = password;
}
}
这是我们的数据库访问类:
包含了三个方法,其中execute方法是有三个参数,sql,params,type,定义type表示这是一个类型安全的方法
package SpringJDBCSupport.WriteData;
import java.sql.PreparedStatement;
import java.sql.SQLException;
import java.sql.Types;
import java.util.List;
import org.springframework.jdbc.core.BatchPreparedStatementSetter;
import org.springframework.jdbc.core.JdbcTemplate;
public class PersonDAO ...{
private JdbcTemplate jdbcTemplate;
public JdbcTemplate getJdbcTemplate() ...{
return jdbcTemplate;
}
public void setJdbcTemplate(JdbcTemplate jdbcTemplate) ...{
this.jdbcTemplate = jdbcTemplate;
}
public int insertPersonUseUpdate(Person person)...{
String sql="insert into login values(?,?,?)";
Object[] params=new Object[]...{
person.getName(),
person.getPassword(),
person.getAddress()
};
return this.getJdbcTemplate().update(sql,params);
}
public int insertPersonUseExecute(Person person)...{
String sql="insert into login values(?,?,?)";
Object[] params=new Object[]...{
person.getName(),
person.getPassword(),
person.getAddress()
};
int[] types=new int[]...{
Types.VARCHAR,
Types.VARCHAR,
Types.VARCHAR
};
return this.getJdbcTemplate().update(sql,params,types);
}
public int[] updatePersonUseBatchUpdate( final List persons)...{
String sql="insert into login values(?,?,?)";
BatchPreparedStatementSetter setter=null;
setter=new BatchPreparedStatementSetter()...{
public int getBatchSize()...{
return persons.size();
}
public void setValues(PreparedStatement ps,int index) throws SQLException...{
Person person=(Person)persons.get(index);
ps.setString(1,person.getName());
ps.setString(2,person.getPassword());
ps.setString(3,person.getAddress());
}
};
return this.getJdbcTemplate().batchUpdate(sql,setter);
}
}
测试代码:
package SpringJDBCSupport.WriteData;
import java.io.File;
import java.util.ArrayList;
import java.util.List;
import org.springframework.beans.factory.BeanFactory;
import org.springframework.beans.factory.xml.XmlBeanFactory;
import org.springframework.core.io.FileSystemResource;
public class TestJDBCTemplate ...{
public static String filePath="";
public static BeanFactory factory=null;
public static void main(String[] args) ...{
filePath=System.getProperty("user.dir")+File.separator+"SpringJDBCSupport"+File.separator+"WriteData"+File.separator+"hello.xml";
factory=new XmlBeanFactory(new FileSystemResource(filePath));
PersonDAO personDAO=(PersonDAO)factory.getBean("personDAO");
/**//*
* 准备数据
*/
Person p1=new Person("test1","test1","test1");
分享到:
相关推荐
spring 中对大数据的处理,包括clob,blob的数据。比之jdbc下简便很多。
SpringBoot操作数据库JdbcTemplate--SB系列之005的配套项目代码。 环境: win11 工具: idea 2017 jdk: 1.8 数据库: mysql5.5 maven : 3.2.1 项目:maven 导入 首先介绍一下本人与本篇: 因为本篇之后其实...
本篇文章主要介绍了Spring Boot中使用jdbctemplate 操作MYSQL数据库实例,具有一定的参考价值,有兴趣的可以了解一下。
springjdbc演示,spring持久层知识,包括注入数据源,jdbcTemplate操作数据库,jdbcTemplate以对象方式操作数据库
数据源可能是不同种类的:如sql server,oracl等等,一开始是用的配置实现,后来发现在项目运行中,可能需要动态的添加更多不同类型的数据源,所以最终的逻辑是将数据源配置在数据库中。
主要使用Spring MVC框架,实现jdbcTemplate核心组件,利用注解,实现与数据库的连接
本文介绍在Spring Boot基础下配置数据源和通过 JdbcTemplate 编写数据访问的示例。感兴趣的朋友跟随脚本之家小编一起学习吧
Spring Boot+Jpa多数据源配置Demo,可同时支持多种数据库,不同数据库,同时支持不同数据库的JdbcTemplate
chapter3-2-2:使用Spring-data-jpa简化数据访问层(推荐) chapter3-2-3:多数据源配置(一):JdbcTemplate chapter3-2-4:多数据源配置(二):Spring-data-jpa chapter3-2-5:使用NoSQL数据库(一):Redis ...
- chapter3-2-2:[使用Spring-data-jpa简化数据访问层(推荐)](http://blog.didispace.com/springbootdata2/) - chapter3-2-3:[多数据源配置(一):JdbcTemplate]...
基于spring jdbc的上层封装,底层jdbc操作基于JdbcTemplate,支持MySql、SqlServer、Oracle数据库,强弱类型完美结合 1、mini-jdbc:针对spring jdbc的一些不方便的地方,做了一些封装,大小写不敏感,简化了日常的...
使用maven构建项目,spring mvc,spring,分别与jdbctemplate,hibernate,mybatis全注解整合,其中包括包含有spring动态代理,数据库的事务处理。以及动态数据源的切换! 最新新增了ehcache缓存的应用
使用maven构建项目,spring mvc,spring,分别与jdbctemplate,hibernate,mybatis全注解整合,其中包括包含有spring动态代理,数据库的事务处理。以及动态数据源的切换! 最新新增了ehcache缓存的应用 ...
common 通用依赖、接口等 ...mybatis、jdbcTemplate、spring jpa持久层 hibernate-validation数据校验 spring-cloud-config管理配置 其他 nginx反向代理 前端: 采用vuejs + webpack + vue各大组件(vue
mybatis、jdbcTemplate、spring jpa持久层 hibernate-validation数据校验 spring-cloud-config管理配置 其他 nginx反向代理 前端: 采用vuejs + webpack + vue各大组件(vue-router、vue-resource等) ui采用...
Spring对JDBC进行了封装,提供了JdbcTemplate类,该类使Spring框架数据抽象层的基类,还有一些更高层次的类继承该类。使用该类要导入几个必须的jar包,分别是spring-jdbc-4.0.0.RELEASE.jar、spring-orm-4.0.0....
利用spring boot的jdbctemplate实现大批量数据导出数据库道文件,及文件中大批量数据导入mysql数据库
Spring JdbcTemplate的解析 针对数据库的操作,Spring框架提供了JdbcTemplate类,该类是Spring框架数据抽象层的基础。可以说,JdbcTemplate类是Spring JDBC的核心类。 接口JdbcOperations 抽象类JdbcAccessor 核心...
合集中的每一项都是针对不同数据存储做的简化封装,使我们在操作不同数据库时,以最简洁的代码完成需求功能。 SpringTest它是针对Junit单元测试的整合。让我们在开发中以及开发后期进行测试时,直接使用Junit结合...
6.8.1. 在Spring中使用AspectJ来为domain object进行依赖注入 6.8.1.1. @Configurable object的单元测试 6.8.1.2. 多application context情况下的处理 6.8.2. Spring中其他的AspectJ切面 6.8.3. 使用Spring IoC来...