欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Oracle別名使用要點(diǎn)小結(jié)

 更新時(shí)間:2022年04月19日 16:23:03   作者:godtrue  
在Oracle中別名也可以在列名和表名中進(jìn)行,進(jìn)行別名處理是為了給列或表一個(gè)臨時(shí)項(xiàng),下面這篇文章主要給大家介紹了關(guān)于Oracle別名使用的一些要點(diǎn)小結(jié),需要的朋友可以參考下

今天在寫一個(gè)簡(jiǎn)單的SQL語(yǔ)句并執(zhí)行時(shí)拋出了如下圖所示的一個(gè)錯(cuò)誤提示信息!

恩,此異常信息很明顯,在SQL語(yǔ)句中標(biāo)示符的長(zhǎng)度過(guò)長(zhǎng)了,簡(jiǎn)短一些就應(yīng)該沒(méi)問(wèn)題了,我查看了一下我的SQL語(yǔ)句發(fā)現(xiàn)是我的查詢字段的列別名過(guò)長(zhǎng),實(shí)際測(cè)試的結(jié)果為列字段別名的最大長(zhǎng)度為30個(gè)字節(jié)!

注意:我的測(cè)試數(shù)據(jù)庫(kù)是ORACLE 11.2.0.4.0(如下圖所示)

ok,問(wèn)題搞定了,對(duì)應(yīng)的更多的錯(cuò)誤信息及解決方案,也可以從ORACLE的錯(cuò)誤信息手冊(cè)中查詢比如(針對(duì)此問(wèn)題):

Error:
ORA-00972: identifier is too long 
Cause:
You tried to reference a table, cluster, view, index, synonym, tablespace, or username with a value that was longer than 30 characters. 
Action:
The options to resolve this Oracle error are: 
Names for tables, clusters, views, indexes, synonyms, tablespaces, and usernames must be 30 characters or less. You must shorten the name to no more than 30 characters for these objects.

以上內(nèi)容是我分析和解決我的SQL語(yǔ)句中,查詢時(shí)列的別名過(guò)長(zhǎng)問(wèn)題的過(guò)程,也是我分享這篇小博文的引子!

下面是我針對(duì)別名的一個(gè)小結(jié)(注意:我的測(cè)試數(shù)據(jù)庫(kù)是ORACLE 11.2.0.4.0 字符集是AMERICAN_AMERICA.AL32UTF8)

一:使用別名的好處

   1)簡(jiǎn)化SQL語(yǔ)句的書寫,特別是多表關(guān)聯(lián)查詢且表名較長(zhǎng)時(shí)

   2)增強(qiáng)SQL語(yǔ)句的可讀性,特別是當(dāng)查詢出來(lái)的列字段較為復(fù)雜時(shí)效果更為明顯

二:測(cè)試小結(jié)

1)測(cè)試時(shí)使用的簡(jiǎn)單表結(jié)構(gòu)

CREATE TABLE SALES.STUDENT
(
  ID        NUMBER,
  NAME      VARCHAR2(20 BYTE),
  SEX       CHAR(1 BYTE),
  BIRTHDAY  DATE,
  HOBBY     VARCHAR2(20 CHAR)
)

2)測(cè)試使用的若干條測(cè)試數(shù)據(jù)

3)列名的最大長(zhǎng)度——30個(gè)字節(jié)

SELECT ID ABCDEABCDEABCDEABCDEABCDEABCDE--30個(gè)英文大寫字符,正常執(zhí)行
FROM STUDENT

SELECT ID ABCDEABCDEABCDEABCDEABCDEABCDE1--多加另一個(gè)1就會(huì)報(bào)ORA-00972:identifier is to long
FROM STUDENT

SELECT ID 我們學(xué)校的好學(xué)生學(xué)號(hào)--10個(gè)中文漢字字符,正常執(zhí)行
FROM STUDENT

SELECT ID 我們學(xué)校的好學(xué)生學(xué)號(hào)1--多加另一個(gè)1就會(huì)報(bào)ORA-00972:identifier is to long
FROM STUDENT

4)是否可以使用AS關(guān)鍵字——可以使用

SELECT ID AS 學(xué)號(hào)--使用AS的情況,正常執(zhí)行
FROM STUDENT

SELECT ID 學(xué)號(hào)--不適用AS也可以正常執(zhí)行,而且代碼更簡(jiǎn)潔,建議使用方式
FROM STUDENT

5)是否可以以數(shù)字開(kāi)頭——可以以數(shù)字開(kāi)頭但必須使用雙引號(hào)括起來(lái)

SELECT ID 123學(xué)號(hào)--執(zhí)行時(shí)報(bào)"ORA-00923: FROM keyword not found where expected"
FROM STUDENT

SELECT ID "123學(xué)號(hào)"--正常執(zhí)行

6)對(duì)于中文別名雙引號(hào)、單引號(hào)、不使用引號(hào)的區(qū)別(注意:全是英文的單引或雙引符號(hào))——使用單引符號(hào)時(shí)報(bào)錯(cuò)

SELECT ID 學(xué)號(hào)--正常執(zhí)行
FROM STUDENT

SELECT ID "學(xué)號(hào)"--正常執(zhí)行
FROM STUDENT

SELECT ID '學(xué)號(hào)'--執(zhí)行時(shí)報(bào)"ORA-00923: FROM keyword not found where expected"
FROM STUDENT

SELECT ID StudentId--正常執(zhí)行
FROM STUDENT

SELECT ID "StudentId"--正常執(zhí)行
FROM STUDENT

SELECT ID 'StudentId'--執(zhí)行時(shí)報(bào)"ORA-00923: FROM keyword not found where expected"
FROM STUDENT

7)是否可以使用其他的特殊符號(hào)比如:小括號(hào)——可以使用但必須使用雙引號(hào)括起來(lái)(注意:其他的特殊符號(hào)可能類似,這里以小括號(hào)為例做了測(cè)試,其他情況如果感興趣可以自己動(dòng)手試試)

SELECT ID AS (學(xué)號(hào))--英文小括號(hào)且使用AS的情形,執(zhí)行時(shí)報(bào)"ORA-00923: FROM keyword not found where expected"
FROM STUDENT

SELECT ID (學(xué)號(hào))--英文小括號(hào),執(zhí)行時(shí)報(bào)"ORA-00904: "ID": invalid identifier"
FROM STUDENT

SELECT ID AS "(學(xué)號(hào))"--正常執(zhí)行
FROM STUDENT

SELECT ID AS(學(xué)號(hào))--中文小括號(hào)且使用AS的情形,執(zhí)行時(shí)報(bào)"ORA-00923: FROM keyword not found where expected"
FROM STUDENT

SELECT ID(學(xué)號(hào))--中文小括號(hào),執(zhí)行時(shí)報(bào)"ORA-00904: "ID": invalid identifier"
FROM STUDENT

SELECT ID "(學(xué)號(hào))"--正常執(zhí)行
FROM STUDENT

8)是否可以保留別名中的空格——可以,但必須使用雙引號(hào)括起來(lái)

SELECT ID 學(xué) 號(hào)--執(zhí)行時(shí)報(bào)"ORA-00923: FROM keyword not found where expected"
FROM STUDENT

SELECT ID "學(xué) 號(hào)"--正常執(zhí)行
FROM STUDENT

SELECT ID XUE HAO--執(zhí)行時(shí)報(bào)"ORA-00923: FROM keyword not found where expected"
FROM STUDENT

SELECT ID "XUE HAO"--正常執(zhí)行
FROM STUDENT

9)使用別名時(shí)因SQL語(yǔ)句各子句的執(zhí)行順序引起的問(wèn)題

           ORACLE中的SQL語(yǔ)句, 

            1.WHERE/GROUP BY/HAVING子句中只能直接使用欄位或者常量,而不能使用欄位的別名,除非這個(gè)別名來(lái)自                   子查詢之中,如:SELECT .... FROM (SELECT COLUMN_NAME C FROM TABLE_NAME) WHERE C > 1
            2.而ORDER BY 則可以直接使用別名,如SELECT COLUMN_NAME C FROM TABLE_NAME ORDER BY C

                這和SQL的執(zhí)行順序是有關(guān)的,SQL語(yǔ)句的執(zhí)行順序大致如下所示:

                1. FROM語(yǔ)句

                2. WHERE語(yǔ)句(結(jié)合條件)

                3. START WITH語(yǔ)句

                4. CONNECT BY語(yǔ)句

                5. WHERE語(yǔ)句

                6. GROUP BY語(yǔ)句

                7. HAVING語(yǔ)句

                8. MODEL語(yǔ)句

                9. SELECT語(yǔ)句

                10. UNION、MINUS、INTERSECT等集合演算演算

                11. ORDER BY語(yǔ)句

           我們可以看到SELECT子句是在WHERE子句執(zhí)行后才執(zhí)行的,當(dāng)SELECT子句執(zhí)行時(shí)查詢列的別名才生成,所以在            WHERE子句中根本看不到列的別名,當(dāng)然,自然也就無(wú)法引用列的別名了。 所以字段、表達(dá)式的別名在WHERE子            句和GROUP BY子句都是不能使用的,而在ORDER BY中不僅可以使用別名,甚至可以直接使用欄位的下標(biāo)來(lái)進(jìn)行            排序,如:ORDER BY ID或者ORDER BY 1

SELECT ID ID_ 
FROM STUDENT 
WHERE ID_=11--執(zhí)行時(shí)報(bào)"ORA-00904: "ID_": invalid identifier"

SELECT ID ID_ 
FROM STUDENT 
WHERE ID=11--正常執(zhí)行

SELECT ID ID_ 
FROM STUDENT 
WHERE ID='11'--正常執(zhí)行,注意:ID是NUMBER類型的數(shù)據(jù)

SELECT ID ID_ 
FROM STUDENT 
WHERE ID="11"--執(zhí)行時(shí)報(bào)"ORA-00904: "11": invalid identifier",注意:ID是NUMBER類型的數(shù)據(jù)


SELECT ID,COUNT(*) C
FROM STUDENT
GROUP BY ID
      HAVING C>0--執(zhí)行時(shí)報(bào)"ORA-00904: "C": invalid identifier"
      
SELECT ID,COUNT(*) C
FROM STUDENT
GROUP BY ID
      HAVING Count(*)>0--正常執(zhí)行   

SELECT ID,COUNT(*)C
FROM STUDENT
GROUP BY ID
      HAVING COUNT(*)>0
ORDER BY C--正常執(zhí)行


SELECT ID ID_
FROM STUDENT
ORDER BY ID_--正常執(zhí)行

SELECT ID ID_
FROM STUDENT
ORDER BY 1--正常執(zhí)行

10)別名是否區(qū)分大小寫——區(qū)分大小寫(注意:當(dāng)不用雙引號(hào)括起來(lái)的時(shí)候英文字符大小寫不敏感)

SELECT XUEHAO
FROM (SELECT ID XUEHAO FROM STUDENT) 
WHERE XUEHAO > 1--正常執(zhí)行

SELECT XUEHAO
FROM (SELECT ID xuehao FROM STUDENT) 
WHERE XUEHAO > 1--正常執(zhí)行

SELECT XUEHAO
FROM (SELECT ID "XUEHAO" FROM STUDENT) 
WHERE XUEHAO > 1--正常執(zhí)行

SELECT XUEHAO
FROM (SELECT ID "xuehao" FROM STUDENT) 
WHERE XUEHAO > 1--執(zhí)行時(shí)報(bào)"ORA-00904: "XUEHAO": invalid identifier"

SELECT XUEHAO
FROM (SELECT ID "xuehao" FROM STUDENT) 
WHERE xuehao > 1--執(zhí)行時(shí)報(bào)"ORA-00904: "XUEHAO": invalid identifier"

SELECT XUEHAO
FROM (SELECT ID "xuehao" FROM STUDENT) 
WHERE "xuehao" > 1--執(zhí)行時(shí)報(bào)"ORA-00904: "XUEHAO": invalid identifier"
SELECT "xuehao"
FROM (SELECT ID "xuehao" FROM STUDENT) 
WHERE "xuehao" > 1--正常執(zhí)行

這個(gè)小例子也可以看到SQL語(yǔ)句是先執(zhí)行WHERE子句然后才執(zhí)行SELECT子句的!

總結(jié)

到此這篇關(guān)于Oracle別名使用要點(diǎn)小結(jié)的文章就介紹到這了,更多相關(guān)Oracle別名使用內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Oracle表空間不足的兩種解決辦法

    Oracle表空間不足的兩種解決辦法

    這篇文章主要介紹了Oracle表空間不足的兩種解決辦法,需要的朋友可以參考下
    2017-10-10
  • Oracle查看執(zhí)行計(jì)劃的實(shí)現(xiàn)

    Oracle查看執(zhí)行計(jì)劃的實(shí)現(xiàn)

    查看Oracle 的執(zhí)行計(jì)劃的目的是為了了解 SQL 查詢或語(yǔ)句在數(shù)據(jù)庫(kù)中的執(zhí)行方式和性能表現(xiàn),本文主要介紹了Oracle查看執(zhí)行計(jì)劃的實(shí)現(xiàn),感興趣的可以了解一下
    2024-02-02
  • ORACLE中%TYPE和%ROWTYPE的使用詳解

    ORACLE中%TYPE和%ROWTYPE的使用詳解

    這篇文章主要介紹了ORACLE中%TYPE和%ROWTYPE的使用,本文給大家講解的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-11-11
  • oracle sql執(zhí)行過(guò)程(流程圖)

    oracle sql執(zhí)行過(guò)程(流程圖)

    本篇文章是對(duì)oracle sql執(zhí)行過(guò)程進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05
  • 將mysql轉(zhuǎn)換到oracle必須了解的50件事

    將mysql轉(zhuǎn)換到oracle必須了解的50件事

    我其實(shí)是同一天看到Robert Treat幾人整理的”Mysql 遷移到Oracle前需要了解的50件事“與Baron Schwartz的”O(jiān)racle遷移到Mysql之前需要了解的50件事“的,只是Baron Schwartz的這個(gè)列表可能對(duì)大家更加有用處,也就先將其整出來(lái)了.
    2010-06-06
  • Linux中Oracle數(shù)據(jù)庫(kù)備份

    Linux中Oracle數(shù)據(jù)庫(kù)備份

    在Linux中Oracle數(shù)據(jù)庫(kù)備份的方法有很多,就像mysql一樣可以使用不同方法進(jìn)行備份oracle數(shù)據(jù)庫(kù)
    2013-11-11
  • 淺談oracle SCN機(jī)制

    淺談oracle SCN機(jī)制

    這篇文章主要介紹了淺談oracle SCN機(jī)制,介紹了oracle事務(wù)中數(shù)據(jù)變化的部分內(nèi)容,以及scn的作用等,需要的朋友可以參考下。
    2017-09-09
  • Oracle?創(chuàng)建和操作表的示例代碼

    Oracle?創(chuàng)建和操作表的示例代碼

    本節(jié)主要介紹Oracle創(chuàng)建、修改和刪除表的基本操作,對(duì)創(chuàng)建數(shù)據(jù)庫(kù)表一般有兩種方式,文中結(jié)合示例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧
    2023-12-12
  • WMware redhat 5 oracle 11g 安裝方法

    WMware redhat 5 oracle 11g 安裝方法

    本文將詳細(xì)介紹WMware中redhat 5 安裝oracle 11g方法,需要的朋友可以參考下
    2012-12-12
  • ORACLE常見(jiàn)錯(cuò)誤代碼的分析與解決(三)

    ORACLE常見(jiàn)錯(cuò)誤代碼的分析與解決(三)

    ORACLE常見(jiàn)錯(cuò)誤代碼的分析與解決(三)...
    2007-03-03

最新評(píng)論