程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> 其他數據庫知識 >> 更多數據庫知識 >> sql查詢點滴記錄

sql查詢點滴記錄

編輯:更多數據庫知識

也不一定,以前從來沒有深入的研究過sql查詢,最近買了一本T-SQL查詢的書,把以前忽視的問題都記錄一下

以前一直模模糊糊的把sqlserver作為關系數據庫,裡面就是以表的方式進行數據的關系化話管理,後來有些SQL語句看著怪怪的,也沒怎麼管

其實

“寫好sql,需要的是一種面向聲明和集合的思維方式,而不是面向過程的(集合是重點)”(PS:數據庫裡面的表就是一個集合,集合是無序的!)

以前沒太注意過sql語句執行時的邏輯順序,在研究linq時,linq強調了sql語句的執行順序,在看書時也留意了一下

(5) select (5-2) distinct (5-3) top (<top_specification>) (5-1) <select_list>
(1) from (1-j) <left_table> <join_type> join <right_table> on <on_predicate>
|(1-a) <left_table> <apply_type> apply <right_table_expression> as <alias>
|(1-p) <left_table> pivot (<pivot_specification>) as <alias>
|(1-u) <left_table> unpivot (<unpivot_specification>) as <alias>
(2) where <where_predicate>
(3) group by <group_by_specification>
(4) having <having_predicate>
(6) order by <order_by_list>


可以看到

第一個階段是from :標識出查詢的來源,處理表(集合)運算符

第二個階段是where根據謂詞(查詢條件)進行刷選

第三個階段是gruop by 根據指定的列表名進行分組

第四個階段是having 根據having中出現的謂詞進行刷選

第五個階段是select

第六各階段是order by根據指定列進行排序

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved