sql查詢點(diǎn)滴記錄
更新時(shí)間:2011年12月20日 13:06:28 作者:
做.NET有一段時(shí)間了,如果說不會(huì)sql,那肯定是假的,但是真的掌握嗎
也不一定,以前從來沒有深入的研究過sql查詢,最近買了一本T-SQL查詢的書,把以前忽視的問題都記錄一下
以前一直模模糊糊的把sqlserver作為關(guān)系數(shù)據(jù)庫,里面就是以表的方式進(jìn)行數(shù)據(jù)的關(guān)系化話管理,后來有些SQL語句看著怪怪的,也沒怎么管
其實(shí)
“寫好sql,需要的是一種面向聲明和集合的思維方式,而不是面向過程的(集合是重點(diǎn))”(PS:數(shù)據(jù)庫里面的表就是一個(gè)集合,集合是無序的!)
以前沒太注意過sql語句執(zhí)行時(shí)的邏輯順序,在研究linq時(shí),linq強(qiáng)調(diào)了sql語句的執(zhí)行順序,在看書時(shí)也留意了一下
(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>
可以看到
第一個(gè)階段是from :標(biāo)識(shí)出查詢的來源,處理表(集合)運(yùn)算符
第二個(gè)階段是where根據(jù)謂詞(查詢條件)進(jìn)行刷選
第三個(gè)階段是gruop by 根據(jù)指定的列表名進(jìn)行分組
第四個(gè)階段是having 根據(jù)having中出現(xiàn)的謂詞進(jìn)行刷選
第五個(gè)階段是select
第六各階段是order by根據(jù)指定列進(jìn)行排序
以前一直模模糊糊的把sqlserver作為關(guān)系數(shù)據(jù)庫,里面就是以表的方式進(jìn)行數(shù)據(jù)的關(guān)系化話管理,后來有些SQL語句看著怪怪的,也沒怎么管
其實(shí)
“寫好sql,需要的是一種面向聲明和集合的思維方式,而不是面向過程的(集合是重點(diǎn))”(PS:數(shù)據(jù)庫里面的表就是一個(gè)集合,集合是無序的!)
以前沒太注意過sql語句執(zhí)行時(shí)的邏輯順序,在研究linq時(shí),linq強(qiáng)調(diào)了sql語句的執(zhí)行順序,在看書時(shí)也留意了一下
(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>
可以看到
第一個(gè)階段是from :標(biāo)識(shí)出查詢的來源,處理表(集合)運(yùn)算符
第二個(gè)階段是where根據(jù)謂詞(查詢條件)進(jìn)行刷選
第三個(gè)階段是gruop by 根據(jù)指定的列表名進(jìn)行分組
第四個(gè)階段是having 根據(jù)having中出現(xiàn)的謂詞進(jìn)行刷選
第五個(gè)階段是select
第六各階段是order by根據(jù)指定列進(jìn)行排序
相關(guān)文章
SQLServer2005 按照日期自動(dòng)備份的方法
SQLServer2005如何備份,按照日期自動(dòng)備份2010-07-07
SQLServer2005創(chuàng)建定時(shí)作業(yè)任務(wù)
這篇文章主要為大家介紹了SQLServer2005創(chuàng)建定時(shí)作業(yè)任務(wù)的詳細(xì)過程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-12-12
sql server中隨機(jī)函數(shù)NewID()和Rand()
在SQL語言中,隨機(jī)函數(shù)NEWID和rand()用法并不相同,下面就將為您示例分析這兩個(gè)隨機(jī)函數(shù)的區(qū)別,供您參考,希望對您深入理解SQL函數(shù)能起到作用2015-10-10
sql 隨機(jī)抽取幾條數(shù)據(jù)的方法 推薦
前段時(shí)間在做項(xiàng)目的時(shí)刻??偸怯龅竭@樣一個(gè)問題。就是要怎么去讓首頁顯示的內(nèi)容不斷的變化。想了很久。也沒有什么結(jié)果。后面去想了一下。得出以下一個(gè)結(jié)果2009-06-06
必備 SQL 查詢優(yōu)化技巧提升網(wǎng)站訪問速度
在這篇文章中,我將介紹如何識(shí)別導(dǎo)致性能出現(xiàn)問題的查詢,如何找出它們的問題所在,以及快速修復(fù)這些問題和其他加快查詢速度的方法2018-01-01
我也有微信朋友圈了 Android實(shí)現(xiàn)
最近寫了一個(gè)簡單的朋友圈程序,包含了朋友圈的列表實(shí)現(xiàn),視頻的錄制、預(yù)覽與上傳,圖片可選擇拍照或者從相冊選取,從相冊選取可以一次選擇多張照片,并且限制照片的張數(shù),想擁有真正屬于自己的朋友圈嗎?快來圍觀2016-05-05
SQL設(shè)置SQL Server最大連接數(shù)及查詢語句
今天遇到了關(guān)于Sql Server最大連接數(shù)(Max Pool Size)的問題,后來通過查找一些資料解決了,所以想著總結(jié)下關(guān)于SQL Server最大連接數(shù)的內(nèi)容,所以這篇文章主要介紹了SQL設(shè)置SQL Server最大連接數(shù)與查詢語句,有需要的朋友們可以參考借鑒。2016-12-12

