JDBC(java连接MySQL)

#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(); 
            } 
        } 
		
	}

}

转载于:https://my.oschina.net/duandoudou/blog/124502

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值