Spring中的jdbcTemplate操作

本文介绍如何使用Spring框架中的jdbcTemplate进行数据库操作,包括连接数据库、增删改查等基本功能的实现方法,并提供了具体的代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Spring中的jdbcTemplate操作

准备工作

1.设置数据库信息

DriverManagerDataSource dataSource = new DriverManagerDataSource();
dataSource.setDriverClassName("com.mysql.jdbc.Driver");
dataSource.setUrl("jdbc:mysql://localhost:3306/ssm");
dataSource.setUsername("root");
dataSource.setPassword("root");

2.创建jdbcTemplate对象,设置数据源

JdbcTemplate jdbcTemplate = new JdbcTemplate(dataSource);

测试crud

1.add

public void add() {
    String sql = "insert into user(username,password,sex,address) values(?,?,?,?)";
    jdbcTemplate.update(sql, "令狐冲", "123", "男", "华山");
}

2.delete

String sql = "delete from user where userId = ?";
jdbcTemplate.update(sql, 2);

3.update

String sql = "update user set password = ? where userId = ?";
jdbcTemplate.update(sql, "lhc", 3);

4.select

4.1 查询有多少条数据:

public Integer selectNum() {
    String sql = "select count(*) from user";
    //第二个参数是返回类型
    Integer count = jdbcTemplate.queryForObject(sql, Integer.class);
    return count;
}

4.2 查询返回对象

public User selectUser() {
    String sql = "select * from user where userId = ?";
    //需要自己写一个继承RowMapper接口的实现类
    User user  = (User) jdbcTemplate.queryForObject(sql, new MyRowMapper(), 3);
    return user;
}
class MyRowMapper implements RowMapper{
    @Override
    public User mapRow(ResultSet resultSet, int i) throws SQLException {
        //从结果集中拿到数据
        String userId = resultSet.getString("userId");
        String username = resultSet.getString("username");
        String password = resultSet.getString("password");
        String sex = resultSet.getString("sex");
        String address = resultSet.getString("address");
        //把得到的数据封装到对象中
        User user = new User();
        user.setUserId(Integer.valueOf(userId));
        user.setUsername(username);
        user.setPassword(password);
        user.setSex(sex);
        user.setAddress(address);
        return user;
    }
}

4.3 查询返回list

public List<User> selectUserList() {
    String sql = "select * from user";
    List<User> list = jdbcTemplate.query(sql, new MyRowMapper());
    return list;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值