感觉比hibernate还好用的JdbcTemplete

package com.template;

import com.dataSource.druid.utils.DBUtils;
import com.domain.User;
import com.sun.tracing.dtrace.ArgsAttributes;
import org.junit.Test;
import org.springframework.jdbc.core.BeanPropertyRowMapper;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.core.RowMapper;

import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.List;
import java.util.Map;

/**
 * JbbcTemplate 的update
 */
public class JdbcTemplateDemo02 {

    JdbcTemplate jdbcTemplate = new JdbcTemplate(DBUtils.getDataSource());

    @Test
    public void add () {

        int count = jdbcTemplate.update("INSERT INTO account VALUES (?,?,?)",null,"sa",10);
        System.out.println(count);

    }

    @Test
    public void delete () {

        int count = jdbcTemplate.update("delete FROM account WHERE id = ?",5);
        System.out.println(count);

    }

    @Test
    public void update () {

        int count = jdbcTemplate.update("UPDATE account SET money = ? WHERE id = ?",0,4);
        System.out.println(count);

    }

    @Test
    public void test () {
        //注意我们的map只能封装结果集是一条的数据
        Map<String,Object> map = jdbcTemplate.queryForMap("select * from account where id = ?",1);
        System.out.println(map);

    }


    @Test
    public void test01 () {
        //注意当我们封装多条记录的时候我们可以使用 封装list的方法  这个方法就是每一个记录封装成一个map放到list中
        List<Map<String,Object>> list = jdbcTemplate.queryForList("select * from account");
        System.out.println(list);

    }


    @Test
    public void test02 () {
        //查询出多条记录  把它封装成对应的对象  方法list里面
        List<User> list = jdbcTemplate.query("select * from account", new RowMapper<User>() {
            @Override
            public User mapRow(ResultSet resultSet, int i) throws SQLException {
                User user = new User();

                user.setId(resultSet.getInt("id"));
                user.setMoney(resultSet.getInt("money"));
                user.setUsername(resultSet.getString("username"));

                return user;
            }
        });
        System.out.println(list);

    }

    /**
     * 这个方法是真的好用啊
     */
    @Test
    public void test03 () {
        //查询出多条记录  把它封装成对应的对象  方法list里面  我们使用它们提供的实现类
        List<User> list = jdbcTemplate.query("select * from account",new BeanPropertyRowMapper<User>(User.class));
        System.out.println(list);

    }

    @Test
    public void test04 () {
        //就是把我们查询出来的结果封装成你想要的那个样子   后面那个参数传你想要的那个参数的字节码
        Long aLong = jdbcTemplate.queryForObject("select COUNT(id) from account",Long.class);
        System.out.println(aLong);

    }

}

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值