使用dbutils连接sqlserver插入失败的问题
帅宏军
一、问题描述:
使用dbutils对数据库sqlserver进行插入操作时,失败,提示参数“?”不可识别。代码如下
- public void insert(Customer customer) {
- String sql = "insert into customer values(?,?,?)";
- Object[] args = { CustomerUtils.getID(), customer.getName(),
- customer.getGender(), customer.getBirthday(),
- customer.getCellphone(), customer.getEmail(),
- customer.getPreference(), customer.getType(),
- customer.getDescription() };
- // 在执行这段代码时就出错了
- QueryRunner queryRunner = new QueryRunner(JDBCUtils.getDataSource());
- try {
- queryRunner.update(sql, args);
- } catch (sqlException e) {
- // Todo Auto-generated catch block
- e.printstacktrace();
- }
public void insert(Customer customer) { String sql = "insert into customer values(?,?)"; Object[] args = { CustomerUtils.getID(),customer.getName(),customer.getGender(),customer.getBirthday(),customer.getCellphone(),customer.getEmail(),customer.getPreference(),customer.getType(),customer.getDescription() }; // 在执行这段代码时就出错了 QueryRunner queryRunner = new QueryRunner(JDBCUtils.getDataSource()); try { queryRunner.update(sql,args); } catch (sqlException e) { // Todo Auto-generated catch block e.printstacktrace(); } }
问题原因发现是sqlserver的jdbc驱动在判断占位符类型的时候有问题;具体的就是获得ParameterMetaData的时候出了问题,这个时候可以用一个kNowParaType的参数避免这个问题,就是在创建 QueryRunner的时候,提供一个true参数。
附上代码
- public void insert(Customer customer) {
- String sql = "insert into customer values(?,?)";
- Object[] args = { CustomerUtils.getID(),
- customer.getGender(),
- customer.getCellphone(),
- customer.getPreference(),
- customer.getDescription() };
- //关键是这句加一个参数true
- QueryRunner queryRunner = new QueryRunner(JDBCUtils.getDataSource(),
- true);
- try {
- queryRunner.update(sql, args);
- } catch (sqlException e) {
- // Todo Auto-generated catch block
- e.printstacktrace();
- }
- }
public void insert(Customer customer) { String sql = "insert into customer values(?,customer.getDescription() }; //关键是这句加一个参数true QueryRunner queryRunner = new QueryRunner(JDBCUtils.getDataSource(),true); try { queryRunner.update(sql,args); } catch (sqlException e) { // Todo Auto-generated catch block e.printstacktrace(); } }
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。