使用DBUtils连接Sqlserver插入失败的问题
2013-11-11 19:47
232 查看
使用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(); } }
问题原因发现是sqlserver的jdbc驱动在判断占位符类型的时候有问题;具体的就是获得ParameterMetaData的时候出了问题,这个时候可以用一个knowParaType的参数避免这个问题,就是在创建 QueryRunner的时候,提供一个true参数。
二、解决方法
附上代码
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() }; //关键是这句加一个参数true QueryRunner queryRunner = new QueryRunner(JDBCUtils.getDataSource(), true); try { queryRunner.update(sql, args); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } }
转载请注明出处:/article/1411374.html
相关文章推荐
- SQL Server的非聚集索引中会存储NULL吗?
- SQL Server的非聚集索引中会存储NULL吗?
- Navicat for MySQL使用手记(上)--创建数据库和表
- oracle体系结构小结
- sql中的limit和offset
- 手把手教你mysql(二)Database操作
- mysql小技巧
- DB2新手使用的一些小笔记:新建实例、数据库路径不存在、客户端连接 .
- MySQL 5.6学习笔记(数据表基本操作)
- oracle insert语句 中含有&
- Windows下PostgreSQL安装图解
- T-SQL 练习整理
- Oracle常用Sql--初级
- Oracle replace 函数用法
- mysql数据库常用备份、恢复命令
- MySQL Administrator连接VMWare下Red hat中MySQL过程
- Mysql数据库的一些命令
- 简单工厂模式构建数据访问层以实现多种数据库之间的切换
- DB2日常表,空间管理等部分SQL语句
- Ubuntu下远程访问MySQL数据库