使用DBUtils连接Sqlserver插入失败的问题
发布时间:2020-12-12 13:19:00 所属栏目:MsSql教程 来源:网络整理
导读:使用DBUtils连接Sqlserver插入失败的问题 帅宏军 一、问题描述: 使用DBUtils对数据库Sqlserver进行插入操作时,失败,提示参数“?”不可识别。代码如下 [java] view plain copy print ? public ? void ?insert(Customer?customer)?{?? String?sql?=? "inse
使用DBUtils连接Sqlserver插入失败的问题帅宏军一、问题描述: 使用DBUtils对数据库Sqlserver进行插入操作时,失败,提示参数“?”不可识别。代码如下 [java] view plain copy print ?
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参数。 附上代码 [java] view plain copy print ?
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(); } } 转载请注明出处:http://www.voidcn.com/article/p-qbdpqvie-bgg.html (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |