0

我能够连接到 IMS 段并使用 where 子句中的主键执行 sql 查询并选择 * 查询。但是,每当我尝试对另一列进行选择时,都会出现词汇错误。

Select * from table where column-name='something'

这会给我异常“线程“主”com.ibm.ims.jdbc.TokenMgrError 中的异常:第 1 行第 42 列的词法错误。遇到:“-”(45),之后:“”'。如果我将列名作为名字,那么在名字中连字符的位置会出现词汇错误。我已经尝试通过 Prepared Statement 执行此操作,但它仍然无法正常工作。

进行以下更改后,我仍然遇到异常。Select * from table where 'column-name'='something' Caused by: com.ibm.ims.jdbc.ParseException: Encountered ""\'column-name\' "" at line 1, column 36. 期待其中之一: ... "(" ...

Select * from table where column+'-'+name='something' 带有'-'的词法错误异常

无效的转义序列(有效的是 \b \t \n \f \r \" \' \ ),这是我尝试添加反引号或一些转义序列时收到的消息。

4

2 回答 2

5

在大多数 SQL 方言中,该-字符不是(未定界的)标识符中的合法字符。例如,SQL-92 规范说:

     <identifier> ::=
          [ <introducer><character set specification> ] <actual identifier>

     <actual identifier> ::=
            <regular identifier>
          | <delimited identifier>

     <SQL language identifier> ::=
          <SQL language identifier start>
            [ { <underscore> | <SQL language identifier part> }... ]

     <SQL language identifier start> ::= <simple Latin letter>

     <SQL language identifier part> ::=
            <simple Latin letter>
          | <digit>

(TL;DR - 字母、数字和下划线)

(我不敢说所有方言,因为 SQL 语言寓言中充斥着与各种标准的偏差。)


这是否也适用于 %,_,我可以看到一些允许使用 %,_ 转义序列的解决方案。提到的解决方案仍然不适用于连字符。参考:myitforum.com/cs2/blogs/jnelson/archive/2008/08/27/121684.aspx

首先,您找到的参考适用于字符串文字中的转义,而不是标识符名称中的转义。它不适用于这个问题。(它适用于您的 SQL 方言吗?)

其次,根据上面的语法,标识符中应该允许使用下划线......如果您使用的 SQL 方言遵循标准。

第三,标准谈到“分隔标识符”(使用双引号字符作为分隔符)。我不知道这在真正的 SQL 方言中得到了多么广泛的支持,但我想即使是这样,你可以使用的字符也会受到限制......以及其他警告。

第四,不管 SQL 标准怎么说,您所使用的特定方言的记录语法都是您应该查看的。(我只是用它来说明 SQL 的一般属性......在没有你实际使用的方言的任何细节的情况下。“大型机”SQL 可能有很多东西。)

最后,最好不要尝试在标识符中使用“时髦字符”。使用拉丁字母、数字和下划线……如果您的 SQL 方言甚至不允许这样做,那么请坚持使用它所允许的内容。

并阅读供应商 SQL 文档!!!

@Rob我都试过了,但没有奏效。

仔细阅读供应商 SQL 文档。它应该告诉你什么会起作用。如果它说你不能这样做......好吧,你不能。

于 2012-06-06T13:42:38.560 回答
2

我怀疑您所说的连字符被您的数据库解释为减号。

删除 - 或引用它,使其不会被解释为减号。

于 2012-06-06T12:54:03.233 回答