JDBC 无数据库选择

3

我在我的Java类中有以下代码,但是我无法创建单个表,因为它不会选择数据库

//STEP 1. Import required packages
import java.sql.*;

public class DBTest {
    // Database credentials
    private static final String USER = "root";
    private static final String PASS = "1234";

    private static Connection conn = null;
    private static Statement stmt = null;

    static final String DB_URL = "jdbc:mysql://localhost/";

    public static void main(String[] args) throws SQLException, ClassNotFoundException {
        getConnection();
    }

    public static Connection getConnection() throws SQLException, ClassNotFoundException {

        try {
            System.out.println("Connecting to database...");
            conn = DriverManager.getConnection(DB_URL, USER, PASS);
            createTable(conn);

        } catch (SQLException se) {
            se.printStackTrace();
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            // finally block used to close resources
            try {
                if (stmt != null)
                    stmt.close();
            } catch (SQLException se2) {
            } // nothing we can do
            try {
                if (conn != null)
                    conn.close();
            } catch (SQLException se) {
                se.printStackTrace();
            } // end finally try
        } // end try
        return conn;
    }

    public static void createTable(Connection conn) throws SQLException {
        System.out.println("Creating database...");
        stmt = conn.createStatement();

        // Open a connection
        System.out.println("Connecting to a selected database...");
        conn = DriverManager.getConnection(DB_URL, USER, PASS);
        System.out.println("Connected database successfully...");

        // Execute a query
        System.out.println("Creating table in given database...");

        String sql = "CREATE TABLE REGISTRATION " + "(id INTEGER not NULL, " + " first VARCHAR(255), "
                + " last VARCHAR(255), " + " age INTEGER, " + " PRIMARY KEY ( id ))";

        stmt.executeUpdate(sql);
        System.out.println("Created table in given database...");
    }

}

请注意:我仅导入了java.sql库,并且我已经在引用的库中获得了我的连接器,所以一切都应该设置好了!考虑到所有这些,请问有人能告诉我为什么会出现“未选择数据库”的SQLException吗?

4
静态常量字符串DB_URL的值是"jdbc:mysql://localhost/MyDatabase",它是用于连接本地MySQL数据库中名为"MyDatabase"的数据库的。 - Reimeus
你不需要jdbc的jar包吗? - AbtPst
@Reimeus 谢谢您的评论!我知道我的URL中没有数据库,但是我如何创建一个新的数据库,而不必安装任何第三方软件,以便使用我的程序的任何用户都不需要安装任何东西? - user3153278
@abtPst 我已经设置了所需的库! - user3153278
你的代码很难理解,首先:为什么在createTable中创建一个新的服务器连接(没有数据库)? - Mark Rotteveel
2个回答

6

您的DB_URL变量缺少数据库名称:

您只需要:

jdbc:mysql://localhost/my_db_name

其中my_db_name是您创建的数据库名称。


谢谢你的评论!问题是,我没有数据库,并且我想通过代码创建一个数据库,这样每当有人执行这段代码时,他们所创建的一切都会发生在本地主机上。 - user3153278
2
https://dev59.com/tXRB5IYBdhLWcg3wHkLi - GriffeyDog
VoodooBiiT,我没有在任何地方创建数据库!这是我试图解决的主要问题!我该如何创建一个数据库实例,以便无论谁使用我的代码,都将创建一个新的数据库单元? - user3153278

2

只有连接到数据库时,才能创建表。目前您仅连接到服务器,因此无法执行像CREATE TABLE这样的语句,因为没有任何内容可以用来创建该表。

您需要在连接字符串中指定数据库:

jdbc:mysql://localhost/<database>

或者你需要显式地使用以下方法切换到一个数据库:

connection.setCatalog("<database>");

从评论中看来,您实际上的问题是如何从Java创建一个新的数据库。对于这个问题的答案,您需要查看:从Java创建MySQL数据库


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接