Rumah >pangkalan data >tutorial mysql >Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL

Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL

WBOY
WBOYke hadapan
2022-07-11 13:45:122148semak imbas

Artikel ini membawakan anda pengetahuan yang berkaitan tentang mysql, yang terutamanya mengatur isu berkaitan titik pengetahuan pengaturcaraan JDBC (Java DataBase Connectivity, sambungan pangkalan data java) ialah sejenis API Java yang melaksanakan pernyataan SQL. boleh menyediakan akses bersatu kepada pelbagai pangkalan data relasi Ia terdiri daripada satu set kelas dan antara muka yang ditulis dalam bahasa Java Mari kita lihat bersama-sama.

Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL

Pembelajaran yang disyorkan: tutorial video mysql

Artikel ini akan memperkenalkan pengaturcaraan JDBC, JDBC (Java DataBase Connectivity, sambungan pangkalan data java ) ialah API Java untuk melaksanakan pernyataan SQL yang boleh menyediakan akses bersatu kepada pelbagai pangkalan data hubungan Ia terdiri daripada satu set kelas dan antara muka yang ditulis dalam bahasa Java.

Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL.JDBC pra-kerjamata pengetahuan pengaturcaraan JDBC pangkalan data MySQL>Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL.Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL Sediakan pakej pemacu MySQLmata pengetahuan pengaturcaraan JDBC pangkalan data MySQL>

Kami boleh memuat turun pakej pemacu jdbc MySQL dari tapak web rasmi, atau kami boleh memuat turunnya dari gudang pusat maven, ini Apakah gudang pusat maven? Anda boleh menganggapnya sebagai perisian "kedai aplikasi" dalam telefon mudah alih kami Fungsinya serupa dengan kedai aplikasi, kecuali kedai aplikasi mudah alih mengandungi perisian mudah alih, manakala gudang pusat maven mengandungi banyak API dan pakej pergantungan.

Sekarang MySQL telah diperoleh oleh Oracle, "rupa" Oracle adalah agak hodoh anda boleh menemuinya dari laman web rasmi, tetapi saya merasakan bahawa gudang pusat maven lebih mudah dicari, jadi kita pergi ke. gudang pusat maven untuk memuat turun pakej pemandu jdbc.

Laman web: maven central warehouse

Langkah pertama ialah klik pada laman web untuk masuk ke maven central warehouse.
Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL

Langkah kedua ialah mencari MySQL dan pilih yang ditunjukkan di bawah.
Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL
Langkah ketiga, klik untuk masuk dan cari pakej pemacu jdbc yang sepadan dengan versi utama Jika MySQL anda adalah versi 5, kemudian pilih versi 5 untuk pakej pemacu ialah versi Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL, Kemudian pilih versi Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL untuk pakej pemandu anda.

MySQL saya ialah versi 5, jadi saya memilih pakej pemacu dengan versi 5 terbesar.
Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL
Langkah keempat ialah klik masuk dan ikuti imej di bawah untuk memuat turun pakej pemandu.
Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL
Setelah muat turun selesai pakej pemandu kami sedia.

Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL.Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL Cipta projek mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL>

Gunakan pengkompil untuk mencipta projek Selepas projek dibuat, ikut langkah di bawah:

Langkah pertama ialah mencipta direktori dengan. nama rawak , juga boleh dipanggil direktori lib.
Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL

Langkah kedua ialah menyalin pakej pemacu yang dimuat turun ke direktori ini.
Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL

Langkah ketiga, tetapkan pilihan, klik kanan direktori yang baru anda buat dan salin pakej pemandu, cari As a Lib...
Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL
Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL
Dengan cara ini, pakej pemandu kami akan diimport ke dalam projek kami, dan kemudian kami boleh menulis kod jdbc.

Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL. Langkah pengaturcaraan JDBC mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL>Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL.Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL Cipta sumber data DataSource mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL>

Langkah pertama ialah mencipta objek DataSource untuk menerangkan tempat pangkalan data.

DataSource dataSource = new MysqlDataSource();

di mana DataSource ialah antara muka jdbc dalam java.sql dan MysqlDataSource ialah kelas yang melaksanakan antara muka DataSource daripada pakej pemacu yang kami muat turun.

Langkah kedua ialah menetapkan "lokasi" (URL) pangkalan data, nama akaun dan kata laluan untuk log masuk ke pangkalan data.

        //设置数据库所在地址
        ((MysqlDataSource)dataSource).setURL("jdbc:mysql://Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQLRingkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQLRingkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL.0.0.Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL:Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQLRingkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL06/jdbctest/characterEncoding=utfRingkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL&useSSL=false");
        //设置登录数据库的账户名
        ((MysqlDataSource)dataSource).setUser("root");
        //设置登录数据库的密码
        ((MysqlDataSource)dataSource).setPassword("Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQLRingkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQLRingkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQLRingkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL56");

jdbc:mysql://Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQLRingkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQLRingkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL.0.0.Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL:Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQLRingkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL06/jdbctest?characterEncoding=utfRingkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL&useSSL=false ialah URL, juga dipanggil pengesan sumber unik.
jdbc:mysql bermaksud url adalah URL untuk jdbc mysql Kerana terdapat banyak pangkalan data, bukan sahaja jdbc, ia perlu dipecahkan.

Hubungi maksud khusus secara bebas: URL类型声明://数据库的地址/数据库名?字符集编码&是否加密.

Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL.Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL Menyambung ke pangkalan data mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL>

Langkah ketiga ialah mewujudkan sambungan dengan pelayan Selepas mencipta objek sumber data DataSource, panggil kaedah getConnection() objek untuk mendapatkan objek java.sql.Connection, seperti ini Sambungan diwujudkan dengan pangkalan data.

Connection connection = dataSource.getConnection();
Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL.Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL构造并执行sql语句(插入操作为例)mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL>

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

我们先以插入操作为例。

        //操作数据库 关键在于构造sql语句
        //jdbc 构造的sql语句不需要带上;
        String sql = "insert into student values(Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL, Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL9;张三Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL9;)";
        //将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结果表对象。

Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL.Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL及时释放资源mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL>

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

//此时sql语句已经执行完毕了,需要释放资源statement.close();connection.close();

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

import com.mysql.jdbc.jdbcRingkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL.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://Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQLRingkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQLRingkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL.0.0.Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL:Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQLRingkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL06/jdbctest?characterEncoding=utfRingkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL&useSSL=false");
        //设置登录数据库的账户名
        ((MysqlDataSource)dataSource).setUser("root");
        //设置登录数据库的密码
        ((MysqlDataSource)dataSource).setPassword("Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQLRingkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQLRingkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQLRingkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL56");

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

        //操作数据库 关键在于构造sql语句
        //jdbc 构造的sql语句不需要带上;
        String sql = "insert into student values(Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL, Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL9;张三Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL9;)";
        //将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, Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL row affected (0.0Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL sec)mysql> use jdbctest;Database changed
mysql> create table student(id int, name varchar(Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL0));Query OK, 0 rows affected (0.0Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL sec)mysql> show tables;+--------------------+| Tables_in_jdbctest |+--------------------+| student            |+--------------------+Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL row in set (0.00 sec)-- 执行jdbc代码后查询mysql> select * from student;+------+--------+| id   | name   |+------+--------+|    Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL | 张三   |+------+--------+Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL row in set (0.00 sec)

程序运行结果,表示Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL行受到了影响。
Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL

Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL.5不要写死的代码(以插入为例)mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL>

我们发现我们的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(Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL, id);
        statement.setString(Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL, name);

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

运行结果:
Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL
数据库查询结果:

mysql> select * from student;+------+--------+| id   | name   |+------+--------+|    Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL | 张三   ||    Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL | 李四   |+------+--------+Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL rows in set (0.00 sec)
Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL.6JDBC删除,更新操作mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL>

在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(Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL, id);
        System.out.println("statement" + statement);

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

程序运行结果:
Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL

数据库查询结果:

mysql> select * from student;+------+--------+| id   | name   |+------+--------+|    Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL | 张三   |+------+--------+Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL 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(Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL, afterName);
        statement.setInt(Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL, id);
        System.out.println("statement" + statement);

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

程序运行结果:

Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL

数据库查询结果:

mysql> select * from student;+------+--------+| id   | name   |+------+--------+|    Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL | 王五   |+------+--------+Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL row in set (0.00 sec)
Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL.Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQLJDBC查询操作mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL>

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   |//        +------+--------+//        |    Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL | 王五   |//        +------+--------+
        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查询操作完代码:源代码地址

程序运行结果:
Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL0
好了,JDBC的全部内容差不多就是这一些,所有的完整代码链接:地址。

推荐学习:mysql视频教程

Atas ialah kandungan terperinci Ringkasan mata pengetahuan pengaturcaraan JDBC pangkalan data MySQL. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Artikel ini dikembalikan pada:csdn.net. Jika ada pelanggaran, sila hubungi admin@php.cn Padam