• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            Prayer

            在一般中尋求卓越
            posts - 1256, comments - 190, trackbacks - 0, articles - 0
              C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

            db2表名大小寫問題

            Posted on 2010-08-05 16:16 Prayer 閱讀(1691) 評論(1)  編輯 收藏 引用 所屬分類: DB2

            今天在查warehous數(shù)據(jù)庫下的表Linux_CPU

            db2 "select * from Linux_CPU" 總是提示表未定義.后來發(fā)現(xiàn)表名大小寫問題,應(yīng)該在db2提示符下運(yùn)行 select * from "Linux_CPU"或者db2 "select * from \"Linux_CPU\""才正確,.晚上在IBM網(wǎng)站上查到詳細(xì)說明.

            如何定義和使用含小寫字符的 DB2 表名?

            Document #:1807545I27000

            Body:
            [標(biāo)題]如何定義和使用含小寫字符的 DB2 表名?


            環(huán)境:

            產(chǎn)品:DB2 UDB
            平臺:跨平臺
            版本:v8


            問題描述:

            在 DB2 UDB 中除非另外指定,否則,所有名稱都可包括下列字符:

            ·A 到 Z。當(dāng)在大多數(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)建的表名含有小寫字符時應(yīng)如何處理呢?這里簡單介紹一下其創(chuàng)建和使用的方法。


            解答:


            如果需要創(chuàng)建含小寫英文字符的 DB2 表名,應(yīng)使用雙引號將表名括起來,為避免雙引號被轉(zhuǎn)義,需在雙引號前加上轉(zhuǎn)義字符\。以創(chuàng)建一個名為 TestName 的表為例,其創(chuàng)建語句應(yīng)寫為:

            db2 "create table \"TestName\" (col1 int)" -- Windows & Unix 環(huán)境下

            如果創(chuàng)建的表名中包含有$的特殊字符時,在 Unix 環(huán)境下,還需要在這些字符的前面也加一個轉(zhuǎn)義字符,以創(chuàng)建名為 Test$Name 的表為例,創(chuàng)建語句應(yīng)為:

            db2 create table \"Test\$Name\" (col1 int)

            而在 Windows 環(huán)境下,可直接寫為:

            db2 create table \"Test$Name\" (col1 int)

            表創(chuàng)建完成之后,在以后對這些表進(jìn)行引用的時候,同樣需要象在創(chuàng)建表的語句中那樣對表名加轉(zhuǎn)義符進(jì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 條記錄已選擇。

            當(dāng)然除舉例中所使用的“$”特殊字符外,還有一些其它的特殊字符,在今后使用中,應(yīng)根據(jù)情況嘗試加上轉(zhuǎn)義符,以創(chuàng)建用戶需要的表名。

            Feedback

            # re: db2表名大小寫問題  回復(fù)  更多評論   

            2010-11-10 14:47 by hwankin
            挺好,工作中有用。
            色综合合久久天天综合绕视看| 久久国产精品免费一区二区三区| 亚洲国产精品久久久久婷婷软件| 99久久精品国产一区二区三区| 思思久久99热只有频精品66| 久久久无码精品亚洲日韩按摩 | 思思久久99热免费精品6| 国产激情久久久久久熟女老人| 国产精品九九九久久九九 | 久久久久国产精品嫩草影院| 国产国产成人精品久久| 亚洲七七久久精品中文国产 | 久久亚洲国产最新网站| 精品国产乱码久久久久久郑州公司 | 日本加勒比久久精品| 久久香综合精品久久伊人| 久久国产热这里只有精品| 精品国产一区二区三区久久久狼| 精品久久亚洲中文无码| 欧美日韩精品久久久久| 国产伊人久久| 精品久久国产一区二区三区香蕉| 欧美一区二区三区久久综合| 亚洲午夜无码久久久久小说| 久久久精品人妻无码专区不卡 | 国内精品伊人久久久久AV影院| 亚洲欧美成人久久综合中文网| 久久久久亚洲av成人无码电影 | 久久笫一福利免费导航 | 亚洲欧美成人久久综合中文网| 精品久久久久一区二区三区| 国产精品美女久久久免费| 久久久久久久99精品免费观看| 国产精品久久一区二区三区 | 国产精品久久久久aaaa| 狠狠色婷婷综合天天久久丁香 | 色综合久久久久综合体桃花网| 日韩AV无码久久一区二区| 日日狠狠久久偷偷色综合免费 | 伊人久久精品无码二区麻豆| 久久精品国产清自在天天线|