mysql explainÖеÄusing filesort
Using filesort±íʾÔÚË÷ÒýÖ®Í⣬ÐèÒª¶îÍâ½øÐÐÍⲿµÄÅÅÐò¶¯×÷¡£µ¼Ö¸ÃÎÊÌâµÄÔÒòÒ»°ãºÍorder byÓÐÕßÖ±½Ó¹ØÏµ£¬Ò»°ã¿ÉÒÔͨ¹ýºÏÊʵÄË÷ÒýÀ´¼õÉÙ»òÕß±ÜÃâ¡£
explain SELECT * from table_item WHERE user_id = 2 ORDER BY item_id LIMIT 0, 5
user_id ºÍ item_id ·Ö±ð½¨Á¢Ò»¸öË÷Òý£¬¶Ô´ËÓï¾äMySQLÑ¡ÔñÁË user_idË÷Òý£¬ÄÇô item_id µÄË÷ÒýûÓÐÆðµ½ÈκÎÓô¦¡£µ±ÅÅÐòʱ¼Ç¼Êý½Ï¶à£¬ÄÚ´æÖеÄÅÅÐò bufferÂúÁË£¬Ö»ÄÜ Using filesort ½øÐÐÍⲿÅÅÐò¡£
½â¾ö·½Ê½Îª¶ÔÕâÁ½Áн¨Á¢×éºÏË÷Òý¡£
explain SELECT * from table_item WHERE user_id = 2 and user_age > 20 ORDER BY item_id LIMIT 0, 5
½¨Á¢×éºÏË÷Òý£¨user_id, user_age, item_id£©£¬¿´ËƷdz£ÍêÃÀ¡£µ«ÓÉÓÚuser_age¹æÔò²»ÊÇÈ·¶¨Öµ£¬Ê¹ÓøÃ×éºÏË÷ÒýµÄ»°Êµ¼ÊÉÏÐèÒªÏȰ´Ë÷ÒýÕÒ³öÒ»¸ö¸öuser_ageÏµĶ«Î÷ºóÔÙ¶ÔÆä½øÐÐÅÅÐò£¬ÈÔÈ»»áfilesort¡£
½â¾ö·½Ê½ÊÇʹÓÃ×éºÏË÷Òý£¨user_id, item_id£©£¬¶ÔÅÅÐòºÃµÄitem_idÔÙ¹ýÂ˵½²»Âú×ãuser_age > 20µÄÌõÄ¿£¬²»»á³öÏÖfilesort¡£
explain SELECT * from table_item WHERE user_id = 2 ORDER BY item_attr desc, item_id LIMIT 0, 5
½¨Á¢ÁË×éºÏË÷Òý£¨user_id, item_attr, item_id)£¬ÒòΪitem_attrÊǽµÐò¶øitem_idÊÇÉýÐò£¬´Ó¶øÈÔÈ»ÐèÒªÍⲿÅÅÐò¡£
Èç¹ûitem_attrºÍitem_id¶¼ÊÇÉýÐò»òÕß¶¼ÊǽµÐò£¬Ôò²»»á³öÏÖfilesort£»½¨Á¢×éºÏË÷Òý£¨user_id, item_attr desc, item_id)ÏÖÏóÒÀ¾É¡£
Mysql5.1ÔÚÏßÎĵµ“13.1.4. CREATE INDEXÓï·¨”ÖÐÌáµ½£º“Ò»¸öindex_col_name¹æÔ¼¿ÉÒÔÒÔASC»òDESCΪ½áβ¡£ÕâЩ¹Ø¼ü´Ê½«À´¿ÉÒÔÀ©Õ¹£¬ÓÃÓÚÖ¸¶¨µÝÔö»òµÝ¼õË÷ÒýÖµ´æ´¢¡£Ä¿Ç°£¬ÕâЩ¹Ø¼ü´Ê±»·ÖÎö£¬µ«ÊDZ»ºöÂÔ£»Ë÷ÒýÖµ¾ùÒÔµÝÔö˳Ðò´æ´¢¡£”
¿ÉÒÔ¿´³öÎÞ·¨Í¨¹ýÐÞ¸ÄË÷ÒýÀ´±ÜÃâÕâ¸öfilesort£¬Ö»ÄÜÊÇÈç¹û¿ÉÄܵϰÐ޸IJéѯµÄÅÅÐòÌõ¼þ¡£
Ïà¹ØÎĵµ£º
¶ÔmysqlµÄÓÅ»¯²»ÔÚÐУ¬¸ã¹ý¼¸´ÎÓÅ»¯£¬µ«ÊǶ¼²»ÊǺÜÀíÏ룬»¹ÊÇÀË·Ñ×ÊÔ´Ì«¶à¡£Ò»Ö±·¢ÏÖÎÒµÄmysqlµÄ»º´æÃüÖÐÂʼ«²î£¬Çé¿öÁ¼ºÃµÄʱºòµ½´ï¹ý60-70%£¬µ«ÊÇÔËÐÐʱ¼äÒ»³¤£¬Ö»ÓÐ10-20%¡£²éÁËһЩ×ÊÁÏ£¬¹ØÓÚ»º´æµÄһЩ²ÎÊý¼Ç¼
mysql> SHOW VARIABLES LIKE ‘%query_cache%’;
+—————&m ......
MySQL´æ´¢¹ý³ÌµÄ²ÎÊýÓÃÔÚ´æ´¢¹ý³ÌµÄ¶¨Ò壬¹²ÓÐÈýÖÖ²ÎÊýÀàÐÍ,IN,OUT,INOUT,ÐÎʽÈ磺
CREATE PROCEDURE([[IN |OUT |INOUT ] ²ÎÊýÃû Êý¾ÝÀàÐÎ...])
1¡¢IN ÊäÈë²ÎÊý:±íʾ¸Ã²ÎÊýµÄÖµ±ØÐëÔÚµ÷Óô洢¹ý³Ìʱָ¶¨£¬ÔÚ´æ´¢¹ý³ÌÖÐÐ޸ĸòÎÊýµÄÖµ²»Äܱ»·µ»Ø£¬ÎªÄ¬ÈÏÖµ
2¡¢OUT Êä³ö²ÎÊý:¸ÃÖµ¿ÉÔÚ´æ´¢¹ý³ÌÄÚ²¿±»¸Ä±ä£¬²¢¿É·µ»Ø
3¡¢I ......
Mysql ´æ´¢Àý³ÌµÄʹÓÃ
Ò»¡¢ ¼ò½é
´æ´¢¹ý³Ì£¨Stored Procedure£©ÊÇÒ»×éΪÁËÍê³ÉÌØ¶¨¹¦ÄܵÄSQLÓï¾ä¼¯£¬¾±àÒëºó´æ´¢ÔÚÊý¾Ý¿âÖС£Óû§Í¨¹ýÖ¸¶¨´æ´¢¹ý³ÌµÄÃû×Ö²¢¸ø³ö²ÎÊý£¨Èç¹û¸Ã´æ´¢¹ý³Ì´øÓвÎÊý£©À´Ö´ÐÐËü¡£´æ´¢¹ý³Ì ÊÇÊý¾Ý¿âÖеÄÒ»¸öÖØÒª¶ÔÏó£¬ÈκÎÒ»¸öÉè¼ÆÁ¼ºÃµÄ ......
ʹÓÃant¹¤¾ß±àÒë³ÌÐò£¬ÔËÐгÌÐò.ÃüÁî:ant -f xxx.xmlÖ¸¶¨Éú³ÉÎļþ£»ant run±àÒë²¢ÔËÐÐÎļþ¡£
Èç¹ûHibernate½«ÖÐÎIJåÈëmysqlÊý¾Ý¿â£¬µ÷ÓÃselectÓï¾äÖÐÎÄÏÔʾÂÒÂ룬ÔòmysqlµÄ±àÂ뷽ʽÉèΪgbk£¬×¢ÒâÕâÀïÊÇСд£¬²»ÓÃÖØÐ°²×°mysqlÊý¾Ý¿â£¬½«MySQL Server 5.1Ŀ¼ÏµÄmy.iniÅäÖÃÎļþÀïµÄËùÓÐdefault-character-setÉèΪgbk£¬× ......