支持命名参数的JdbcTemplate

本文介绍如何使用Spring JDBC中的NamedParameterJdbcTemplate进行数据库操作,通过BeanPropertySqlParameterSource简化参数设置过程,提高代码可读性和维护性。

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

在上2个例子中,参数的设置必须要与sql语句中的?对应,当参数很多时就会很不方便。

package cn.itcast.jdbc.spring;

import org.springframework.jdbc.core.BeanPropertyRowMapper;
import org.springframework.jdbc.core.namedparam.BeanPropertySqlParameterSource;
import org.springframework.jdbc.core.namedparam.NamedParameterJdbcTemplate;
import org.springframework.jdbc.core.namedparam.SqlParameterSource;
import org.springframework.jdbc.support.GeneratedKeyHolder;
import org.springframework.jdbc.support.KeyHolder;

import cn.itcast.domain.User;
import cn.itcast.jdbc.JdbcUtils;

public class NamedJdbcTemplate {

    public static void main(String[] args) {
        User user = new User();
        user.setMoney(10);
        user.setId(2);
        System.out.println(findUser(user));
    }

    static NamedParameterJdbcTemplate named = new NamedParameterJdbcTemplate(
            JdbcUtils.getDataSource());


    static int addUser(User user){

        String sql="insert into user(name,birthday,money)values(:name,:birthday,:money)";
        SqlParameterSource ps = new BeanPropertySqlParameterSource(user);       //参数源
        KeyHolder keyHolder=new GeneratedKeyHolder();
        named.update(sql, ps,keyHolder);    
        int id=keyHolder.getKey().intValue();
        user.setId(id);
        return id;
    }

    static User findUser(User user) {
        String sql = "select id ,name,money,birthday from user where money > :money and id<:id";
        SqlParameterSource ps = new BeanPropertySqlParameterSource(user);       //参数源
        Object u = named.queryForObject(sql, ps,
                new BeanPropertyRowMapper<User>(User.class));
        return (User) u;
    }
}

上面的例子中使用了BeanPropertySqlParameterSource 参数源,这要求sql语句中的命名参数必须与user中的参数同名。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值