#Java连接MySQL
今天下午自己在试着连接MySQL数据库,作为初学者,遇到了很多问题,自己也不是很清楚,就慢慢的查资料,看论坛慢慢的总结了一些经验,上来和大家分享一下!(有些专业名词记得不太清楚,希望大家见谅!)
##准备工作
- 编程环境配置:
首先要安装JDK和MySql,这是基本的要求,在这里就不介绍了。另外还得下载mysql-connector- java的jar压缩包。
##配置驱动程序
- java程序的编译环境,有些人使用的是IDE,也有人直接使用的是DOS窗口。
###DOS下配置驱动程序
- 拷贝文件
使用DOS窗口的,请将下载好的mysql-connector-java的jar压缩包拷贝到一个磁盘的任意目录(最好好放到自己经常使用的目录,我下载的是mysql-connector-java-5.0.4-bin.jar,将他放到了D:\Program Files目录下面)。 - 配置环境变量
我的是win7系统,配置环境变量如下:右键 计算机→属性→高级系统设置→环境变量→系统变量,在系统变量中找到classpath,在classpath中添加mysql-connector-java的路径(也就是自己存放mysql-connector-java的目录,我的是在D:\Program Files目录下,所以我就添加了D:\Program Files\mysql-connector-java-5.0.4-bin.jar)主要要在路径前面添加;(分号)作为和上一个路径的分隔符,然后一路确定确定。
###IDE环境下配置驱动程序
- 存放文件
将下载好的mysql-connector-java的jar压缩包存放到磁盘。 - 导入mysql-connector-java驱动程序包 我使用的是Eclipse,所以我的导入步骤如下: 在Eclipse中菜单栏找到 Project,接下来Project→Properties→Java Build Path,选择Libraries选项卡,点击右侧 Add External JARs,会弹出JAR Selection对话框,然后找到自己先存放mysql-connector-java的地方,点击,然后确定,然后会看到你选择的JAR包出现在对话框中,然后点击 OK ,导入就成功了!
##连接数据库
- 现在可以编辑连接MySQL的java程序了
- 导入类
//接口 Connection,与特定数据库的连接(会话)。在连接上下文中执行 SQL 语句并返回结果。
import java.sql.Connection;
//类 DriverManager,管理一组 JDBC 驱动程序的基本服务。
import java.sql.DriverManager;
//类 SQLException,提供关于数据库访问错误或其他错误信息的异常。
import java.sql.SQLException;
//接口 Statement,用于执行静态 SQL 语句并返回它所生成结果的对象。
import java.sql.Statement;
//接口 ResultSet,表示数据库结果集的数据表,通常通过执行查询数据库的语句生成。
import java.sql.ResultSet;
- 创建对象及常量
创建常量主要用来存放驱动程序名称,数据库的用户名,密码,和URL地址,驱动程序名称是固定的为com.mysql.jdbc.Driver,用户名和密码是自己数据库的连接账户和密码,可以在DOS中执行mysql -h主机地址 -u 用户名 -p用户密码 来测试,我的测试命令为:mysql -h localhost -u root -p123456,注意-p和密码<比如我的123456>之间是没有空格的。或者执行mysql -h主机地址 -u 用户名 -p也可以,这样系统会弹出输入密码的命令。
URL地址,基本的形式是jdbc:mysql://主机名:端口号/要连接数据库名称, 比如我的就是jdbc:mysql://localhost:3309/doudou(我的端口号是3309,我自己建立的数据库名称为doudou),如果不知道端口好的,可以在DOS中执行命令show variables like 'port';,当然前提是你已经通过命令 mysql -h主机地址 -u用户名 -p用户密码 成功连接到了数据库。
//驱动程序名
final String driver = "com.mysql.jdbc.Driver";
//URL指向要访问的数据库名doudou
final String URL = "jdbc:mysql://localhost:3309/doudou";
//用户名(我是用的root账户root)
final String name = "root";
//密码
final String password = "123456";
//创建//数据库表达式
Statement stmt = null;
//创建结果集
ResultSet rs = null;
//创建数据库连接
Connection conn = null;
- 建立连接
// 加载驱动程序
Class.forName(driver);
//连接数据库
conn = DriverManager.getConnection(URL, name, password);
//查看是否连接成功
if(!conn.isClosed()){
System.out.println("Succeeded connecting to the Database!");
}
//获取表达式
stmt =conn.createStatement();
如果成功输出Succeeded connecting to the Database! 就表示你已经成功连接到数据库了! 接下来就可以尝试着查看数据库信息了!
rs = stmt.executeQuery("SELECT * FROM persons");
//输出数据
System.out.println("姓名:" + "\t\t" + "年龄");
while(rs.next()){
System.out.println(rs.getString("name") + "\t\t" + rs.getShort("age"));
}
当然建立连接的这些代码都应该是包含在 try{ } catch(){ }里面的,否则会抛出异常!在catch后面还要加上finally语句,用来执行关闭连接和数据库的操作。
全部的代码如下:大家可以借鉴一下,如果有什么不足,也希望大家批评指正!谢谢!
<!-- lang: java -->
//导入类
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;
import java.sql.ResultSet;
public class TestConnection {
public static void main(String[] args) {
//驱动程序名
final String driver = "com.mysql.jdbc.Driver";
//URL指向要访问的数据库名doudou
final String URL = "jdbc:mysql://localhost:3309/doudou";
//用户名(我是用的端丽软账户root)
final String name = "root";
//密码
final String password = "123456";
//创建//数据库表达式
Statement stmt = null;
//创建结果集
ResultSet rs = null;
//创建数据库连接
Connection conn = null;
try{
// 加载驱动程序
Class.forName(driver);
//连接数据库
conn = DriverManager.getConnection(URL, name, password);
//查看是否连接成功
if(!conn.isClosed()){
System.out.println("Succeeded connecting to the Database!");
}
//获取表达式
stmt =conn.createStatement();
//执行SQL
rs = stmt.executeQuery("SELECT * FROM persons");
//输出数据
System.out.println("姓名:" + "\t\t" + "年龄");
while(rs.next()){
System.out.println(rs.getString("name") + "\t\t" + rs.getShort("age"));
}
} catch(Exception e){
e.printStackTrace();
} finally {
try {
if(rs != null) {
rs.close();
}
if(stmt != null) {
stmt.close();
}
if(conn != null) {
conn.close();
}
} catch(Exception ex) {
ex.printStackTrace();
}
}
}
}