在maven中实现spring的jdbc模块
来源:互联网 发布:cdma无线网络优化流程 编辑:程序博客网 时间:2024/06/05 08:23
本项目是在maven中构建的,所以要在pom.xml中加入dependency:
<dependencies> <!--编译加载java连接数据库的依赖jar包,mysql-connector-java--> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.0.5</version> </dependency> <!--spring相关包--> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-web</artifactId> <version>4.3.1.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>4.3.1.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-jdbc</artifactId> <version>4.3.6.RELEASE</version> </dependency> <!-- https://mvnrepository.com/artifact/c3p0/c3p0 --> <dependency> <groupId>c3p0</groupId> <artifactId>c3p0</artifactId> <version>0.9.1.2</version> </dependency> <!-- https://mvnrepository.com/artifact/commons-dbcp/commons-dbcp --> <dependency> <groupId>commons-dbcp</groupId> <artifactId>commons-dbcp</artifactId> <version>1.4</version> </dependency> </dependencies>
(1)数据库中有的字段名字,写进java文件中:
import java.io.Serializable;/** * 数据库中的数据字段 */public class Emp implements Serializable{ private int id; private String name; private String sex; private String age; private String tel; public Emp(){ super(); } public Emp(int id,String name,String sex,String age,String tel){ super(); this.id=id; this.name=name; this.sex=sex; this.age=age; this.tel=tel; } public int getId(){ return id; } public void setId(int 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 getAge(){ return age; } public void setAge(String age){ this.age=age; } public String getTel(){ return tel; } public void setTel(String tel){ this.tel=tel; }}
(2)定义接口(增删改查):
public interface EmpDao { /*插入的操作*/ boolean insert(Emp entity); /*查询所有*/ List<Emp> findAll();}
(3)实现上面接口的类(增删改查):
import org.springframework.jdbc.core.JdbcTemplate;import org.springframework.jdbc.core.RowMapper;import java.sql.ResultSet;import java.sql.SQLException;import java.util.ArrayList;import java.util.List;/** * 实现EmpDao接口的类 */public class EmpDaoImpl implements EmpDao { private JdbcTemplate jdbcTemplate; public EmpDaoImpl(JdbcTemplate jdbcTemplate){ this.jdbcTemplate=jdbcTemplate; } @SuppressWarnings("unchecked") public List<Emp> findAll() { // 定义返回结果 List<Emp> entities =new ArrayList<Emp>(); entities = (List<Emp>) jdbcTemplate.query( "select id,name,sex from students", new RowMapper() { 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")); return emp; } }); return entities; } //插入数据 public boolean insert(Emp entity) { // 定义返回结果 boolean flag = false; /* 插入实现 */ int i = jdbcTemplate.update( "insert into students(id,name,sex,age,tel) values(?,?,?,?,?)", new Object[] { entity.getId(), entity.getName(),entity.getSex(), entity.getAge(),entity.getTel()}); if (i > 0) { flag = true; } return flag; }}
(4)配置类:要进行数据库连接,数据的注入,把jdbcTemplate注入到EmpDaoImpl中:
import org.apache.commons.dbcp.BasicDataSource;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration;import org.springframework.jdbc.core.JdbcTemplate;import javax.sql.DataSource;/** * Created by Administrator on 2017/3/8. */@Configurationpublic class EmDaoConfig { @Bean public BasicDataSource dataSource(){ BasicDataSource ds=new BasicDataSource(); ds.setDriverClassName("com.mysql.jdbc.Driver");//加载驱动 ds.setUrl("jdbc:mysql://localhost:3306/mydata?"); ds.setUsername("root"); ds.setPassword("86914381"); ds.setInitialSize(5); //池启动时创建的连接数量 ds.setMaxActive(10); //同一时间可以从池中分配的最多连接数。如果设置为0,则无限制 return ds; } @Bean //加入数据 public JdbcTemplate jdbcTemplate(DataSource dataSource){ return new JdbcTemplate(dataSource); } @Bean //jdbcTemplate注入依赖 public EmpDao empDaoImpl(JdbcTemplate jdbcTemplate){ return new EmpDaoImpl(jdbcTemplate); }}
(5)测试类:
import org.springframework.context.ApplicationContext;import org.springframework.context.annotation.AnnotationConfigApplicationContext;import java.util.List;/** * 测试实例 */public class EmDaoTest { public static void main(String[] args){ ApplicationContext ac=new AnnotationConfigApplicationContext(EmDaoConfig.class); //获取实例 EmpDao ed = ac.getBean(EmpDao.class); List<Emp> emps = ed.findAll(); for(Emp emp:emps){ System.out.println( "ID::"+emp.getId()+" Name::"+emp.getName()+" sex::"+emp.getSex()); } //插入数据 Emp emp=new Emp(20,"llqllq","男","10","15603004804"); boolean flag=ed.insert(emp); if(flag){ System.out.println("插入成功"); }else{ System.out.println("插入失败"); } }}
0 0
- 在maven中实现spring的jdbc模块
- maven+Spring在Eclipse中搭建多模块企业级项目
- Spring中实现基于Jdbc的DAO
- spring boot在maven下的多模块打包
- Spring第七篇【Spring的JDBC模块】
- 在Maven中Spring的基础配置
- 在maven本地仓库中添加oracle的jdbc驱动。
- Spring-jdbc的实现
- 在spring中使用JDBC
- 在Eclipse中创建Maven多模块工程的例子
- 在Eclipse中创建Maven多模块工程的例子
- 在Eclipse中创建Maven多模块工程的例子
- 在Eclipse中创建Maven多模块工程的例子
- 在Eclipse中创建Maven多模块工程的例子
- 在Eclipse中创建Maven多模块工程的例子
- 在Eclipse中创建Maven多模块工程的例子
- 在Eclipse中创建Maven多模块工程的例子
- 在Eclipse中创建Maven多模块工程的例子
- 极光推送3分集成干货--android
- struts2接收表单传过来的参数方法
- 蓝桥杯 2016-省赛-C语言大学A组-3题方格填数
- C语言宏条件编译详解
- KMP的python实现
- 在maven中实现spring的jdbc模块
- python爬虫高级功能
- Android 3种自定义圆形ProgressBar
- 大端模式和小端模式
- mysqldumper 与 Innobackupex的备份和恢复操作实验过程
- 希望能够坚持下去!
- Tomcat配置虚拟主机的两种方式
- 使用edittext搜索时,更改软键盘的回车为搜索
- 【c语言基础】字符串数组与字符串指针的理解心得