MySQL データベース JDBC プログラミングの知識ポイントのまとめ

WBOY
リリース: 2022-07-11 13:45:12
転載
2091 人が閲覧しました

この記事では、mysql に関する関連知識を提供します。主に JDBC プログラミングの知識ポイントの関連問題を整理しています。JDBC (Java DataBase Connectivity、Java データベース接続) は、SQL を実行する Java API の一種です。ステートメントは、さまざまなリレーショナル データベースへの統合アクセスを提供します。これは、Java 言語で書かれたクラスとインターフェイスのセットで構成されています。一緒に見てみましょう。皆さんのお役に立てれば幸いです。

MySQL データベース JDBC プログラミングの知識ポイントのまとめ

推奨学習: mysql ビデオ チュートリアル

この記事では、JDBC プログラミング、JDBC (Java Database Connectivity、Java データベース接続) について紹介します。は、さまざまなリレーショナル データベースへの統合アクセスを提供できる SQL ステートメントを実行するための Java API で、Java 言語で記述されたクラスとインターフェイスのセットで構成されます。

MySQL データベース JDBC プログラミングの知識ポイントのまとめ.JDBC の事前作業データベース JDBC プログラミングの知識ポイントのまとめ>MySQL データベース JDBC プログラミングの知識ポイントのまとめ.MySQL データベース JDBC プログラミングの知識ポイントのまとめ MySQL ドライバー パッケージの準備データベース JDBC プログラミングの知識ポイントのまとめ>

MySQL jdbc ドライバー パッケージは、公式 Web サイトからダウンロードすることも、次の Web サイトからダウンロードすることもできます。 maven セントラル ウェアハウス. これは maven セントラル ウェアハウスとは何ですか?携帯電話の「アプリ ストア」ソフトウェアと考えることができます。その機能はアプリ ストアの機能と似ていますが、モバイル アプリ ストアにはモバイル ソフトウェアが含まれ、Maven 中央ウェアハウスには多くの API と依存関係パッケージが含まれている点が異なります。

MySQL が Oracle に買収されたので、Oracle の「食べ物の見た目」が少々ダサいです。公式サイトからも見つかりますが、Maven 中央倉庫のほうが見つけやすいような気がするので、行きます。 Maven 中央ウェアハウスにアクセスして、JDBC ドライバー パッケージをダウンロードします。

Web サイト: Maven セントラル ウェアハウス

最初のステップは、Web サイトをクリックして Maven セントラル ウェアハウスにアクセスすることです。
MySQL データベース JDBC プログラミングの知識ポイントのまとめ

MySQL データベース JDBC プログラミングの知識ポイントのまとめ 番目のステップは、MySQL を検索し、以下に示すものを選択することです。
MySQL データベース JDBC プログラミングの知識ポイントのまとめ
MySQL データベース JDBC プログラミングの知識ポイントのまとめ 番目のステップでは、クリックしてメジャー バージョンに対応する jdbc ドライバー パッケージを見つけます。MySQL がバージョン 5 の場合は、ドライバー パッケージにバージョン 5 を選択します。 MySQL はバージョン MySQL データベース JDBC プログラミングの知識ポイントのまとめ です。ドライバー パッケージにはバージョン MySQL データベース JDBC プログラミングの知識ポイントのまとめ を選択します。

私の MySQL はバージョン 5 なので、最大のバージョン 5 のドライバー パッケージを選択します。
MySQL データベース JDBC プログラミングの知識ポイントのまとめ
MySQL データベース JDBC プログラミングの知識ポイントのまとめ 番目のステップでは、クリックして以下の手順に従ってドライバー パッケージをダウンロードします。
MySQL データベース JDBC プログラミングの知識ポイントのまとめ
ダウンロードが完了すると、ドライバー パッケージの準備が整います。

MySQL データベース JDBC プログラミングの知識ポイントのまとめ.MySQL データベース JDBC プログラミングの知識ポイントのまとめ プロジェクトの作成データベース JDBC プログラミングの知識ポイントのまとめ>

コンパイラを使用してプロジェクトを作成します。プロジェクトの作成後、次の手順に従います。

最初のステップは、次のディレクトリを作成することです。ランダムな名前。 lib ディレクトリと呼ぶこともできます。
MySQL データベース JDBC プログラミングの知識ポイントのまとめ

MySQL データベース JDBC プログラミングの知識ポイントのまとめ 番目のステップは、ダウンロードしたドライバー パッケージをこのディレクトリにコピーすることです。
MySQL データベース JDBC プログラミングの知識ポイントのまとめ

#MySQL データベース JDBC プログラミングの知識ポイントのまとめ 番目のステップは、オプションを設定することです。作成してドライバー パッケージをコピーしたディレクトリを右クリックし、[ライブラリとして...] を見つけます。


# このようにして、ドライバー パッケージがプロジェクトにインポートされ、jdbc コードを作成できるようになります。 MySQL データベース JDBC プログラミングの知識ポイントのまとめ
MySQL データベース JDBC プログラミングの知識ポイントのまとめ.JDBC プログラミングの手順MySQL データベース JDBC プログラミングの知識ポイントのまとめ
MySQL データベース JDBC プログラミングの知識ポイントのまとめ.MySQL データベース JDBC プログラミングの知識ポイントのまとめ データ ソース DataSource を作成する

最初の手順は、データベースの場所を記述する データベース JDBC プログラミングの知識ポイントのまとめ>DataSource オブジェクトを作成することです。 。 データベース JDBC プログラミングの知識ポイントのまとめ>
DataSource dataSource = new MysqlDataSource();
ログイン後にコピー

DataSource

java.sql

の jdbc インターフェイス、MysqlDataSource はソースであり、ダウンロードしたドライバー パッケージの実装です DataSourceインターフェイス クラス。 MySQL データベース JDBC プログラミングの知識ポイントのまとめ 番目のステップは、データベースの「場所」(URL)、データベースにログインするためのアカウント名とパスワードを設定することです。 <div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">        //设置数据库所在地址         ((MysqlDataSource)dataSource).setURL(&quot;jdbc:mysql://MySQL データベース JDBC プログラミングの知識ポイントのまとめMySQL データベース JDBC プログラミングの知識ポイントのまとめMySQL データベース JDBC プログラミングの知識ポイントのまとめ.0.0.MySQL データベース JDBC プログラミングの知識ポイントのまとめ:MySQL データベース JDBC プログラミングの知識ポイントのまとめMySQL データベース JDBC プログラミングの知識ポイントのまとめ06/jdbctest/characterEncoding=utfMySQL データベース JDBC プログラミングの知識ポイントのまとめ&amp;useSSL=false&quot;);         //设置登录数据库的账户名         ((MysqlDataSource)dataSource).setUser(&quot;root&quot;);         //设置登录数据库的密码         ((MysqlDataSource)dataSource).setPassword(&quot;MySQL データベース JDBC プログラミングの知識ポイントのまとめMySQL データベース JDBC プログラミングの知識ポイントのまとめMySQL データベース JDBC プログラミングの知識ポイントのまとめMySQL データベース JDBC プログラミングの知識ポイントのまとめ56&quot;);</pre><div class="contentsignin">ログイン後にコピー</div></div>

jdbc:mysql://MySQL データベース JDBC プログラミングの知識ポイントのまとめMySQL データベース JDBC プログラミングの知識ポイントのまとめMySQL データベース JDBC プログラミングの知識ポイントのまとめ.0.0.MySQL データベース JDBC プログラミングの知識ポイントのまとめ:MySQL データベース JDBC プログラミングの知識ポイントのまとめMySQL データベース JDBC プログラミングの知識ポイントのまとめ06/jdbctest?characterEncoding=utfMySQL データベース JDBC プログラミングの知識ポイントのまとめ&useSSL=false

は URL であり、一意のリソース ロケーターとも呼ばれます。

jdbc:mysql は、url
が jdbc mysql の URL であることを意味します。jdbc に限らず多くのデータベースがあるため、細分化する必要があります。 特定の意味に依存しない比較: URL タイプ ステートメント://データベース アドレス/データベース名?文字セット エンコーディング&暗号化するかどうか

MySQL データベース JDBC プログラミングの知識ポイントのまとめ.MySQL データベース JDBC プログラミングの知識ポイントのまとめ データベースへの接続MySQL データベース JDBC プログラミングの知識ポイントのまとめ 番目のステップは、サーバーとの接続を確立することです。データ ソース

DataSource オブジェクトを作成した後、データベース JDBC プログラミングの知識ポイントのまとめ>getConnection( )## オブジェクトの #メソッドで、

java.sql.Connection オブジェクトを取得し、データベースとの接続を確立します。

Connection connection = dataSource.getConnection();
ログイン後にコピー
MySQL データベース JDBC プログラミングの知識ポイントのまとめ.MySQL データベース JDBC プログラミングの知識ポイントのまとめ构造并执行sql语句(插入操作为例)データベース JDBC プログラミングの知識ポイントのまとめ>

第四步,构造sql语句字符串,并将该语句包装成PreparedStatement对象,即调用Connection对象的prepareStatement方法,参数是sql字符串,会返回一个PreparedStatement对象,然后我们再调用PreparedStatement对象中的executeUpdate方法或executeQuery方法执行sql语句。

我们先以插入操作为例。

        //操作数据库 关键在于构造sql语句
        //jdbc 构造的sql语句不需要带上;
        String sql = "insert into student values(MySQL データベース JDBC プログラミングの知識ポイントのまとめ, MySQL データベース JDBC プログラミングの知識ポイントのまとめ9;张三MySQL データベース JDBC プログラミングの知識ポイントのまとめ9;)";
        //将sql字符串包装成一个语句对象,表示待执行的sql的对象
        PreparedStatement statement = connection.prepareStatement(sql);

        //执行sql
        //如果待执行的sql语句操作是insert, update, delete,则使用executeUpdate方法执行,返回值为影响数据的行数
        //如果待执行的sql语句操作是select,则使用executeQuery方法执行
        int ret = statement.executeUpdate();
ログイン後にコピー

其中,如果待执行的sql语句操作是insert, update, delete,则使用executeUpdate方法执行,返回值为影响数据的行数,如果待执行的sql语句操作是select,则使用executeQuery方法执行,返回值是一个ResultSet结果表对象。

MySQL データベース JDBC プログラミングの知識ポイントのまとめ.MySQL データベース JDBC プログラミングの知識ポイントのまとめ及时释放资源データベース JDBC プログラミングの知識ポイントのまとめ>

第五步,释放资源,我们执行完毕sql语句后需要及时地将资源释放,在JDBC编程中,最常见需要释放的类或接口有三个,分别是ConnectionPreparedStatementResultSet,其中前面两个在jdbc插入操作中已经使用过了,而最后一个,即ResultSet,它是在执行查询语句需要用到的,调用executeQuery方法执行查询语句之后,会返回一个“临时表”,该“临时表”上储存了查询的结果,我们可以通过遍历该结果表来获取查询数据库的结果。

//此时sql语句已经执行完毕了,需要释放资源statement.close();connection.close();
ログイン後にコピー

使用jdbc编程进行插入操作全部代码:

import com.mysql.jdbc.jdbcMySQL データベース JDBC プログラミングの知識ポイントのまとめ.optional.MysqlDataSource;import javax.sql.DataSource;import java.sql.Connection;import java.sql.PreparedStatement;import java.sql.SQLException;import java.util.Scanner;public class TestJdbc {

    public static void main(String[] args) throws SQLException {
        DataSource dataSource = new MysqlDataSource();
        //设置数据库所在地址
        ((MysqlDataSource)dataSource).setURL("jdbc:mysql://MySQL データベース JDBC プログラミングの知識ポイントのまとめMySQL データベース JDBC プログラミングの知識ポイントのまとめMySQL データベース JDBC プログラミングの知識ポイントのまとめ.0.0.MySQL データベース JDBC プログラミングの知識ポイントのまとめ:MySQL データベース JDBC プログラミングの知識ポイントのまとめMySQL データベース JDBC プログラミングの知識ポイントのまとめ06/jdbctest?characterEncoding=utfMySQL データベース JDBC プログラミングの知識ポイントのまとめ&useSSL=false");
        //设置登录数据库的账户名
        ((MysqlDataSource)dataSource).setUser("root");
        //设置登录数据库的密码
        ((MysqlDataSource)dataSource).setPassword("MySQL データベース JDBC プログラミングの知識ポイントのまとめMySQL データベース JDBC プログラミングの知識ポイントのまとめMySQL データベース JDBC プログラミングの知識ポイントのまとめMySQL データベース JDBC プログラミングの知識ポイントのまとめ56");

        //建立连接
        Connection connection = dataSource.getConnection();

        //操作数据库 关键在于构造sql语句
        //jdbc 构造的sql语句不需要带上;
        String sql = "insert into student values(MySQL データベース JDBC プログラミングの知識ポイントのまとめ, MySQL データベース JDBC プログラミングの知識ポイントのまとめ9;张三MySQL データベース JDBC プログラミングの知識ポイントのまとめ9;)";
        //将sql字符串包装成一个语句对象,表示待执行的sql的对象
        PreparedStatement statement = connection.prepareStatement(sql);

        //执行sql
        //如果待执行的sql语句操作是insert, update, delete,则使用executeUpdate方法执行,返回值为影响数据的行数
        //如果待执行的sql语句操作是select,则使用executeQuery方法执行
        int ret = statement.executeUpdate();

        //此时sql语句已经执行完毕了,需要释放资源
        statement.close();
        connection.close();
    }}
ログイン後にコピー

运行结果,我们通过查询数据库的表的结果来进行观察:

mysql> create database jdbctest;Query OK, MySQL データベース JDBC プログラミングの知識ポイントのまとめ row affected (0.0MySQL データベース JDBC プログラミングの知識ポイントのまとめ sec)mysql> use jdbctest;Database changed
mysql> create table student(id int, name varchar(MySQL データベース JDBC プログラミングの知識ポイントのまとめ0));Query OK, 0 rows affected (0.0MySQL データベース JDBC プログラミングの知識ポイントのまとめ sec)mysql> show tables;+--------------------+| Tables_in_jdbctest |+--------------------+| student            |+--------------------+MySQL データベース JDBC プログラミングの知識ポイントのまとめ row in set (0.00 sec)-- 执行jdbc代码后查询mysql> select * from student;+------+--------+| id   | name   |+------+--------+|    MySQL データベース JDBC プログラミングの知識ポイントのまとめ | 张三   |+------+--------+MySQL データベース JDBC プログラミングの知識ポイントのまとめ row in set (0.00 sec)
ログイン後にコピー

程序运行结果,表示MySQL データベース JDBC プログラミングの知識ポイントのまとめ行受到了影响。
MySQL データベース JDBC プログラミングの知識ポイントのまとめ

MySQL データベース JDBC プログラミングの知識ポイントのまとめ.5不要写死的代码(以插入为例)データベース JDBC プログラミングの知識ポイントのまとめ>

我们发现我们的sql语句是完完全全写死的,这一点不好,我们可以使用输入的操作让用户输入信息进行插入,那就需要使用到Scanner类了。

我们得到用户输入的信息后,我们需要对信息进行整合,最容易想到的方式就是字符串拼接,但是这么做有如下的缺点,一是容易写错,特别是单双引号比较多的情况下,二是不安全,黑客可以使用sql注入的方式来修改数据库。

所以更好的方法就是把sql字符串中待输入的信息使用?来代替或者叫做占位,然后通过PreparedStatement中的setXXX系列方法来逐个设置每个?的内容是什么。

这个系列的方法,第一个参数表示sql待执行对象中第多少个?,第二个参数表示将这个?设置的内容。比如:

        //操作数据库 关键在于构造sql语句
        //jdbc 构造的sql语句不需要带上;
        String sql = "insert into student values(?, ?)";
        //将sql字符串包装成一个语句对象,表示待执行的sql的对象
        PreparedStatement statement = connection.prepareStatement(sql);
        statement.setInt(MySQL データベース JDBC プログラミングの知識ポイントのまとめ, id);
        statement.setString(MySQL データベース JDBC プログラミングの知識ポイントのまとめ, name);
ログイン後にコピー

完整代码:jdbc插入操作源代码

运行结果:
MySQL データベース JDBC プログラミングの知識ポイントのまとめ
数据库查询结果:

mysql> select * from student;+------+--------+| id   | name   |+------+--------+|    MySQL データベース JDBC プログラミングの知識ポイントのまとめ | 张三   ||    MySQL データベース JDBC プログラミングの知識ポイントのまとめ | 李四   |+------+--------+MySQL データベース JDBC プログラミングの知識ポイントのまとめ rows in set (0.00 sec)
ログイン後にコピー
MySQL データベース JDBC プログラミングの知識ポイントのまとめ.6JDBC删除,更新操作データベース JDBC プログラミングの知識ポイントのまとめ>

在jdbc编程中,删除操作和更新操作,它的步骤与插入操作是一模一样的,只不过就是构造的sql语句不一样,其他都一样。

删除操作关键代码:

        //用户输入
        System.out.println("请输入需要删除的学号:");
        int id = sc.nextInt();

        //操作数据库 关键在于构造sql语句
        //jdbc 构造的sql语句不需要带上;
        String sql = "delete from student where id = ?";
        PreparedStatement statement = connection.prepareStatement(sql);
        statement.setInt(MySQL データベース JDBC プログラミングの知識ポイントのまとめ, id);
        System.out.println("statement" + statement);
ログイン後にコピー

jdbc删除操作完整代码:源代码地址

程序运行结果:
MySQL データベース JDBC プログラミングの知識ポイントのまとめ

数据库查询结果:

mysql> select * from student;+------+--------+| id   | name   |+------+--------+|    MySQL データベース JDBC プログラミングの知識ポイントのまとめ | 张三   |+------+--------+MySQL データベース JDBC プログラミングの知識ポイントのまとめ row in set (0.00 sec)
ログイン後にコピー

更新操作关键代码:

        //用户输入 需要修改的id 与修改后的姓名
        System.out.println("请输入需要修改的学号:");
        int id = sc.nextInt();
        sc.nextLine();
        System.out.println("请输入修改后的姓名:");
        String afterName = sc.nextLine();

        //操作数据库 关键在于构造sql语句
        //jdbc 构造的sql语句不需要带上;
        String sql = "update student set name = ? where id = ?";
        PreparedStatement statement = connection.prepareStatement(sql);
        statement.setString(MySQL データベース JDBC プログラミングの知識ポイントのまとめ, afterName);
        statement.setInt(MySQL データベース JDBC プログラミングの知識ポイントのまとめ, id);
        System.out.println("statement" + statement);
ログイン後にコピー

jdbc更新操作完整代码:源代码地址

程序运行结果:

MySQL データベース JDBC プログラミングの知識ポイントのまとめ

数据库查询结果:

mysql> select * from student;+------+--------+| id   | name   |+------+--------+|    MySQL データベース JDBC プログラミングの知識ポイントのまとめ | 王五   |+------+--------+MySQL データベース JDBC プログラミングの知識ポイントのまとめ row in set (0.00 sec)
ログイン後にコピー
MySQL データベース JDBC プログラミングの知識ポイントのまとめ.MySQL データベース JDBC プログラミングの知識ポイントのまとめJDBC查询操作データベース JDBC プログラミングの知識ポイントのまとめ>

jdbc的查询操作与插入删除更新操作有一点点不同,执行查询sql语句的时候是调用executeQuery方法来执行语句的,并且会带回查询的结果,我们可以通过类似与迭代器的操作来获取查询的结果,这个结果集使用完后需要将它释放。

关键代码:

        //操作数据库 关键在于构造sql语句
        //jdbc 构造的sql语句不需要带上;
        String sql = "select * from student";
        PreparedStatement statement = connection.prepareStatement(sql);

        //执行sql 查询操作返回的不是int 而是一个临时表 使用ResultSet对象表示这个临时表
        ResultSet ret = statement.executeQuery();

        //便利结果集合
        //预期结果格式//        +------+--------+//        | id   | name   |//        +------+--------+//        |    MySQL データベース JDBC プログラミングの知識ポイントのまとめ | 王五   |//        +------+--------+
        while (ret.next()) {
            int id = ret.getInt("id");
            String name = ret.getString("name");
            System.out.println("id:" + id + ", name:" + name);
        }
        //关闭资源
        ret.close();
        statement.close();
        connection.close();
ログイン後にコピー

jdbc查询操作完代码:源代码地址

程序运行结果:
MySQL データベース JDBC プログラミングの知識ポイントのまとめ0
好了,JDBC的全部内容差不多就是这一些,所有的完整代码链接:地址。

推荐学习:mysql视频教程

以上がMySQL データベース JDBC プログラミングの知識ポイントのまとめの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:csdn.net
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート