データベースへの JDBC 接続:
1. JDBC ドライバーをロードします2. データベース接続を作成します
4. SQL ステートメントを実行します
6.結果
7. JDBC オブジェクトを閉じる
1. JDBC ドライバーをロードします:
//加载数据库驱动总共有三种方式: try{ //① Class.forName("com.mysql.jdbc.Driver") ; //② com.mysql.jdbc.Driver driver = new com.mysql.jdbc.Driver(); //③ new com.mysql.jdbc.driver(); }catch(ClassNotFoundException e){ System.out.println("找不到驱动程序类 ,加载驱动失败!"); e.printStackTrace() ; }
ロードが成功すると、Driver クラスのインスタンスが DriverManager クラスに登録されます。
String url = "jdbc:mysql://localhost:3306/samp_db?" + "user=root&password=mysql&useUnicode=true&characterEncoding=UTF8";3. データベース接続を作成します
•DriverManager の getConnectin(String url, String username, String password) メソッドを使用して、接続する指定された番号を渡します
String url = "jdbc:mysql://localhost:3306/test" ; String username = "root" ; String password = "root" ; try{ Connection con = DriverManager.getConnection(url , username , password ) ; }catch(SQLException se){ System.out.println("数据库连接失败!"); se.printStackTrace() ; }
1. 静的 SQL ステートメントを実行します。通常、Statement インスタンスを通じて実装されます。
2. 動的 SQL ステートメントを実行します。通常は PreparedStatement インスタンスを通じて実装されます。 3. データベースストアドプロシージャを実行します。通常は CallableStatement インスタンスを通じて実装されます。
Statement stmt = con.createStatement() ; PreparedStatement pstmt = con.prepareStatement(sql) ; CallableStatement cstmt = con.prepareCall("{CALL demoSp(? , ?)}") ;
2. intexecuteUpdate(String sqlString): INSERT、UPDATE、または DELETE ステートメントと SQL DDL ステートメント (CREATE TABLE や DROP TABLE など) を実行するために使用されます。
3.execute(sqlString): 複数の結果を実行して返すために使用されます。セット、カウントを更新する複数のステートメント、または両方の組み合わせ。ResultSet rs = stmt.executeQuery("SELECT * FROM ...") ; int rows = stmt.executeUpdate("INSERT INTO ...") ; boolean flag = stmt.execute(String sql) ;
2. クエリの実行によって返される結果は ResultSet オブジェクトです。
• ResultSet には SQL ステートメントの条件に一致するすべての行が含まれており、一連の get メソッドを通じてこれらの行のデータへのアクセスを提供します。• ResultSet オブジェクトのアクセス メソッドを使用してデータを取得します:
while(rs.next()){ String name = rs.getString("name") ; String pass = rs.getString(1) ; // 此方法比较高效 } (列是从左到右编号的,并且从列1开始)
2. ステートメントを閉じる
3. 接続オブジェクトを閉じるif(rs != null){ // 关闭记录集 try{ rs.close() ; }catch(SQLException e){ e.printStackTrace() ; } } if(stmt != null){ // 关闭声明 try{ stmt.close() ; }catch(SQLException e){ e.printStackTrace() ; } } if(conn != null){ // 关闭连接对象 try{ conn.close() ; }catch(SQLException e){ e.printStackTrace() ; } }
package org.Mysql; import java.sql.Connection;import java.sql.DriverManager; import java.sql.ResultSet;import java.sql.SQLException; import java.sql.Statement;public class mysqlDemo { public static void main(String[] args) throws Exception { //使用connection进行数据库的连接,创建一个connection对象,用于数据库的连接 Connection conn = null; String sql; // MySQL的JDBC URL编写方式:jdbc:mysql://主机名称(localhost):连接端口(3306)/数据库的名称?参数=值 // 指定数据库的用户名和密码 // 避免中文乱码要指定useUnicode和characterEncoding // 执行数据库操作之前要在数据库管理系统上创建一个数据库,名字自己定 // 下面语句之前就要先创建samp_db数据库 String url = "jdbc:mysql://localhost:3306/samp_db?" + "user=root&password=mysql&useUnicode=true&characterEncoding=UTF8"; try { // 之所以要使用下面这条语句,是因为要使用MySQL的驱动,所以我们要把它驱动起来, // 可以通过Class.forName把它加载进去,也可以通过初始化来驱动起来,下面三种形式都可以 // 动态加载mysql驱动 Class.forName("com.mysql.jdbc.Driver"); // or: // com.mysql.jdbc.Driver driver = new com.mysql.jdbc.Driver(); // or: // new com.mysql.jdbc.Driver(); System.out.println("成功加载MySQL驱动程序"); // 一个Connection代表一个数据库连接 conn = DriverManager.getConnection(url); // Statement里面带有很多方法,比如executeUpdate可以实现插入,更新和删除等 Statement stmt = conn.createStatement(); sql = "create table student(NO char(20),name varchar(20),primary key(NO))"; int result = stmt.executeUpdate(sql);// executeUpdate语句会返回一个受影响的行数,如果返回-1就没有成功 if (result != -1) { System.out.println("创建数据表成功"); sql = "insert into student(NO,name) values('2012001','陶伟基')"; result = stmt.executeUpdate(sql); sql = "insert into student(NO,name) values('2012002','周小俊')"; result = stmt.executeUpdate(sql); sql = "select * from student"; ResultSet rs = stmt.executeQuery(sql);// executeQuery会返回结果的集合,否则返回空值 System.out.println("学号\t姓名"); while (rs.next()) { System.out .println(rs.getString(1) + "\t" + rs.getString(2));// 入如果返回的是int类型可以用getInt() } } } catch (SQLException e) { System.out.println("MySQL操作错误"); e.printStackTrace(); } catch (Exception e) { e.printStackTrace(); } finally { conn.close(); } } }