Java MySQL 连接
java mysql 连接
java 通过使用 jdbc 来连接 mysql 数据库。java 连接 mysql 需要专用的驱动包,官方下载地址为:http://dev.mysql.com/downloads/connector/j/,解压后得到 jar 库文件,然后在项目中导入该库文件。
本范例使用的是 eclipse,导入 jar 包:
mysql 8.0 以上版本的数据库连接有所不同:
-
1、mysql 8.0 以上版本驱动包版本 mysql-connector-java-8.0.16.jar。
-
2、com.mysql.jdbc.driver 更换为 com.mysql.cj.jdbc.driver。
-
mysql 8.0 以上版本不需要建立 ssl 连接的,需要显式关闭。
-
allowpublickeyretrieval=true 允许客户端从服务器获取公钥。
-
最后还需要设置 cst。
加载驱动与连接数据库方式如下:
class.forname("com.mysql.cj.jdbc.driver"); conn = drivermanager.getconnection("jdbc:mysql://localhost:3306/test_demo?usessl=false&allowpublickeyretrieval=true&servertimezone=utc","root","password");
1. 创建测试数据
接下来我们在 mysql 中创建 yapf 数据库,并创建 websites 数据表,表结构如下:
create table `websites` ( `id` int(11) not null auto_increment, `name` char(20) not null default '' comment '站点名称', `url` varchar(255) not null default '', `alexa` int(11) not null default '0' comment 'alexa 排名', `country` char(10) not null default '' comment '国家', primary key (`id`) ) engine=innodb auto_increment=10 default charset=utf8;
插入一些数据:
insert into `websites` values ('1', 'google', 'https://www.google.cm/', '1', 'usa'); insert into `websites` values ('2', '淘宝', 'https://www.taobao.com/', '13', 'cn'),; insert into `websites` values ('3', '硕编程', 'http://www.yapf.com/', '888', ''); insert into `websites` values ('4', '微博', 'http://weibo.com/', '20', 'cn'); insert into `websites` values ('5', 'facebook', 'https://www.facebook.com/', '3', 'usa');
数据表显示如下:
2. 连接数据库
以下范例使用了 jdbc 连接 mysql 数据库,注意一些数据如用户名,密码需要根据你的开发环境来配置:
package com.yapf.test; import java.sql.*; public class mysqldemo { // mysql 8.0 以下版本 - jdbc 驱动名及数据库 url static final string jdbc_driver = "com.mysql.jdbc.driver"; static final string db_url = "jdbc:mysql://localhost:3306/yapf"; // mysql 8.0 以上版本 - jdbc 驱动名及数据库 url //static final string jdbc_driver = "com.mysql.cj.jdbc.driver"; //static final string db_url = "jdbc:mysql://localhost:3306/yapf?usessl=false&allowpublickeyretrieval=true&servertimezone=utc"; // 数据库的用户名与密码,需要根据自己的设置 static final string user = "root"; static final string pass = "123456"; public static void main(string[] args) { connection conn = null; statement stmt = null; try{ // 注册 jdbc 驱动 class.forname(jdbc_driver); // 打开链接 system.out.println("连接数据库..."); conn = drivermanager.getconnection(db_url,user,pass); // 执行查询 system.out.println(" 范例化statement对象..."); stmt = conn.createstatement(); string sql; sql = "select id, name, url from websites"; resultset rs = stmt.executequery(sql); // 展开结果集数据库 while(rs.next()){ // 通过字段检索 int id = rs.getint("id"); string name = rs.getstring("name"); string url = rs.getstring("url"); // 输出数据 system.out.print("id: " + id); system.out.print(", 站点名称: " + name); system.out.print(", 站点 url: " + url); system.out.print("\n"); } // 完成后关闭 rs.close(); stmt.close(); conn.close(); }catch(sqlexception se){ // 处理 jdbc 错误 se.printstacktrace(); }catch(exception e){ // 处理 class.forname 错误 e.printstacktrace(); }finally{ // 关闭资源 try{ if(stmt!=null) stmt.close(); }catch(sqlexception se2){ }// 什么都不做 try{ if(conn!=null) conn.close(); }catch(sqlexception se){ se.printstacktrace(); } } system.out.println("goodbye!"); } }