在maven中实现spring的jdbc模块

本项目是在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.
 */
@Configuration
public 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
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

洛克-李

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值