select 1 from ..., sql語句中的1代表什么意思?查出來是個什么結果?


select  1 from ..., sql語句中的1代表什么意思?查出來是個什么結果?

        select 1 from table;與select anycol(目的表集合中的任意一行) from table;與select * from table 從作用上來說是沒有差別的,都是查看是否有記錄,一般是作條件查詢用的。select 1 from 中的1是一常量(可以為任意數值),查到的所有行的值都是它,但從效率上來說,1>anycol>*,因為不用查字典表


 

測試場景:(轉自網絡文獻)
table表是一個數據表,假設表的行數為10行。

1:select  1 from table       增加臨時列,每行的列值是寫在select后的數,這條sql語句中是1

2:select count(1)  from table   管count(a)的a值如何變化,得出的值總是table表的行數

3:select sum(1) from table   計算臨時列的和

 

 在SQL SERVER中用 1 測試了一下,發現結果如下:

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表的行數;第三種是計算臨時列的和
 

語句if not exists(select 1 from deleted d join inserted i on d.ID=i.ID
and d.col1=1 and i.col1=2)

if not exists 如果不存在
(..)這里該是驗證更新,更新前的id等於更新后的id,並且更新前col的值是1,更新后的值是2


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM