JDBC-ODBC桥连接MySQL的配置以及乱码问题的解决

      今天由于一个应用,需要连接MySQL,但是碰巧不支持JDBC直接连接,只能通过ODBC方式。在安装JDK的时候,实际上已经安装了sun的JDBC-ODBC桥驱动,也就是在通过ODBC连接数据库之后,就可以和JDBC一样的方式来操作数据库的读写了。下图是JDBC-ODBC调用方式的一个示意图,摘自某网友的博客。

JDBC-ODBC桥连接MySQL的配置以及乱码问题的解决

首先,应该需要安装一个MySQL的ODBC驱动,下载可以直接去mysql官网去下,参考链接:http://www.mysql.com/downloads/connector/odbc/5.2.html。安装之后,打开控制面板->管理工具->数据源(ODBC),在用户DSN面板上添加MySQL数据源。JDBC-ODBC桥连接MySQL的配置以及乱码问题的解决

Test测试通过之后,点击OK就完成了本地ODBC数据源的配置。

 

然后就可以写个java小程序测试一下JDBC-ODBC桥了。示例代码如下:

 

 

 

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.Properties;

public class Test2 {
	public static void main(String[] args) {
		Connection connection = null;
		Statement statement;
		ResultSet resultSet;
		// 加载驱动程序以连接数据库
		try {
			Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");// 这个驱动不能是其他的..
			//ITOMySQL是data Source ,root是用户名,messi是进入mysql的密码
			Properties props = new Properties();
			props.put("user", "root");
			props.put("password", "root");
			//props.put("charSet", "UTF-8");
			connection = DriverManager.getConnection("jdbc:odbc:ITOMySQL",props);
			String query = "select * from security_role";
			statement = connection.createStatement();
			resultSet = statement.executeQuery(query);
			while (resultSet.next()) {
				System.out.print("id:");
				System.out.print(resultSet.getString(1));
				System.out.print("          name:");
				System.out.print(resultSet.getString(2));
				System.out.print("                             description:");
				System.out.print(resultSet.getString(3));
				System.out.println();
			}
			connection.close();

		}
		// 捕获加载驱动程序异常
		catch (ClassNotFoundException cnfex) {
			System.err.println("装载    JDBC/ODBC 驱动程序失败。");
			cnfex.printStackTrace();
			System.exit(1); // terminate program
		}
		// 捕获连接数据库异常
		catch (SQLException sqlex) {
			System.err.println("无法连接数据库");
			sqlex.printStackTrace();
			System.exit(1); // terminate program
		} catch (Exception e) {
			System.out.println(e.toString());
		}
	}
}

 运行代码,正常运行!但是发现中文字符出现乱码。检查了下数据库默认字符集为UTF-8,怀疑可能是ODBC没有指定UTF-8的字符集,于是采用JDBC的方式来指定一个charSet的property(代码中已经注释)来进行连接,但是发现仍然获取到的是乱码。笔者怀疑ODBC数据源可能还有更多的配置,于是去ODBC数据源配置的面板上发现了还有配置指定字符集的选项如图:

 


JDBC-ODBC桥连接MySQL的配置以及乱码问题的解决

选择相应的字符集,这里选择的是UTF-8字符集,和数据库的字符集保持一致。再运行代码就可以正常显示中文了。

你可能感兴趣的:(mysql)