Microsoft JDBC Driver 使用 getParameterMetaData 会报错?
不知道为何使用 Microsoft JDBC Driver for SQL Server 驱动时,sql语句不带参数没有问题,但是如果带参数且使用 getParameterMetaData 就会提示某个关键字附件有错误!下载了最新的 Microsoft JDBC Driver 4.1 for SQL Server 还是一样的错误。难道是没有设置好?做了下测试:
1、简单的语句测试,getParameterMetaData 对 between 支持有问题
//----------------------- dbTest 执行语句方法 ------------------
private void dbTest(String sql) {
Connection conn = null;
PreparedStatement pstmt = null;
ResultSet rs = null;
ParameterMetaData pmd = null;
try {
conn = DBHelper.getConnection();
pstmt = conn.prepareStatement(sql);
pmd = pstmt.getParameterMetaData(); // 关键是这个方法出问题
pstmt.setObject(1, 100);
pstmt.setObject(2, 1000);
rs = pstmt.executeQuery();
if(rs.next()) {
System.out.println(rs.getString(1));
}
} catch (SQLException e) {
e.printStackTrace();
} finally {
DBHelper.release(conn, pstmt, rs);
}
} //--------------------------测试1---------------------------------
// 执行下面between语句,如果dbTest中启用pstmt.getParameterMetaData(),那么会报错,(com.microsoft.sqlserver.jdbc.SQLServerException: 关键字 'between' 附近有语法错误);但是如果注释掉 pmd = pstmt.getParameterMetaData(),那么执行正常。 String sql1 = "select * from users where userId between ? and ?";
dbTest(sql1); //--------------------------测试2---------------------------------
// 将between替换成等效的(>= and <=),无论何种情况执行都正常 String sql2 = "select * from users where userId >= ? and userId <= ?";
dbTest(sql2);
2、子查询测试
// 不用 between,用 >= and <= 等效替换
// 启用 pmd = pstmt.getParameterMetaData(),报错(com.microsoft.sqlserver.jdbc.SQLServerException: 关键字 'WHERE' 附近有语法错误);但是如果不用pstmt.getParameterMetaData()这个方法,就正常执行了! String sql3 = "select * from (select userId, userName from users) as tp where tp.userId >= ? and tp.userId <= ?";
dbTest(sql3);
3、换成jtds驱动没有任何问题。
归纳下问题:
(1)不用 getParameterMetaData 方法,任何sql语句执行都没有任何问题,关键是我要用dbutils,但是这个库使用了getParameterMetaData 方法。怎么解决。
(2)使用getParameterMetaData方法时,不带参数的sql语句执行没有问题,但是如果带参数而且使用了between或者有子查询,那么就出错。为什么?是不是哪儿的设置问题?
==================================================================================
写了这些疑问查找了几天,后来仔细查看了Microsoft JDBC Driver for SQL Server的文档,才发现上面已经有了相关的说明。
在“使用参数元数据”一节中有如下提示:
SQLServerParameterMetaData 类和预定义的语句一起使用时有一些限制。JDBC 驱动程序支持 SELECT、DELETE、INSERT 和 UPDATE 语句。但是,这些语句不能包含子查询。此外,JDBC 驱动程序还支持使用 IN、IS 和 LIKE 谓词。对于搜索条件,JDBC 驱动程序支持使用 IS、<、>、LIKE、>=、<=、NOT IN、<>、!>、!< 和 != 比较运算符。不支持 FREETEXT 运算符。
dbutils使用QueryRunner时,可以设置pmdKnownBroken为true,dbutils设置参数时将绕过 getParameterMetaData 方法:
QueryRunner run = new QueryRunner(true);
QueryRunner run = new QueryRunner(dataSource, true);
Microsoft JDBC Driver 使用 getParameterMetaData 会报错?的更多相关文章
- JDBC driver连接MySQL运行报错The server time zone value 'Öйú±ê׼ʱ¼ä' is unrecognized or represents more than
出错原因: 因为安装mysql的时候时区设置的不正确. mysql默认的是美国的时区,而我们中国大陆要比他们迟8小时,采用GMT+8:00格式. 也就是说是数据库和系统时区差异所造成的. 验证:运行c ...
- 下载 Microsoft JDBC driver 7.2 for SQL Server
下载 Microsoft JDBC driver 7.2 for SQL Server:https://www.microsoft.com/zh-cn/download/confirmation.as ...
- 数据库 alert.log 日志中出现 "[Oracle][ODBC SQL Server Wire Protocol driver][SQL Server] 'RECOVER'"报错信息
现象描述: (1).数据库通过调用透明网络实现分布式事务,但透明网关停用后,失败的分布式事务并未清理. (2).数据库 alert 日志 Thu Sep 06 06:53:00 2018 Errors ...
- 在IDEA中使用JDBC获取数据库连接时的报错及解决办法
在IDEA中使用JDBC获取数据库连接时,有时会报错Sat Dec 19 19:32:18 CST 2020 WARN: Establishing SSL connection without ser ...
- 喜大普奔,微软Microsoft JDBC Driver For SQL Server已发布到maven中央仓库
相信通过java和SQLServer开发应用的同学们都经历过如下类似的问题. 微软提供的JDBC官方驱动没有放置在Maven仓库中,这样如果你的Java应用需要访问SQL Server,你不得不下载s ...
- JDBC连接SQL Server 2005 报错Connection refused: connect
com.microsoft.sqlserver.jdbc.SQLServerException: 通过端口 1433 连接到主机 localhost 的 TCP/IP 连接失败.错误:“Connect ...
- Microsoft Visual Stduio 2005 Ent安装报错解决方法
错误:Microsoft Visual Studio 2015 Devenv : 安装时发生严重错误 安装过程第一次出现该错误时,查看了日志文件,错误提示如下: [0EEC:0EF0][2016-10 ...
- Microsoft SQL server Management Studio工具报错“应用程序的组件中发生了无法处理的异常”
解决办法 打开目录: C:\Documents and Settings\Administrator\Application Data\Microsoft\Microsoft SQL Server\1 ...
- Microsoft.Practices.Unity使用配置文件总是报错The type name or alias could not be resolved.
Type name could not be resolved. Please check config file http://stackoverflow.com/questions/1493564 ...
随机推荐
- UIButton常见用法
//UIButton是iOS中用来响应用户点击的控件,既可以显示文字,也可以显示图片,也可以处理用户交互 //UIButton的创建,一般采用类方法来创建,不需要释放 //UIButton 也是UIC ...
- fiddler 的AutoRespoder的使用(手动添加测试桩)
---恢复内容开始--- 1.首先我们抓取一个百度的请求,由于百度请求是https协议,需要手动添加证书(这个不写了,大佬们自己手动找下资料) 2.fiddler抓取的百度请求,其他的无关信息删除,便 ...
- canvas变换(移动,缩放等)
代码: 1 /** 2 * Created by Administrator on 2016/1/30. 3 */ 4 function draw (id){ 5 var canvas = docum ...
- 人物-IT-任正非:任正非
ylbtech-人物-IT-任正非:任正非 任正非,祖籍浙江省浦江县,1944年10月25日出生于贵州省安顺市镇宁县.华为技术有限公司主要创始人兼总裁. 1963年就读于重庆建筑工程学院(现已并入重庆 ...
- Ruby中的include
Ruby中的include语句应注意以下两个问题: 1.include与文件无关.C语言中,#include预处理指令在编译期将一个文件的内容插入到另一个文件中.Ruby语句只是简单地产生一个指向指定 ...
- ng2 中使用echart
1.首先创建echarts指令 //echart.directive.ts important { Directive,ElementRef,Input,Ouput,Onchanges,OnInit, ...
- docker出现错误 could not read CA certificate
1. 问题描述 $ docker login # 无法正常使用 其他一堆命令,显示验证失败之类的问题 2. 解决方案 $ unset DOCKER_TLS_VERIFY $ unset DOCKER_ ...
- mysql主从服务器复制操作
master主机ip:192.168.1.19 用户名sunzy 密码123456slave主机ip:192.168.1.20 1.配置master1)接下来对master进行配置,包括打开二进制日 ...
- 安装yum在ubnutu上
安装yum在ubnutu上1:首先检测是否安装了build-essential程序包 apt-get install build-essential2.安装yumapt-get install yum ...
- 树莓派 Learning 002 装机后必要的操作 --- 09 root用户 密码
树莓派 装机后必要的操作 - root用户 密码 我的树莓派型号:Raspberry Pi 2 Model B V1.1 装机系统:NOOBS v1.9.2 树莓派使用的Linux是debian系统, ...