使用DBUtils连接Sqlserver插入失败的问题-阿里云开发者社区

开发者社区> 数据库> 正文
登录阅读全文

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

简介: 使用DBUtils连接Sqlserver插入失败的问题 帅宏军 一、问题描述: 使用DBUtils对数据库Sqlserver进行插入操作时,失败,提示参数“?”不可识别。

使用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();
		}
	}


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


版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

分享:
数据库
使用钉钉扫一扫加入圈子
+ 订阅

分享数据库前沿,解构实战干货,推动数据库技术变革

其他文章
最新文章
相关文章