Posted on 2010-08-05 16:16
Prayer 閱讀(1688)
評論(1) 編輯 收藏 引用 所屬分類:
DB2
今天在查warehous數(shù)據(jù)庫下的表Linux_CPU
db2 "select * from Linux_CPU" 總是提示表未定義.后來發(fā)現(xiàn)表名大小寫問題,應該在db2提示符下運行 select * from "Linux_CPU"或者db2 "select * from \"Linux_CPU\""才正確,.晚上在IBM網(wǎng)站上查到詳細說明.
如何定義和使用含小寫字符的 DB2 表名?
Document #:1807545I27000
Body: [標題]如何定義和使用含小寫字符的 DB2 表名?
環(huán)境: 產(chǎn)品:DB2 UDB 平臺:跨平臺 版本:v8
問題描述:
在 DB2 UDB 中除非另外指定,否則,所有名稱都可包括下列字符:
·A 到 Z。當在大多數(shù)名稱中使用時,字符 A 到 Z 將從小寫形式轉(zhuǎn)換為大寫形式。 ·0 到 9 ·@、#、$ 和 _(下劃線) ·名稱不能以數(shù)字或下劃線字符開始。
作為數(shù)據(jù)庫對象的表,其命名同樣遵循上述規(guī)則,因此即使用戶創(chuàng)建表時使用的名稱是小寫的,DB2 仍會自動將其轉(zhuǎn)化為大寫的形式,如:
db2 create table testname (a1 int) DB20000I SQL 命令成功完成。
db2 list tables
表/視圖 模式 類型 創(chuàng)建時間 ------------------------------- --------------- ----- -------------------------- : TESTNAME TESTUSER T 2005-09-24-18.15.30.428001 :
如果用戶希望創(chuàng)建的表名含有小寫字符時應如何處理呢?這里簡單介紹一下其創(chuàng)建和使用的方法。
解答:
如果需要創(chuàng)建含小寫英文字符的 DB2 表名,應使用雙引號將表名括起來,為避免雙引號被轉(zhuǎn)義,需在雙引號前加上轉(zhuǎn)義字符“\”。以創(chuàng)建一個名為 TestName 的表為例,其創(chuàng)建語句應寫為:
db2 "create table \"TestName\" (col1 int)" -- Windows & Unix 環(huán)境下
如果創(chuàng)建的表名中包含有“$”的特殊字符時,在 Unix 環(huán)境下,還需要在這些字符的前面也加一個轉(zhuǎn)義字符,以創(chuàng)建名為 Test$Name 的表為例,創(chuàng)建語句應為:
db2 create table \"Test\$Name\" (col1 int)
而在 Windows 環(huán)境下,可直接寫為:
db2 create table \"Test$Name\" (col1 int)
表創(chuàng)建完成之后,在以后對這些表進行引用的時候,同樣需要象在創(chuàng)建表的語句中那樣對表名加轉(zhuǎn)義符進行引用,如:
Windows 環(huán)境下:
db2 insert into \"Test$Name\" values (1),(2) DB20000I SQL 命令成功完成。
db2 select * from \"Test$Name\"
COL1 ----------- 1 2 2 條記錄已選擇。
Unix 環(huán)境下:
db2 "insert into \"Test\$Name\" values (1),(2)" DB20000I SQL 命令成功完成。
db2 "select * from \"Test\$Name\""
COL1 ----------- 1 2 2 條記錄已選擇。
當然除舉例中所使用的“$”特殊字符外,還有一些其它的特殊字符,在今后使用中,應根據(jù)情況嘗試加上轉(zhuǎn)義符,以創(chuàng)建用戶需要的表名。
|