使用JDBC获取和设置数据库服务器连接变量

时间:2011-09-04 10:22:36

标签: java mysql jdbc

当我打开到MySQL数据库的JDBC连接时,我想设置一些数据库服务器变量,例如,每次建立连接时,我想用这个值设置变量sqlmode:

SET sql_mode='STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION,PIPES_AS_CONCAT';

用于启用管道串连接...

我必须在查询语句中发送此参数,还是可以直接在JDBC Connection上设置此参数? JDBC连接上是否有允许设置此变量的属性?

使用JDBC连接设置或检索数据库服务器变量的最佳方法是什么?

1 个答案:

答案 0 :(得分:5)

您是否尝试将其添加到getConnection调用中?

String url = "jdbc:mysql://localhost/test?user=sqluser&password=sqluserpw&sessionVariables=sql_mode='STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION,PIPES_AS_CONCAT'";
Class.forName("com.mysql.jdbc.Driver");
Connection c = DriverManager.getConnection(url);

此致