簡體   English   中英

類型“...”不存在 - JDBC 錯誤

[英]Type " ..." does not exist - JDBC error

我正在使用jdbc制作一些數據庫表。 在其中一張表上,我收到此錯誤消息: TYPE 'MEET' does not exist. . 任何想法為什么?

代碼如下:

public class MeetingDAO {
public static String getTableString(){
    String meetingTable =   "create table project ( " +
                            "meeting_id integer not null, " +
                            "timestamp meet, " +
                            "project_key varchar(10), " +
                            "primary key(meeting_id))";
    return projectTable;        
  }
}

public class JDBCUtil {
private static  final String dbURL= "jdbc:derby:MyDB;create=true;";
private static final String userID = "moon";
private static final String password = "moonmoon";

public static void init(){
    makeTable(MeetingDAO.getTableString());
}

private static void makeTable(String tableSQL){
    Connection conn = null;
    try {
        conn = JDBCUtil.getConnection();
        Statement stmt = null;
        try {
            stmt = conn.createStatement();
            stmt.executeUpdate(tableSQL);
        }
        finally {
            JDBCUtil.closeStatement(stmt);
        }
        JDBCUtil.commit(conn);
    }
    catch (SQLException e) {
        System.out.println(e.getMessage());
        JDBCUtil.rollback(conn);
    }
    finally {
        JDBCUtil.closeConnection(conn);
    }

}

public static Connection getConnection() throws SQLException{
    Driver derbyEmbededDriver = new EmbeddedDriver();
    DriverManager.registerDriver(derbyEmbededDriver);

    Connection conn = DriverManager.getConnection(dbURL, userID, password);

    conn.setAutoCommit(false);  

    return conn;
}

public static void closeConnection(Connection conn){
    try{
        if(conn != null)
            conn.close();
    }
    catch(SQLException e){
        e.printStackTrace();
    }
}

public static void closeStatement(Statement stmt){
    try {
        if(stmt != null)
            stmt.close();
    } catch (SQLException e) {
        e.printStackTrace();
    }
}

public static void closeResultSet(ResultSet rs){
    try {
        if(rs != null)
            rs.close();
    } catch (SQLException e) {
        e.printStackTrace();
    }
}

public static void commit(Connection conn){
    try {
        if(conn != null)
            conn.commit();
    } catch (SQLException e) {
        e.printStackTrace();
    }
}

public static void rollback (Connection conn){
    try {
        if(conn != null)
            conn.rollback();
    } catch (SQLException e) {
        e.printStackTrace();
    }
}

}

只需交換這兩個詞:

timestamp meet

meet timestamp 

首先是列命名,然后是列數據類型。

您混淆了列meet列名和數據類型。

public class MeetingDAO {
public static String getTableString(){
    String meetingTable =   "create table project ( " +
                            "meeting_id integer not null, " +
                            "meet timestamp, " +
                            "project_key varchar(10), " +
                            "primary key(meeting_id))";
    return projectTable;        
  }
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM