ホームページ >データベース >mysql チュートリアル >【MySQL 05】Javaを使ってMySQLを操作する(データベースの作成)

【MySQL 05】Javaを使ってMySQLを操作する(データベースの作成)

黄舟
黄舟オリジナル
2017-02-04 11:52:151321ブラウズ

データベースへの JDBC 接続:

1. JDBC ドライバーをロードします

2. データベース接続を作成します
4. SQL ステートメントを実行します
6.結果
7. JDBC オブジェクトを閉じる

1. JDBC ドライバーをロードします:

データベースに接続する前に、まず JVM (Java 仮想マシン) を使用してデータベースのドライバーをロードする必要があります。 java.lang.Class クラスの静的メソッド

 //加载数据库驱动总共有三种方式:
 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 クラスに登録されます。

2. JDBC 接続 URL を指定します

接続 URL は、データベースに接続するときのプロトコル、サブプロトコル、およびデータ ソース ID を定義します。
  • MYSQL JDBC URLの記述方法: jdbc:mysql://ホスト名: ポート番号/データベース名? user = ユーザー名 & パスワード = パスワード & useUnicode = true & CharacterEncoding = UTF8
  •  String url = "jdbc:mysql://localhost:3306/samp_db?" + "user=root&password=mysql&useUnicode=true&characterEncoding=UTF8";

    3. データベース接続を作成します
•データベースに接続するには、java.sql.DriverManager から Connection オブジェクトをリクエストして取得する必要があります。 、データベース接続を表します。

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

4. ステートメントを作成します

• SQL ステートメントを実行するには、java.sql を取得する必要があります。 .Statement インスタンス、Statement インスタンスは以下の 3 種類に分かれます:

1. 静的 SQL ステートメントを実行します。通常、Statement インスタンスを通じて実装されます。

2. 動的 SQL ステートメントを実行します。通常は PreparedStatement インスタンスを通じて実装されます。

3. データベースストアドプロシージャを実行します。通常は CallableStatement インスタンスを通じて実装されます。

 Statement stmt = con.createStatement() ;  

    PreparedStatement pstmt = con.prepareStatement(sql) ; 

    CallableStatement cstmt =   con.prepareCall("{CALL demoSp(? , ?)}") ;

5. SQL ステートメントを実行する

Statement インターフェイスには、SQL ステートメントを実行するための 3 つのメソッドが用意されています。 (ResultSet) オブジェクト。

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) ;

6. 処理結果

2 つの状況:

1. 更新を実行すると、この操作の影響を受けるレコードの数が返されます。

2. クエリの実行によって返される結果は ResultSet オブジェクトです。

• ResultSet には SQL ステートメントの条件に一致するすべての行が含まれており、一連の get メソッドを通じてこれらの行のデータへのアクセスを提供します。

• ResultSet オブジェクトのアクセス メソッドを使用してデータを取得します:

  while(rs.next()){   
         String name = rs.getString("name") ;   
         String pass = rs.getString(1) ; // 此方法比较高效   
  }   
    (列是从左到右编号的,并且从列1开始)

7. JDBC オブジェクトを閉じます

操作が完了したら、使用されているすべての JDBC オブジェクトを閉じて、JDBC リソースを解放する必要があります。閉じる順序は逆になります。宣言順序:

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

    }

}

上記は Java を使用して動作する [MySQL 05] の内容ですMySQL (データベースの作成)、その他 関連コンテンツについては、PHP 中国語 Web サイト (www.php.cn) に注目してください。


声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。