使用DBUtils连接Sqlserver插入失败的问题

使用DBUtils连接Sqlserver插入失败的问题

帅宏军

一、问题描述:

使用DBUtils对数据库Sqlserver进行插入操作时,失败,提示参数“?”不可识别。代码如下

  1. public void insert(Customer customer) {  
  2. String sql = "insert into customer values(?,?,?,?,?,?,?,?,?)";  
  3.   
  4. Object[] args = { CustomerUtils.getID(), customer.getName(),  
  5.         customer.getGender(), customer.getBirthday(),  
  6.         customer.getCellphone(), customer.getEmail(),  
  7.         customer.getPreference(), customer.getType(),  
  8.         customer.getDescription() };  
  9.                 
  10. // 在执行这段代码时就出错了   
  11. QueryRunner queryRunner = new QueryRunner(JDBCUtils.getDataSource());  
  12.   
  13. try {  
  14.     queryRunner.update(sql, args);  
  15. catch (SQLException e) {  
  16.     // TODO Auto-generated catch block   
  17.     e.printStackTrace();  
  18. }  
		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参数。


二、解决方法

附上代码

  1.     public void insert(Customer customer) {  
  2.     String sql = "insert into customer values(?,?,?,?,?,?,?,?,?)";  
  3.   
  4.     Object[] args = { CustomerUtils.getID(), customer.getName(),  
  5.             customer.getGender(), customer.getBirthday(),  
  6.             customer.getCellphone(), customer.getEmail(),  
  7.             customer.getPreference(), customer.getType(),  
  8.             customer.getDescription() };  
  9.   
  10.     //关键是这句加一个参数true   
  11.     QueryRunner queryRunner = new QueryRunner(JDBCUtils.getDataSource(),  
  12.             true);  
  13.   
  14.     try {  
  15.         queryRunner.update(sql, args);  
  16.     } catch (SQLException e) {  
  17.         // TODO Auto-generated catch block   
  18.         e.printStackTrace();  
  19.     }  
  20. }  
		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();
		}
	}


转载请注明出处:http://blog.csdn.net/shuaihj/article/details/15378109



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值