Spring全家桶(九)Spring JdbcTemplate

一、Spring JDBC

Spring JDBC是在JDBC API的基础上定义一个抽象层,用以简化JDBC操作。Spring JdbcTemplate是Spring JDBC框架的核心,为不同类型的JDBC操作提供模板方法,每个模板方法都能控制整个过程,并允许覆盖过程中的特定任务。基于此,可以在保留灵活性的情况下,将数据库存取的工作量降到最低。

二、Bean配置

在Spring配置文件中,配置一个Spring JdbcTemplate Bean:

   <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
        <property name="dataSource" ref="dataSource"/>
    </bean>

三、准备测试数据

登录mysql,创建一张用于测试的数据表:

create database testdb;
use testdb

创建一张数据表:

CREATE TABLE `user` (
  `uid` int(1) NOT NULL AUTO_INCREMENT,
  `username` varchar(50) NOT NULL,
  `password` varchar(200) NOT NULL,
  PRIMARY KEY (`uid`)
) ENGINE=InnoDB AUTO_INCREMENT=8 DEFAULT CHARSET=utf8;

四、JdbcTemplate提供的常用方法

import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import org.springframework.jdbc.core.BeanPropertyRowMapper;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.core.RowMapper;

import javax.sql.DataSource;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;

/**
 * Created by bee on 17/5/17.
 */

public class JDBCTest {
    private ApplicationContext ctx = null;
    private JdbcTemplate jdbcTemplate;

    {
        ctx = new ClassPathXmlApplicationContext("beans-jdbc.xml");
        jdbcTemplate = (JdbcTemplate) ctx.getBean("jdbcTemplate");
    }

    /**
     *
     * @throws SQLException
     */
    @Test
    public void TestDataSource() throws SQLException {
        DataSource dataSource = ctx.getBean(DataSource.class);
        System.out.println(dataSource.getConnection());
    }

    /**
     *更新属性
     */
    @Test
    public void updateTest() {
        String sql = "UPDATE user SET username = ? WHERE uid = ?";
        jdbcTemplate.update(sql, "神乐", 2);
    }

    /**
     *插入数据
     */
    @Test
    public void insertTest() {
        String sql = "INSERT user(username,password) values('Tonny','123456')";
        jdbcTemplate.execute(sql);
    }

    /**
     *删除记录
     */
    @Test
    public void deleteTest() {
        String sql = "DELETE FROM user where uid = ?";
        jdbcTemplate.update(sql, 3);
    }

    /**
     *批量插入
     */
    @Test
    public void batchUpdateTest() {
        String sql = "INSERT INTO user(username,password) values(?,?)";
        List<Object[]> batchArgs = new ArrayList<Object[]>();
        batchArgs.add(new Object[]{"Tina", "876543"});
        batchArgs.add(new Object[]{"Judy", "587641"});
        batchArgs.add(new Object[]{"Sam", "987632"});
        jdbcTemplate.batchUpdate(sql, batchArgs);
    }

    /**
     *查询
     */

    @Test
    public void queryForObject() {
        String sql = "SELECT uid AS id,username AS userName,password AS passWord " +
                "FROM user WHERE uid = ?";
        RowMapper<User> rowMapper = new BeanPropertyRowMapper<User>(User.class);
        User user = (User) jdbcTemplate.queryForObject(sql, rowMapper, 2);
        System.out.println(user);
    }


    /**
     *批量查询
     */
    @Test
    public void queryForList() {
        String sql = "SELECT uid AS id,username AS userName,password AS passWord FROM user WHERE uid > ?";
        RowMapper<User> rowMapper = new BeanPropertyRowMapper<User>(User.class);
        List<User> users = jdbcTemplate.query(sql, rowMapper, 3);
        System.out.println(users);
    }


    /**
     *统计
     */
    @Test
    public void countTest() {
        String sql = "SELECT COUNT(*) FROM user";
        long count = jdbcTemplate.queryForObject(sql, Long.class);
        System.out.println(count);
    }

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

esc_ai

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

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

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

打赏作者

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

抵扣说明:

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

余额充值