1

我有这个:

public static void createTemporaryTable() {
        Statement s = null;
        sentence = "CREATE TEMPORARY TABLE Book (ISBN int NOT NULL, " +
                "title varchar(45), author varchar(45), price double, PRIMARY KEY  (`ISBN`));";

        try {
            s = Conexion.getInstancia().createStatement();
            s.executeUpdate(sentence);
        } catch (SQLException e) {
            e.printStackTrace();
        } finally {
            try {
                s.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
    }

然后:

public class System {

    public static void main(String[] args) {
        SqlSentencesList.createTemporaryTable();
    }

}

但是当我执行时select * from Book,MySQL 告诉我Book表不存在。我没有从 java 收到任何错误消息,所以应该创建表,但事实并非如此。

如果我直接在 mysql 中执行相同的 sql 语句来创建临时表,它就可以正常工作。

这是我的Conexion课:

public class Conexion {

    private static Connection conexion = null;



    private Conexion() {

    }

    public static Connection getInstancia() {
        if (conexion == null) {
            try {
                Class.forName("com.mysql.jdbc.Driver");
                conexion = DriverManager.getConnection(
                        "jdbc:mysql://localhost/Esquema_VentaLibros","gustavo", "123581321");

            } catch (SQLException sqlex) {
                sqlex.printStackTrace();
            } catch(ClassNotFoundException cnfex) {
                cnfex.printStackTrace();
            }
            return conexion;
        }
        else {
            return conexion;
        }
    }

}
4

2 回答 2

1

关闭连接时会自动删除临时表。

有关详细信息,请参阅MySQL CREATE TABLE文档:

创建表时可以使用 TEMPORARY 关键字。TEMPORARY 表仅对当前连接可见,并在连接关闭时自动删除。这意味着两个不同的连接可以使用相同的临时表名,而不会相互冲突或与现有的同名非临时表冲突。(在删除临时表之前,隐藏现有表。)

如果你想创建一个临时表来做一些工作,你应该在开始工作时创建它,并针对它执行你的 UPDATE/SELECT 语句。当您关闭连接时,它会自动删除,并且不会与使用相同临时表名的其他连接发生冲突。

于 2012-04-13T15:23:54.853 回答
1

临时表是每个数据库连接的。因此,如果您尝试从另一个连接访问临时表,您将看不到它。

于 2012-04-13T15:24:21.590 回答