ÓÃSQL Server±£³Ö»á»°×´Ì¬
ÔÚµ÷Ó÷þÎñÆ÷ºóÒª¼ÌÐøÔÚ·þÎñÆ÷Öб£ÁôÊý¾Ýͨ³£ºÜÄÑ£¬Äã¿ÉÒÔÓÃSQL ServerÀ´½øÐлỰ״̬¹ÜÀí(Óû§»á»°Êý¾Ý)¡£ÒÔϽÌÄãÔõÑùÓÃËüÀ´½øÐйÜÀí¡£
¡¡¡¡ÔÚÒ³Ã濪·¢ÖУ¬ÔÚ·þÎñÆ÷µ÷ÓÃÀï±£ÁôÊý¾ÝÊÇÒ»¸ö³£¼ûµÄ²»ºÃ½â¾öµÄÄÑÌâ¡£ÄãÒ²ÐíÐèҪΪÄãµÄÓ¦ÓóÌÐò»òÌØÊâÓû§µÄ»á»°±£´æÐÅÏ¢¡£´æ´¢ÕâÑùµÄÊý¾Ý±»³ÆΪ״̬¹ÜÀí£¬ASP.NETΪÄãÌṩÁËһЩ·½·¨£¬ÕâЩ·½·¨ÄÜÈÃÄãͨ¹ý¸÷ÖÖ;¾¶Íê³ÉÕâÒ»ÈÎÎñ¡£Õâ°üÀ¨½«Êý¾Ý´æ´¢ÔÚÒ»¸ö״̬·þÎñÆ÷µÄÄÚ´æÖУ¬»òÕßͨ¹ýMicrosoft SQL·þÎñÆ÷¡£±¾ÎÄÖ÷ÒªÌÖÂÛÁËÓÃSQL·þÎñÆ÷À´½øÐлỰ״̬¹ÜÀí(Óû§»á»°Êý¾Ý)¡£
¡¡¡¡ÎªÊ²Ã´ÐèÒª½øÐÐ״̬¹ÜÀí£¿
¡¡¡¡ÔÚÉèÖúÍʹÓÃSQL Server֮ǰ£¬ÄãÒ²Ðí»áÏëÓбØÒªÕâÑù×öÂð£¿Ò³Ã濪·¢»¹ÓиüÈÃÈË·³ÄÕµÄÒ»Ã棬ÄǾÍÊÇHTTPÊÇÒ»ÏîÎÞ״̬ÐÒé¡£ËüµÄÔËÐÐÊǶ϶ÏÐøÐøµÄ£¬Ã¿¸öÒ³Ã涼»á°´½ÓÊܵ½µÄÃüÁîÔËÐС£ÃüÁîÖ´ÐÐÍêÒÔºó£¬ËùÓÐÓùýµÄÊý¾Ý¶¼»á¶ªÊ§¡£·þÎñÆ÷²»»á´æ´¢¹ØÓÚÄÇЩµ÷ÓõÄÈκμÇÒä¡£Ò²¾ÍÊÇ˵£¬Ëü²»»á´æ´¢Ïà¹Ø¼ÇÒ䣬³ý·ÇÓÐÌØÊâµÄÖ¸ÁîÈÃËü´æ´¢¡£
¡¡¡¡»á»°±äÁ¿
¡¡¡¡ÒÔÏÂÊÇʹÓûỰ±äÁ¿µÄ¸ñʽ£º
C#: Session["variable_name"] = value;
VB.NET: Session("variable_name") = value
¡¡¡¡µ±Õâ¸öÖµ±»´æ´¢ÁË£¬Óû§¾Í¿ÉÒÔÔÚÕû¸ö»á»°ÖÐʹÓÃËüÁË¡£»á»°½áÊøºó£¬±äÁ¿Ò²¾Í¶ªÊ§ÁË¡£ÄãÒ²¿ÉÒÔʹÓûعé״̬¹ÜÀí(ÕâÊÇÎÒÃÇÏÂÒ»´ÎÒªÌÖÂ۵Ļ°Ìâ)À´´¦ÀíÕâЩ¶ªÊ§µÄÖµ¡£
¡¡¡¡ASP.NET״̬¹ÜÀí
¡¡¡¡ASP.NETÔÊÐíÄãͨ¹ýÒ»¸ö״̬·þÎñÆ÷»òSQL·þÎñÆ÷½«»á»°Êý¾Ý´æ´¢ÔÚÄÚ´æÖС£´æ´¢µÄλÖÃÓÉÓ¦ÓóÌÐòµÄÒ³ÃæÅäÖÃÎļþÀ´¾ö¶¨¡£×´Ì¬¹ÜÀíÑ¡ÏîÊÇÔÚϵͳÖеÄsessionStateÔªËØÖУ¬Ò³ÃæÔªËØÊÇÔÚ״̬¹ÜÀíÖнøÐÐÉèÖõġ£ÒÔϵÄʾÀýÏÔʾÁËÔõÑùʹÓÃSQL Server£º
£¼sessionState
mode="SQLServer"
stateConnectionString="tcpip=127.0.0.1:42424"
sqlConnectionString="data source=127.0.0.1; user id=username; password=password"
cookieless="false"
timeout="20" /£¾
¡¡¡¡×¢Ò⣬ÕâЩԪËصÄÃû³ÆºÍÊôÐÔ¶¼ÒªÇø·Ö´óСд¡£ÒÔÏÂÊǸÃģʽÊôÐԵĸ÷ÖÖ¿ÉÄÜÖµ£º
? InProc-´æ´¢ÔÚÄÚ´æÖС£ËüµÄÔËÐÐËÙ¶È×î¿ì£¬µ«Êǵ±ASP.NET³ÌÐòÖظ´ÔËÐеÄʱºòËùÓеÄÊý¾Ý¶¼»á¶ªÊ§¡£
? SQL Server-½«Êý¾Ý´æ´¢ÔÚSQL ServerÖС£ÓÉÓÚËüÓëÒ³Ãæ·þÎñÆ÷ÊÇ·ÖÀëµÄ£¬Òò´ËËüÊÇ×î¿ÉÐŵġ£Á¬½Ó×Ö·û´®»á°´ÕÕÕý³£µÄ˳ÐòÅÅÁУ¬ÒÔÁ¬½Óµ½SQL ServerÊý¾Ý¿âÖС£
? StateServer-½«Êý¾Ý´æ´¢ÔÚÒ»¸ö¶ÀÁ¢µÄÒ³Ãæ·þÎñÆ÷ÉÏ(IIS)¡£ÕâһѡÏîÀûÓÃÁËstateConnectionStringÕâÒ»ÊôÐÔ¡£
¡¡¡¡ËùÓеÄÑ¡ÏʹÓñ£
Ïà¹ØÎĵµ£º
Òѳɹ¦Óë·þÎñÆ÷½¨Á¢Á¬½Ó£¬µ«ÊÇÔڵǼǰµÄÎÕÊÖÆڼ䷢Éú´íÎóµÄ´¦Àí·½·¨
ÔÚÓÃSQL SERVER Óû§µÇ½SQL SERVER 2005ʱ£¬µ¯³öÒ»¸ö¶Ô»°¿ò£¬Ìáʾ" Òѳɹ¦Óë·þÎñÆ÷½¨Á¢Á¬½Ó£¬µ«ÊÇÔڵǼǰµÄÎÕÊÖÆڼ䷢Éú´íÎó",²éÕÒÁËÒ»ÏÂÔÒò£¬ÔÀ´ÊÇSQL SERVER 2005ʱ½ûÓÃTCP/IPµÇ½ÁË£¬´ò¿ªSQL SERVER 2005²Ë ......
¡¡¡¡ÈÕÇ°SQL INJECTIONµÄ¹¥»÷²âÊÔÓúÑÝÓúÁÒ£¬ºÜ¶à´óÐ͵ÄÍøÕ¾ºÍÂÛ̳¶¼Ïà¼Ì±»×¢Èë¡£ÕâЩÍøÕ¾Ò»°ãʹÓõĶàΪSQL SERVERÊý¾Ý¿â£¬ÕýÒòΪÈç´Ë£¬ºÜ¶àÈË¿ªÊ¼»³ÒÉSQL SERVERµÄ°²È«ÐÔ¡£ÆäʵSQL SERVER 2000ÒѾͨ¹ýÁËÃÀ¹úÕþ¸®µÄC2¼¶°²È«ÈÏÖ¤-ÕâÊǸÃÐÐÒµËùÄÜÓµÓеÄ×î¸ßÈÏÖ¤¼¶±ð£¬ËùÒÔʹÓÃSQL SERVER»¹ÊÇÏ൱µÄ°²È«µÄ¡£µ±È»ºÍORCAL¡¢DB2µ ......
µ±ÄãÕýÔÚ´¦Àí±»¶à¸öÕ¾µã£¨ÏñÔÚ¿ç¹ú¹«Ë¾Ìõ¼þÏ£©Ê¹ÓõĴóÊý¾Ý¿âʱ£¬ÄãÒ²Ðí»áÓöµ½±£Ö¤±í¸ñ¶ÔÏóΨһÐÔÕâÑùµÄ¼¬ÊÖÎÊÌâ¡£ÔÚÕâÖÖÇéÐÎÏ£¬¿ÉÄÜÖ»ÄÜ¿¿UNIQUEIDENTIFIERÀ´½â¾ö¡£UNIQUEIDENTIFIERÊÇÒ»¸ö±£´æÈ«¾ÖΨһ±êʶ·ûµÄGUIDÊý¾ÝÀàÐÍ¡£GUIDÊÇÒ»¸ö±£Ö¤Î¨Ò»µÄ¶þ½øÖÆÊý£¬Òò´Ë¼¸ºõûÓбðµÄ¼ÆËã»ú»á²úÉúͬһ¸öÖµ¡£
GUIDµÄΨһֵÊÇÓÉ¼Æ ......
1. ˵Ã÷£º¸´ÖƱí(Ö»¸´Öƽṹ£¬Ô´±íÃû£ºa£¬Ð±íÃû£ºb)
SQL: select * into b from a where 1<>1;
2. ˵Ã÷£º¿½±´±í(¿½±´Êý¾Ý£¬Ô´±íÃû£ºa£¬Ä¿±ê±íÃû£ºb)
SQL: insert into b(a, b, c) select d, e, f from b;
3. ......
ServerÊý¾Ý¿âÖÐʵÏÖ×îÓÅ×î¼òµÄÕû¸ö¹ý³Ì¡£
Ëã·¨ÊǼÆËã»ú¿ÆѧÖÐÒ»¸öÖØÒªµÄÑо¿·½Ïò£¬Êǽâ¾ö¸´ÔÓÎÊÌâµÄ¹Ø¼ü¡£ÔÚ¼ÆËã»úÊÀ½çÖУ¬Ëã·¨ÎÞ´¦²»ÔÚ¡£Êý¾Ý¿âÊÇ´æ´¢Êý¾ÝºÍÖ´ÐдóÅúÁ¿¼ÆËãµÄ³¡Ëù£¬ÔÚÊý¾Ý¿âÖÐʹÓÃһЩ¼òµ¥µÄSQLÃüÁ½øÐд洢¡¢²éѯ¡¢Í³¼Æ¡¢ÒÔ½â¾öÏÖʵÊÀ½çÖеÄÎÊÌâÒѾÊÇÂżû²»ÏÊ¡£Ëæ×ÅÊý¾ÝÁ¿µÄ´ó·ù¶ÈÔö¼ÓºÍÒµÎñ¹æ ......