2.1.3 JDBC执行SQL语句

优质
小牛编辑
141浏览
2023-12-01

下面给出一个例子来演示一下如何使用JDBC来执行各种SQL语句,其中包括DDL语句(建立数据库和数据表)、INSERT语句和SELECT语句。

1.程序分析说明

本程序首先创建一个mydb数据库(如果存在就不创建),然后创建一个用于保存图书信息的表t_books(如果存在,删除后再创建),最后向表中插入两条记录,并查询和显示其中的第2条记录。

2.代码编写

本程序使用了Statement接口的execute方法来执行DDL和INSERT语句,使用executeQuery方法来执行SELECT语句,程序的实现代码如下:

package chapter2;

import java.sql.*;

public class ExecuteDemo
{
    public static void main(String[] args) throws Exception
    {
        // 装载JDBC驱动
        Class.forName("com.mysql.jdbc.Driver");
        // 获得Connection对象
        Connection conn = DriverManager
                .getConnection("jdbc:mysql://localhost/?characterEncoding=UTF8",
                       "root", "1234");
        // 获得Statement对象
        Statement stmt = conn.createStatement();
        String createDB = "CREATE DATABASE IF NOT EXISTS mydb DEFAULT CHARACTER SET UTF8";
        String dropTable = "DROP TABLE IF EXISTS mydb.t_books";
        String createTable = "CREATE TABLE  mydb.t_books (id int unsigned NOT NULL"
                + " auto_increment, name varchar(50) NOT NULL,isbn varchar(20)"
                + "NOT NULL, author varchar(20) NOT NULL,price int unsigned,"
                + " PRIMARY KEY  (id)) ENGINE=InnoDB DEFAULT CHARSET=UTF8";
        String insertData1 = "INSERT INTO mydb.t_books(name,isbn,author,price) values("
                + "'人月神话', '6787102165345', '布鲁克斯', 52)";
        String insertData2 = "INSERT INTO mydb.t_books(name,isbn,author,price) values("
                + "'Ajax基础教程', '5643489212407', '阿斯利森', 73)";
        String selectData = "SELECT * FROM mydb.t_books where id=2";
        // 建立数据库、表,并插入数据
        stmt.execute(createDB);
        stmt.execute(dropTable);
        stmt.execute(createTable);
        stmt.execute(insertData1);
        stmt.execute(insertData2);
        // 从数据库中查询数据
        ResultSet result = stmt.executeQuery(selectData);
        // 显示查询结果
        while (result.next())
        {
            System.out.print(result.getString("id") + "   ");
            System.out.print(result.getString("name") + "   ");
            System.out.print(result.getString("isbn") + "   ");
            System.out.print(result.getString("author") + "   ");
            System.out.println(result.getInt("price"));
        }
        // 关闭Statement和Connection对象
        stmt.close();
        conn.close();
    }
}

在上面的代码中由于数据库mydb可能不存在,所以在连接字符串中并没有指定数据库名。因此,在使用mydb中的表时必须指定数据库名,如代码中的mydb.t_books。

3.程序总结

通过上面的示例,读者可以对JDBC操作数据库的基本流程和基本方法有了一个初步的了解。在本章接下来的部分,将详细讲解JDBC API的核心功能的使用方法。