select 1 與 select null (轉)

來源:互聯網
上載者:User

標籤:

1.Select 1

在這裡我主要討論的有以下幾個select 語句:

table表是一個資料表,假設表的行數為10行,以下同。

1:select  1 from table     

2:select count(1)  from table 

3:select sum(1) from table

對第一個select語句,我剛開始以為是“1”代表是列名,從2,3種順推得出得結果:)有點無恥吧。不過通過我自己得觀察,這樣我覺得是不對的,所以我在SQL SERVER中測試了一下,發現結果如下:

1:測試結果,得出一個行數和table表行數一樣的臨時列(暫且這麼叫,我也不知道該叫什麼),每行的列值是1;

2:得出一個數,該數是table表的行數;

3:得出一個數,該數是table表的行數;

然後我又用“2”測試,結果如下:

1:得出一個行數和table表行數一樣的臨時列,每行的列值是2;

2:得出一個數,該數是table表的行數;

3:得出一個數,該數是table表的行數×2的數

然後我又用更大的數測試:

1:得出一個行數和table表行數一樣的臨時列,每行的列值是我寫在select後的數;

2:還是得出一個數,該數是table表的行數;

3:得出一個數,該數是table表的行數×寫在select後的數

綜上所述:我發現第一種的寫法是增加臨時列,每行的列值是寫在select後的數;第二種是不管count(a)的a值如何變化,得出的值總是table表的行數;第三種是計算臨時列的和。

 

2.Select null

Select null 與Select 1 類似,只不過返回的列值為Null,在與Exists配合使用時,只要有行返回,則Exists子查詢仍然為True。和Select 1 不通,Select null 中不可以使用Count 和 SUm 函數。

null是一個特殊的值,既不是空也不是空格,而是一個不確定的值。
如下代碼
SELECT   null
FROM     addresses
WHERE    address_id = 1
的意義是在表addresses中有幾行滿足條件address_id = 1的值就返回幾行null值 。

select 1 與 select null (轉)

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.