SQL Server Ë÷Òý½á¹¹¼°ÆäʹÓã¨ËÄ£©
SQL Server Ë÷Òý½á¹¹¼°ÆäʹÓã¨ËÄ£©
×÷Õߣºfreedk
Ò»¡¢ÉîÈëdz³öÀí½âË÷Òý½á¹¹
¶þ¡¢¸ÄÉÆSQLÓï¾ä
Èý¡¢ÊµÏÖСÊý¾ÝÁ¿ºÍº£Á¿Êý¾ÝµÄͨÓ÷ÖÒ³ÏÔʾ´æ´¢¹ý³Ì
¾Û¼¯Ë÷ÒýµÄÖØÒªÐÔºÍÈçºÎÑ¡Ôñ¾Û¼¯Ë÷Òý
¡¡¡¡ÔÚÉÏÒ»½ÚµÄ±êÌâÖУ¬±ÊÕßдµÄÊÇ£ºÊµÏÖСÊý¾ÝÁ¿ºÍº£Á¿Êý¾ÝµÄͨÓ÷ÖÒ³ÏÔʾ´æ´¢¹ý³Ì¡£ÕâÊÇÒòΪÔÚ½«±¾´æ´¢¹ý³ÌÓ¦ÓÃÓÚ“°ì¹«×Ô¶¯»¯”ϵͳµÄʵ¼ùÖÐʱ£¬±ÊÕß·¢ÏÖÕâµÚÈýÖÖ´æ´¢¹ý³ÌÔÚСÊý¾ÝÁ¿µÄÇé¿öÏ£¬ÓÐÈçÏÂÏÖÏó£º
1¡¢·ÖÒ³ËÙ¶ÈÒ»°ãά³ÖÔÚ1ÃëºÍ3ÃëÖ®¼ä¡£
2¡¢ÔÚ²éѯ×îºóһҳʱ£¬ËÙ¶ÈÒ»°ãΪ5ÃëÖÁ8Ã룬ÄÄÅ·ÖÒ³×ÜÊýÖ»ÓÐ3Ò³»ò30ÍòÒ³¡£
¡¡¡¡ËäÈ»ÔÚ³¬´óÈÝÁ¿Çé¿öÏ£¬Õâ¸ö·ÖÒ³µÄʵÏÖ¹ý³ÌÊǺܿìµÄ£¬µ«ÔÚ·Öǰ¼¸Ò³Ê±£¬Õâ¸ö1£3ÃëµÄËÙ¶È±ÈÆðµÚÒ»ÖÖÉõÖÁûÓо¹ýÓÅ»¯µÄ·ÖÒ³·½·¨ËÙ¶È»¹ÒªÂý£¬½èÓû§µÄ»°Ëµ¾ÍÊÇ“»¹Ã»ÓÐACCESSÊý¾Ý¿âËٶȿ씣¬Õâ¸öÈÏʶ×ãÒÔµ¼ÖÂÓû§·ÅÆúʹÓÃÄú¿ª·¢µÄϵͳ¡£
¡¡¡¡±ÊÕ߾ʹ˷ÖÎöÁËһϣ¬ÔÀ´²úÉúÕâÖÖÏÖÏóµÄÖ¢½áÊÇÈç´ËµÄ¼òµ¥£¬µ«ÓÖÈç´ËµÄÖØÒª£ºÅÅÐòµÄ×ֶβ»ÊǾۼ¯Ë÷Òý£¡
¡¡¡¡±¾ÆªÎÄÕµÄÌâÄ¿ÊÇ£º“²éѯÓÅ»¯¼°·ÖÒ³Ëã·¨·½°¸”¡£±ÊÕßÖ»ËùÒÔ°Ñ“²éѯÓÅ»¯”ºÍ“·ÖÒ³Ëã·¨”ÕâÁ½¸öÁªÏµ²»ÊǺܴóµÄÂÛÌâ·ÅÔÚÒ»Æð£¬¾ÍÊÇÒòΪ¶þÕß¶¼ÐèÒªÒ»¸ö·Ç³£ÖØÒªµÄ¶«Î÷¨D¨D¾Û¼¯Ë÷Òý¡£
ÔÚÇ°ÃæµÄÌÖÂÛÖÐÎÒÃÇÒѾÌáµ½ÁË£¬¾Û¼¯Ë÷ÒýÓÐÁ½¸ö×î´óµÄÓÅÊÆ£º
1¡¢ÒÔ×î¿ìµÄËÙ¶ÈËõС²éѯ·¶Î§¡£
2¡¢ÒÔ×î¿ìµÄËٶȽøÐÐ×Ö¶ÎÅÅÐò¡£
¡¡¡¡µÚ1Ìõ¶àÓÃÔÚ²éѯÓÅ»¯Ê±£¬¶øµÚ2Ìõ¶àÓÃÔÚ½øÐзÖҳʱµÄÊý¾ÝÅÅÐò¡£
¡¡¡¡¶ø¾Û¼¯Ë÷ÒýÔÚÿ¸ö±íÄÚÓÖÖ»Äܽ¨Á¢Ò»¸ö£¬ÕâʹµÃ¾Û¼¯Ë÷ÒýÏԵøü¼ÓµÄÖØÒª¡£¾Û¼¯Ë÷ÒýµÄÌôÑ¡¿ÉÒÔ˵ÊÇʵÏÖ“²éѯÓÅ»¯”ºÍ“¸ßЧ·ÖÒ³”µÄ×î¹Ø¼üÒòËØ¡£
¡¡¡¡µ«Òª¼Èʹ¾Û¼¯Ë÷ÒýÁмȷûºÏ²éѯÁеÄÐèÒª£¬ÓÖ·ûºÏÅÅÐòÁеÄÐèÒª£¬Õâͨ³£ÊÇÒ»¸öì¶Ü¡£±ÊÕßÇ°Ãæ“Ë÷Òý”µÄÌÖÂÛÖУ¬½«fariqi£¬¼´Óû§·¢ÎÄÈÕÆÚ×÷ΪÁ˾ۼ¯Ë÷ÒýµÄÆðʼÁУ¬ÈÕÆÚµÄ¾«È·¶ÈΪ“ÈÕ”¡£ÕâÖÖ×÷·¨µÄÓÅµã£¬Ç°ÃæÒѾÌáµ½ÁË£¬ÔÚ½øÐл®Ê±¼ä¶ÎµÄ¿ìËÙ²éѯÖУ¬±ÈÓÃIDÖ÷¼üÁÐÓкܴóµÄÓÅÊÆ¡£
¡¡¡¡µ«ÔÚ·Öҳʱ£¬ÓÉÓÚÕâ¸ö¾Û¼¯Ë÷ÒýÁдæÔÚ×ÅÖØ¸´¼Ç¼£¬ËùÒÔÎÞ·¨Ê¹ÓÃmax»òminÀ´×îΪ·ÖÒ³µÄ²ÎÕÕÎ½ø¶øÎÞ·¨ÊµÏÖ¸üΪ¸ßЧµÄÅÅÐò¡£¶øÈç¹û½«IDÖ÷¼üÁÐ×÷Ϊ¾Û¼¯Ë÷Òý£¬ÄÇô¾Û¼¯Ë÷Òý³ýÁËÓÃÒÔÅÅÐòÖ®Í⣬ûÓÐÈκÎÓô¦£¬Êµ¼ÊÉÏÊÇÀË·ÑÁ˾ۼ¯Ë÷ÒýÕâ¸ö±¦¹óµÄ×ÊÔ´¡£
¡¡¡¡Îª½â¾öÕâ¸öì¶Ü£¬±ÊÕߺóÀ´ÓÖÌí¼ÓÁËÒ»¸öÈÕÆÚÁУ¬ÆäĬÈÏֵΪgetdate()¡£Óû§ÔÚдÈë¼Ç¼ʱ£¬Õâ¸ö
Ïà¹ØÎĵµ£º
RANK ( ) OVER ( [query_partition_clause] order_by_clause )
DENSE_RANK ( ) OVER ( [query_partition_clause] order_by_clause )
¿ÉʵÏÖ°´Ö¸¶¨µÄ×ֶηÖ×éÅÅÐò£¬¶ÔÓÚÏàͬ·Ö×é×ֶεĽá¹û¼¯½øÐÐÅÅÐò,
ÆäÖÐPARTITION BY Ϊ·Ö×é×ֶΣ¬ORDER BY Ö¸¶¨ÅÅÐò×Ö¶Î
over²»Äܵ¥¶ÀʹÓã¬ÒªºÍ·ÖÎöº¯Êý£ºrank(),dense_rank(),row_n ......
ÕªÒª£º±¾ÎĽéÉÜÁËSQL Server´æ´¢¹ý³ÌÏà¶ÔÓÚÆäËûµÄÊý¾Ý¿â·ÃÎÊ·½·¨µÄÓŵ㼰SQL Server´æ´¢¹ý³ÌµÄ·ÖÀàµÈ¡£
SQL Server´æ´¢¹ý³ÌÊÇÒ»¸ö±»ÃüÃûµÄ´æ´¢ÔÚ·þÎñÆ÷ÉϵÄTransacation-SqlÓï¾ä¼¯ºÏ,ÊÇ·â×°ÖØ¸´ÐÔ¹¤×÷µÄÒ»ÖÖ·½·¨,ËüÖ§³ÖÓû§ÉùÃ÷µÄ±äÁ¿¡¢Ìõ¼þÖ´ÐÐºÍÆäËûÇ¿´óµÄ±à³Ì¹¦ÄÜ¡£
SQL Server´æ´¢¹ý³ÌÏà¶ÔÓÚÆäËûµÄÊý¾Ý¿â·ÃÎÊ·½·¨Ó ......
ÔÒò·ÖÎö:
SERVERPROPERTY º¯ÊýµÄ ServerName ÊôÐÔÓë@@SERVERNAME ·µ»ØÏàËÆµÄÐÅÏ¢¡£ServerName ÊôÐÔÌṩWindows ·þÎñÆ÷ºÍʵÀýÃû³Æ£¬Á½Õß¹²Í¬¹¹³ÉΨһµÄ·þÎñÆ÷ʵÀý£»@@SERVERNAME Ìṩµ±Ç°ÅäÖõı¾µØ·þÎñÆ÷Ãû³Æ¡£
Èç¹û°²×°Ê±Î´¸ü¸ÄĬÈÏ·þÎñÆ÷Ãû³Æ£¬Ôò ServerName ÊôÐÔºÍ @@SERVERNAME ·µ»ØÏàͬµÄÐÅÏ¢¡£Èç¹ûÔÚ°²×°Ê±Òѽ«±¾µ ......
ÏÂÁÐÓï¾ä²¿·ÖÊÇMssqlÓï¾ä£¬²»¿ÉÒÔÔÚaccessÖÐʹÓá£
¡¡¡¡SQL·ÖÀࣺ
¡¡¡¡DDL—Êý¾Ý¶¨ÒåÓïÑÔ
(CREATE£¬ALTER£¬DROP£¬DECLARE)
¡¡¡¡DML—Êý¾Ý²Ù×ÝÓïÑÔ
(SELECT£¬DELETE£¬UPDATE£¬INSERT)
¡¡¡¡DCL—Êý¾Ý¿ØÖÆÓïÑÔ
(GRANT£¬REVOKE£¬COMMIT£¬ROLLBACK)
¡¡¡¡Ê×ÏÈ,¼òÒª½éÉÜ»ù´¡Óï¾ä£º
¡¡¡¡1¡¢ËµÃ÷£º´´½¨Êý ......