做.NET有一段時間了,如果說不會sql,那肯定是假的,但是真的掌握嗎
也不一定,以前從來沒有深入的研究過sql查詢,最近買了一本T-SQL查詢的書,把以前忽視的問題都記錄一下
以前一直模模糊糊的把sqlserver作為關系數據庫,里面就是以表的方式進行數據的關系化話管理,后來有些SQL語句看著怪怪的,也沒怎么管
其實
“寫好sql,需要的是一種面向聲明和集合的思維方式,而不是面向過程的(集合是重點)”(PS:數據庫里面的表就是一個集合,集合是無序的!)
以前沒太注意過sql語句執行時的邏輯順序,在研究linq時,linq強調了sql語句的執行順序,在看書時也留意了一下
(5) select (5-2) distinct (5-3) top (
(1) from (1-j)
|(1-a)
|(1-p)
|(1-u)
(2) where
(3) group by
(4) having
(6) order by
可以看到
第一個階段是from :標識出查詢的來源,處理表(集合)運算符
第二個階段是where根據謂詞(查詢條件)進行刷選
第三個階段是gruop by 根據指定的列表名進行分組
第四個階段是having 根據having中出現的謂詞進行刷選
第五個階段是select
第六各階段是order by根據指定列進行排序
? 版權聲明
文章版權歸作者所有,未經允許請勿轉載。
THE END