select 1 from 浅析
一、http://www.cnblogs.com/weiwcn/archive/2008/03/24/1120079.html
今天看到項目代碼里有這條語句,不懂select 1 from XXXXXXX里的1是何意,查了一番才知道:
1、select 1 from mytable;與select anycol(目的表集合中的任意一行) from mytable;與select * from mytable 作用上來說是沒有差別的,都是查看是否有記錄,一般是作條件用的。select 1 from 中的1是一常量,查到的所有行的值都是它,但從效率上來說,1>anycol>*,因為不用查字典表。
2、查看記錄條數可以用select sum(1) from mytable;等價于select sum(*) from mytable;
3、實際項目SQL:
select c_insrnc_cde, c_nme_cn
?? from t_prd_ins a
where a.c_prod_no = '01'
??? and not exists
(select 1
?????????? from (select d.c_insrnc_cde, a.c_nme_cn
?????????????????? from t_prd_ins?????????????????? a,
??????????????????????? tb_bas_ply_policy_rdr?????? c,
??????????????????????? tb_bas_ply_policy_rdr_list d
????????????????? where a.c_insrnc_cde = d.c_insrnc_cde
??????????????????? and d.c_policy_id = c.c_policy_id
??????????????????? and d.c_seq_no = c.c_seq_no
??????????????????? and a.c_kind_no = '01'
??????????????????? and c.c_dpt_cde = '101'?? ----機構樹中取出機構
??????????????????? and c.c_prod_no = '01'
??????????????????? and c.t_effc_tm <= TO_DATE('2007-9-5', 'YYYY-MM-DD')
??????????????????? and c.t_expd_tm >= TO_DATE('2007-9-5', 'YYYY-MM-DD')
??????????????????? and c.c_work_mode = '00501'
??????????????????? and c.c_reach_area = '00701'
??????????????????? ) t
????????? where t.c_insrnc_cde = a.c_insrnc_cde);
?二、http://blog.csdn.net/wangyihust/archive/2009/02/05/3863758.aspx
測試場景:(轉自網絡文獻)
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
總結
以上是生活随笔為你收集整理的select 1 from 浅析的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 数据分析工具选型3大秘诀,Excel竟未
- 下一篇: 论程序员的核心竞争力