Kettle报OPTION SQL_SELECT_LIMIT=DEFAULT错误的解决办法

近日使用kettle开发报表时,遇到错误:OPTION SQL_SELECT_LIMIT=DEFAULT

搜罗了下网络上解释基本是一致的:
mysql通过jdbc链接的时候会进行测试’SET OPTION SQL_SELECT_LIMIT=DEFAULT’,但是5.6以后的版本弃用了set的方式

的确,我提数使用的源库版本就是5.6,但是kettle中数据库连接其实是通的,只是在获取列的时候提示了如上报错。暂且不管它,既然高版本的连接驱动解决了这个问题,那我们就去升级驱动好了,参照大家的说法,mysql-connector-java需要升级到5.1.22以上。

尝试一(一般都能解决):
我依次下载了mysql-connector-java-5.1.23.jar、mysql-connector-java-5.1.25.jar、mysql-connector-java-5.1.36.jar置于data-integration\lib目录并重启kettle。竟然都没解决!

不合理啊!难道驱动放置的目录不对?又看到说windows 64系统驱动包要放到data-integration\libswt\win64目录:

尝试二:
依次将上面三个版本的驱动包放入data-integration\libswt\win64目录并重启kettle,依然失败!

怀疑人生中…是不是大家的解决办法是基于老版本的开发工具的(我当前使用的工具是8.2的,最新)?OK,我去换下老版本的,于是下载了Kettle7.1。

尝试三:
下载Kettle7.1之后,以上两种方法都试了一遍,未果!

是不是老的驱动的影响?那么kettle默认的JDBC连接驱动在哪呢?搜索了下安装目录,竟然没有!那我放入data-integration\lib目录应该起作用才对啊!

难道?是不是我以前在JRE中内置了驱动包?致使我以上的尝试都没起作用?

尝试四:
进入%JAVA_HOME%\jre\lib\ext目录,果真发现了mysql连接驱动包:mysql-connector-java-5.1.14.jar!想必是我之前放进来的,替换成以上提到的任意驱动包,比如mysql-connector-java-5.1.25.jar,打开kettle,再次尝试,问题解决!

你可能感兴趣的:(kettle)