SQL——Êý¾ÝÍêÕûÐÔ
Ò»£®Êý¾ÝÍêÕûÐÔ
¾ÍÊÇΪÁË·ÀÖ¹Êý¾Ý¿âÖдæÔÚ²»·ûºÏÓïÒ广¶¨µÄÊý¾Ý£¬ºÍ·ÀÖ¹ÒòÊäÈëÊä³ö´íÎó¶øÔì³ÉµÄÎÞЧ²Ù×÷»òÕß´íÎóÐÅÏ¢¶øÌá³öµÄ£¬Öƶ¨µÄһЩ¶ÔÔª×é¡¢ÊôÐÔºÍÓòµÄÒ»Ð©Ô¼ÊøºÍ¹æ¶¨¡£
½â¾ö°ì·¨ÓÉ£º¹æÔò£¬Ä¬ÈÏÖµ£¬Ô¼ÊøºÍ´¥·¢Æ÷µÈ¡£
¶þ£®Ô¼Êø
ÓÃÓÚÔöÇ¿Êý¾ÝÍêÕûÐÔ£¬·ÀÖ¹ºÏ·¨Óû§Ê¹ÓÃÊý¾Ý¿âʱ£¬ÏëÊý¾Ý¿âÖÐÌí¼Ó²»·ûºÏÓïÒåµÄÊý¾Ý¡£Ô¼Êø·ÖΪÈýÖÖ£ºÓë±íÓйصÄÔ¼Êø£¬ÓòÔ¼Êø£¬¶ÏÑÔÔ¼Êø¡£
¡£Óë±íÓйصÄÔ¼Êø£ºÐÐÔ¼Êø£¬ÁÐÔ¼Êø¡£
¡£ÓòÔ¼Êø£ºÔÚÓò¶¨ÒåÖб»¶¨ÒåµÄ£¬²¢ÇÒÓëÔÚÓòÖж¨ÒåµÄÈκÎÁж¼ÓйØÏµµÄÒ»ÖÖÔ¼Êø¡£
¡£.¶ÏÑÔÔ¼Êø£ºÔÚ¶ÏÑÔ¶¨Òåʱ¶¨ÒåµÄÒ»ÖÖÔ¼Êø£¬¿ÉÒÔÓëÒ»¸ö»òÕß¶à¸ö±íÓйء£
ÏÂÃæÊÇDEFAULTÔ¼Êø£¬CHECKÔ¼Êø£¬PRIMARYKEYÔ¼Êø£¬UNIQUEÔ¼Êø£¬FOREIGN KEYÔ¼Êø£¬NOU NULLÔ¼Êø£¬ÁÐÔ¼Êø£¬±íÔ¼Êø¡£
1£®DEFAULTÔ¼Êø
Ö÷Òª¾ÍÊÇÕë¶Ô±íÖеÄij¸öÁУ¬´´½¨Ò»¸öĬÈÏÖµ£¬ÔÚÓû§²åÈëֵʱ£¬Èç¹ûûÓиø¶¨Öµ£¬ÄǾÍĬÈÏΪ´ËÖµ¡£
(1).´´½¨Êý×ÖÀàÐ͵ÄDEFAULTÔ¼Êø
Êý×ÖÀàÐÍÓУºÕûÊý£¨bigint , int , smallint , tinyint£©£¬¾«È·Êý×Ö£¨decimal[p( , s)] ,
numeric[p( , s]£©£¬¸¡µãÊý£¨float[(n)] , real£©£¬»õ±ÒÖµ£¨money , smallmoney£©¡£
¼ÙÉè±ígoods£¬ÊôÐÔ£ºgNO,gNAME,gCOUNT,gPRICE,gADDRESS,StartDate
ÏÖÔÚΪgCOUNTºÍgPRICE´´½¨Ä¬ÈÏÖµ£º
ALTER TABLE goods ADD DEFAULT 0 FOR gCOUNT;
ALTER TABLE goods ADD DEFAULT 0 FOR gPRICE;
ÊäÈëÒÔÏÂÓï¾ä£ºINSERT INTO goods (gNO,gNAME,gADDRESS) VALUES('1001','ë½í','¼ªÁÖ³¤´º','2010-1-20 15:25:30.120')¡£Ö´Ðгɹ¦ºó£¬ÔÚ²Á¿´Ò»Ï£¬Äã»á·¢ÏÖ½á¹ûÖÐgCOUNTºÍgPRICEÁеÄֵΪ0¡£
×¢Ò⣺ÔÚÖ´ÐвåÈëÓï¾äʱ£¬Ò»¶¨ÒªÁгö²åÈëµÄÁУ¬Òª²»È»Äã»áÓöµ½²åÈëÊý¾ÝÁÐÓë±íÊôÐÔÁв»Ò»ÖµĴíÎó¡£
(2).ÉèÖÃDEFAULTÈÕÆÚÐÍÔ¼Êø
Ϊgoods±íµÄ»õÎïµ½»õÈÕÆÚStartDateÉèÖÃĬÈÏֵΪϵͳµ±Ç°ÈÕÆÚ¡£
ALERT TABLE 
Ïà¹ØÎĵµ£º
ÅÅÃûº¯ÊýÊÇSQL Server2005мӵŦÄÜ¡£ÔÚSQL Server2005ÖÐÓÐÈçÏÂËĸöÅÅÃûº¯Êý£º
¡¡¡¡1.row_number
¡¡¡¡2.rank
¡¡¡¡3.dense_rank
¡¡¡¡4.ntile¡¡¡¡
¡¡¡¡ÏÂÃæ·Ö±ð½éÉÜÒ»ÏÂÕâËĸöÅÅÃûº¯ÊýµÄ¹¦Äܼ°Ó÷¨¡£ÔÚ½éÉÜ֮ǰ¼ÙÉèÓÐÒ»¸öt_table±í£¬±í½á¹¹Óë±íÖеÄÊý¾ÝÈçͼ1Ëùʾ£º
¡¡¡¡Í¼1
¡¡¡¡ÆäÖÐfield1×ֶεÄÀàÐÍÊÇint£¬field2×Ö¶ ......
Ëø»úÖÆ
NOLOCKºÍREADPASTµÄÇø±ð¡£
1. ¿ªÆôÒ»¸öÊÂÎñÖ´ÐвåÈëÊý¾ÝµÄ²Ù×÷¡£
BEGIN TRAN t
INSERT INTO Customer
SELECT 'a','a'
2. Ö´ÐÐÒ»Ìõ²éѯÓï¾ä¡£
SELECT * from Customer WITH (NOLOCK)
½á¹ûÖÐÏÔʾ"a"ºÍ"a"¡£µ±1ÖÐÊÂÎñ»Ø¹öºó£¬ÄÇôa½«³ÉΪÔàÊý¾Ý¡£(×¢:1ÖеÄÊÂÎñδÌá½») ¡£NOLOCK±íÃ÷ûÓжÔÊý¾Ý±íÌí¼Ó¹²Ï ......
×Ó²éѯÊÇÔÚÒ»¸ö²éѯÄڵIJéѯ¡£×Ó²éѯµÄ½á¹û±»DBMSʹÓÃÀ´¾ö¶¨°üº¬Õâ¸ö×Ó²éѯµÄ¸ß¼¶²éѯµÄ½á¹û¡£ÔÚ×Ó²éѯµÄ×î¼òµ¥µÄÐÎʽÖУ¬×Ó²éѯ³ÊÏÖÔÚÁíÒ»ÌõSQLÓï¾äµÄWHERE»òHAVING×Ó¾ÖÄÚ¡£
ÁгöÆäÏúÊÛÄ¿±ê³¬¹ý¸÷¸öÏúÊÛÈËÔ±¶¨¶î×ۺϵÄÏúÊ۵㡣
SELECT CITY
from OFFICES
WHERE TARGET&nbs ......
1.select * from A where a.a='a';
Ö´ÐÐ˳Ðò ÏÈÖ´ÐÐ from ÔÚÖ´ÐÐ where ÖеĶ«Î÷ £¬×îºóÖ´ÐÐ select
2.ÁÐÖµÁ¬½Ó db2 oracle || , mysql concat(column1,'sss',column2) sqlServlerʹÓÃ+Á¬½Ó;
3. case when ±í´ïʽ then ''
  ......
1.¶àwhere£¬ÉÙhaving
whereÓÃÀ´¹ýÂËÐУ¬havingÓÃÀ´¹ýÂË×é
2.¶àunion all£¬ÉÙunion
unionɾ³ýÁËÖØ¸´µÄÐУ¬Òò´Ë»¨·ÑÁËһЩʱ¼ä
3.¶àExists£¬ÉÙin
ExistsÖ»¼ì²é´æÔÚÐÔ£¬ÐÔÄܱÈinÇ¿ºÜ¶à£¬ÓÐЩÅóÓѲ»»áÓÃExists£¬¾Í¾Ù¸öÀý×Ó
Àý£¬ÏëÒªµÃµ½Óе绰ºÅÂëµÄÈ˵Ļù±¾ÐÅÏ¢£¬table2ÓÐÈßÓàÐÅÏ¢
select * from table1;--(id,n ......