簡體   English   中英

SQL異常:意外令牌-UCanAccess

[英]SQL Exception : Unexpected Token - UCanAccess

我正在嘗試從Java程序創建新的MS Access表。 SQL查詢如下。 我收到一條錯誤消息:

net.UcanacessSQLException:UCAExc ::: 4.0.1意外令牌:REQ-MTI

PreparedStatement prepStmt;

String createStmt = "CREATE TABLE [" + tableName + "] ([Test_Case_ID] CHAR (20) PRIMARY KEY, [Test_Name] CHAR (120)," 
    + " [Test_Description] CHAR (100), [Req-MTI] CHAR (15), [Req-Card_ID] CHAR (50), [Req-H19] CHAR (20));";

prepStmt = conn.prepareStatement(createStmt);
prepStmt.executeUpdate();

我不能使用下划線代替連字符。 我嘗試將所有表名放在方括號,引號等中,但似乎沒有任何作用。 我已經采用了生成的字符串並將其粘貼到MS Access查詢中,並在此處很好地創建了表。

任何幫助,將不勝感激。 謝謝!

如果列名包含字母,數字和下划線以外的任何字符,則必須通過將其括在反引號(`)中來分隔該名稱。

因此,請嘗試將列名稱更改為:

`Req-MTI`

我能夠在UCanAccess 4.0.2下重現您的問題。 CHAR關鍵字后的空格似乎使它感到困惑。 如果我將字段指定為CHAR(20)而不是CHAR (20) ,則可以運行代碼。

編輯回復:問題更新

我能夠在UCanAccess 4.0.1下重現該問題。 解決方法是使用Statement而不是PreparedStatement來執行DDL。 (至少在4.0.1以下,甚至沒有必要如上所述刪除空格。)

暫無
暫無

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

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