1. 程式人生 > >count(1) sum(1) select 1 from table 含義

count(1) sum(1) select 1 from table 含義

轉自:http://blog.csdn.net/u010104750/article/details/51141221

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);

測試場景:
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