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 ...
随机推荐
- JS undefined
undefined表示"缺少值",就是此处应该有一个值,但是还没有定义.典型用法是: (1)变量被声明了,但没有赋值时,就等于undefined. (2) 调用函数时,应该提供的参 ...
- 洛谷【P1303】A*B Problem
题目传送门:https://www.luogu.org/problemnew/show/P1303 高精度乘法板子题,灵性地回忆一下小学时期列竖式的草稿纸即可. 时间复杂度:\(O(len^2)\) ...
- Dockerfile创建MySQL容器
本文目的是创建一个MySQL的image,并且在新创建出来的容器里自动启动mysql服务接受外部连接 步骤: 1. 首先创建一个目录并在目录下创建一个Dockerfile,文件内容如下 FROM ce ...
- Poj 1316 Self Numbers(水题)
一.Description In 1949 the Indian mathematician D.R. Kaprekar discovered a class of numbers called se ...
- Java类的生命周期(转)
引言 最近有位细心的朋友在阅读笔者的文章时,对java类的生命周期问题有一些疑惑,笔者打开百度搜了一下相关的问题,看到网上的资料很少有把这个问题讲明白的,主要是因为目前国内java方面的教材大多只是告 ...
- k8s 基础 k8s架构和组件
k8s 的总架构图
- /*带动画效果的hover*/
<!DOCTYPE html> /*带动画效果的hover*/ <html lang="en"> <head> <meta charset ...
- [hdu1402]A * B Problem Plus(FFT模板题)
解题关键:快速傅里叶变换fft练习. 关于结果多项式长度的确定,首先将短多项式扩展为长多项式,然后扩展为两倍. #include<cstdio> #include<cstring&g ...
- error C2144: 语法错误:“int”的前面应有“;”
error C2144: 语法错误:"int"的前面应有";" C++- error C2144 syntax error : 'int' should be ...
- 1.QObject类
简述 QObject类是所有Qt对象的基类. QObject是Qt对象模型的核心. 该模型的核心特征是称为信号和槽的对象通信机制. 您可以使用connect()将信号连接到槽,并用disconnect ...