JDBC使用QreryRunner简化SQL查询注意事项

QreryRunner是Dbutils的核心类之一,它显著的简化了SQL查询,并与ResultSetHandler协同工作将使编码量大为减少。

注意事项

  1. 使用QreryRunner必须保证实体类的变量名,和sql语句中要查找的字段名必须相同,否则查询

不到数据,会出现NullPointerException异常

此时sql语句名和数据库名不一致

java 复制代码
public Manager selectManagerByName(String name) throws SQLException {
    QueryRunner qr = new QueryRunner(JDBCUtils.getDataSource());
    String sql = "select mgr_id,login_name,login_pwd ,mgr_name " +
                ",mgr_gender ,mgr_tel ,mgr_email ,mgr_qq ,create_time  " +
                "from tb_managers where login_name=?";
    Object[] args = {name};
    return qr.query(sql,new BeanHandler<>(Manager.class),args);
}

异常

加上别名后可正常查询

java 复制代码
public Manager selectManagerByName(String name) throws SQLException {
    QueryRunner qr = new QueryRunner(JDBCUtils.getDataSource());
    String sql = "select mgr_id mgrId ,login_name loginName,login_pwd loginPwd,mgr_name mgrName" +
                ",mgr_gender mgrGender,mgr_tel mgrTel,mgr_email mgrEmail,mgr_qq mgrQQ,create_time createTime " +
                "from tb_managers where login_name=?";
    Object[] args = {name};
    return qr.query(sql,new BeanHandler<>(Manager.class),args);
}
相关推荐
NineData7 分钟前
NineData云原生智能数据管理平台新功能发布|2025年8月版
数据库·mongodb·云原生·数据库管理工具·ninedata·数据库迁移·数据复制
白云如幻18 分钟前
【Java】QBC检索和本地SQL检索
java·数据库·sql
勘察加熊人1 小时前
python将pdf转txt,并切割ai
数据库·python·pdf
不良人天码星1 小时前
Redis单线程模型为什么快?
数据库·redis·缓存
RestCloud2 小时前
ETL 不只是数据搬运工:如何实现智能转换与清洗?
数据库·api
lu9up2 小时前
因表并行引发的血案【故障处理案例】
数据库·oracle·dba
问道飞鱼2 小时前
【大数据相关】ClickHouse命令行与SQL语法详解
大数据·sql·clickhouse
qq_356408663 小时前
es通过分片迁移迁移解决磁盘不均匀问题
java·数据库·elasticsearch
武子康3 小时前
Java-122 深入浅出 MySQL CAP理论详解与分布式事务实践:从2PC到3PC与XA模式
java·大数据·数据库·分布式·mysql·性能优化·系统架构
爱考证的小刘3 小时前
阿里云ACA认证[特殊字符]阿里云ACP认证
数据库·阿里云·云计算