MySQLÖÐÓÃselectʵÏÖTOP N¹¦ÄÜ
ÏÈ˵¼¸¸ö¹Ø¼ü×Ö£º
distinct ·µ»Ø²»Öظ´µÄ¶àÁÐ
count() ¼ÆÊý
limit m,n µÚm¸öÆðn¸ö
ÄÇô£¬Èç¹ûÐèÒª²éÕÒÃûΪcolµÄijһ¸öÁеÄTop N£¬²¢Áгö¶ÔÓ¦µÄÖµµÄselectÓï¾ä¾ÍÈçÏ£º
select dinstinct(col),count(col) from tablename group by 1 order by 2 desc limit 0,N;
......
MYSQL³£ÓÃÃüÁîÁбí
1¡¢ÏµÍ³¹ÜÀí
mysql -hÖ÷»úµØÖ· -uÓû§Ãû -p
Á¬½ÓMYSQL£¨ÔÚmysql/bin£©
exit
Í˳öMYSQLÃüÁî
mysqladmin -uÓû§Ãû -p¾ÉÃÜÂë passwordÐÂÃÜÂë
ÐÞ¸ÄÃÜÂ루ÔÚmysql/bin£©
grantselect[insert][,update][,delete]onÊý¾Ý¿â.*toÓû§Ãû@localhost£¨"%"£¬ ±íʾÈκÎÖ÷»ú£©identifiedby "ÃÜÂë"
Ôö¼ÓÓû§
mysqldump –u root –p optÊý¾Ý¿âÃû>±¸·ÝÎļþÃû
±¸·ÝÊý¾Ý¿â£¨ÔÚmysql/bin£©
mysql –u root –p < batch file £¨ÀýÈ籸·ÝÎļþÃû£©
ʹÓÃÅú´¦Àí
mysql.server start
Æô¶¯·þÎñÆ÷
mysql.server stop
Í£Ö¹·þÎñÆ÷
msql.server log
2¡¢²éѯÃüÁî
select version()
²éѯ°æ±¾ºÅ
select current_date
²éѯµ±Ç°ÈÕÆÚ
3¡¢ÏÔʾÃüÁî
show databases
ÏÔʾÊý¾Ý¿âÁбí
show tables ÏÔʾ¿âÖеÄÊý¾Ý±í
describe ±íÃû ÏÔʾÊý¾Ý±íµÄ½á¹¹
select * from ±íÃû ÏÔʾ±íÖеļǼ
select what_to_select from which table [whereconditions_to_satisfy and (or) where conditions_to_satisfy] ´ÓÒ»¸ö±íÖмìË÷Êý¾Ý¡ºÂú×ãÌõ¼þ¡»
select ×Ö¶Î1,×Ö¶Î2,… from ± ......
mysql·þÎñÆ÷°²×°ÅäÖãº
1. sudp apt-get install mysql-server-5.0
2. ´´½¨¿âsecond_proxy, ΪsecProxyÌí¼ÓÓû§£ºgrant all privileges on second_proxy.* to secProxy@'%' identified by 'passwd';
3. ÉèÖÃmysql.user±íÈçÏ£º
+-----------+------------------+-------------------------------------------+
| Host | User | Password |
+-----------+------------------+-------------------------------------------+
| % | root | *D0CC270F9B91B4CF3D13B5D56E1E52A9F7C001B1 |
| localhost | debian-sys-maint | *F6484D4F45B78E2CE99845B5D54DED451834E427 |
| % ......
mysql ibdata1ÎļþµÄËõС(2009-12-22 15:29:46)
±êÇ©£ºit
mysql ibdata1´æ·ÅÊý¾Ý£¬Ë÷ÒýµÈ£¬ÊÇMYSQLµÄ×îÖ÷ÒªµÄÊý¾Ý¡£
Èç¹û²»°ÑÊý¾Ý·Ö¿ª´æ·ÅµÄ»°£¬Õâ¸öÎļþµÄ´óСºÜÈÝÒ×¾ÍÉÏÁËG£¬ÉõÖÁ10+G¡£¶ÔÓÚijЩӦÓÃÀ´Ëµ£¬²¢²»ÊÇÌ«ºÏÊÊ¡£Òò´ËÒª°Ñ´ËÎļþËõС¡£
·½·¨£ºÊý¾ÝÎļþµ¥¶À´æ·Å¡£
²½Ö裺
1£¬±¸·ÝÊý¾Ý¿â
´ÓÃüÁîÐнøÈëMySQL Server 5.0\bin
±¸·ÝÈ«²¿Êý¾Ý¿â£¬Ö´ÐÐÃüÁîmysqldump -q -uusername -pyourpassword --add-drop-table -all-databases > /all.sql
×öÍê´Ë²½ºó£¬Í£Ö¹Êý¾Ý¿â·þÎñ¡£
2£¬ÐÞ¸ÄmysqlÅäÖÃÎļþ
ÐÞ¸Ämy.iniÎļþ£¬Ôö¼ÓÏÂÃæÅäÖÃ
innodb_file_per_table
¶ÔÿÕűíʹÓõ¥¶ÀµÄinnoDBÎļþ, ÐÞ¸Ä/etc/my.cnfÎļþ
3£¬É¾³ýÔÊý¾ÝÎļþ
ɾ³ýÔÀ´µÄibdata1Îļþ¼°ÈÕÖ¾Îļþib_logfile*£¬É¾³ýdataĿ¼ÏµÄÓ¦ÓÃÊý¾Ý¿âÎļþ¼Ð(mysqlÎļþ¼Ð²»ÒªÉ¾)
4£¬»¹ÔÊý¾Ý¿â
Æô¶¯Êý¾Ý¿â·þÎñ
´ÓÃüÁîÐнøÈëMySQL Server 5.0\bin
»¹ÔÈ«²¿Êý¾Ý¿â£¬Ö´ÐÐÃüÁîmysql -uusername -pyourpassword < /all.sql
¾¹ýÒÔÉϼ¸²½ºó£¬¿ÉÒÔ¿´µ½ÐµÄibdata1Îļþ¾ÍÖ»Óм¸Ê®MÁË£¬Êý¾Ý¼°Ë÷Òý¶¼±ä³ÉÁËÕë¶Ôµ¥¸ö±íµÄСibdÎļþÁË£¬ËüÃÇÔÚÏàÓ¦Êý¾Ý¿âµÄÎļþ¼ÐÏÂÃæ¡£
......
ÓÃrpm°ü°²×°µÄMySQLÊDz»»á°²×°/etc/my.cnfÎļþµÄ£¬
ÖÁÓÚΪʲôûÓÐÕâ¸öÎļþ¶øMySQLÈ´Ò²ÄÜÕý³£Æô¶¯ºÍ×÷Óã¬ÔÚµãÓÐÁ½¸ö˵·¨£¬
µÚÒ»ÖÖ˵·¨£¬my.cnfÖ»ÊÇMySQLÆô¶¯Ê±µÄÒ»¸ö²ÎÊýÎļþ£¬¿ÉÒÔûÓÐËü£¬ÕâʱMySQL»áÓÃÄÚÖõÄĬÈϲÎÊýÆô¶¯£¬
µÚ¶þÖÖ˵·¨£¬MySQLÔÚÆô¶¯Ê±×Ô¶¯Ê¹ÓÃ/usr/share/mysqlĿ¼ÏµÄmy-medium.cnfÎļþ£¬ÕâÖÖ˵·¨½öÏÞÓÚrpm°ü°²×°µÄMySQL£¬
½â¾ö·½·¨£¬Ö»ÐèÒª¸´ÖÆÒ»¸ö/usr/share/mysqlĿ¼ÏµÄ.cnfÎļþµ½/etcĿ¼£¬²¢¸ÄÃûΪmy.cnf¼´¿É¡£ ......
ÓÃrpm°ü°²×°µÄMySQLÊDz»»á°²×°/etc/my.cnfÎļþµÄ£¬
ÖÁÓÚΪʲôûÓÐÕâ¸öÎļþ¶øMySQLÈ´Ò²ÄÜÕý³£Æô¶¯ºÍ×÷Óã¬ÔÚµãÓÐÁ½¸ö˵·¨£¬
µÚÒ»ÖÖ˵·¨£¬my.cnfÖ»ÊÇMySQLÆô¶¯Ê±µÄÒ»¸ö²ÎÊýÎļþ£¬¿ÉÒÔûÓÐËü£¬ÕâʱMySQL»áÓÃÄÚÖõÄĬÈϲÎÊýÆô¶¯£¬
µÚ¶þÖÖ˵·¨£¬MySQLÔÚÆô¶¯Ê±×Ô¶¯Ê¹ÓÃ/usr/share/mysqlĿ¼ÏµÄmy-medium.cnfÎļþ£¬ÕâÖÖ˵·¨½öÏÞÓÚrpm°ü°²×°µÄMySQL£¬
½â¾ö·½·¨£¬Ö»ÐèÒª¸´ÖÆÒ»¸ö/usr/share/mysqlĿ¼ÏµÄ.cnfÎļþµ½/etcĿ¼£¬²¢¸ÄÃûΪmy.cnf¼´¿É¡£ ......
֮ǰ£¬Ò»Ö±À§ÄպܾõÄMySQLµÄÎÊÌâÒòΪÓÐÁËtcmallocºóµÃÒÔ½â¾ö¡£
ÎÊÌâÊÇ£ºÍøÕ¾·ÃÎÊÁ¿²»¸ß£¬¸ß·åʱ²¢·¢ÊýÔÚ300-400Ö®¼ä¡£CPU±È½Ï¸ß£¬ÔÚ30-80%Ö®¼ä²¨¶¯µÃÀ÷º¦£¬Ê¹ÓÃtopÃüÁî¿ÉÒÔ¿´µ½ÊÇmysql½ø³Ìµ¼Ö£¬Í¬Ê±ÓÃiostatºÍsar²é¿´iowaitÖµºÜ¸ßÔÚ20-30Ö®¼ä¡£
µ«ÊÇϵͳ»¹¿ÉÒÔÎȶ¨ÔËÐУ¬È»ºóÖÜÆÚÐԵijöÏÖswap·ÖÇøÕ¼ÓÃÂÊÅÊÉý£¬Ö±½Óµ¼ÖÂÓ¦ÓóÌÐòÎÞ·¨Á¬½ÓÊý¾Ý¿â¡£²»ÖªµÀÕâÊDz»ÊÇmysqlµÄswapµßô¤µÄÎÊÌ⡣û½â¾ö°ì·¨µÄʱºòÖ»ºÃ¾³£¼à¿ØÄÚ´æµÄʹÓÃÇé¿ö£¬Åöµ½swap¿ªÊ¼ÅÊÉýµÄʱºòÖØÆôMySQL·þÎñ¡£Ò»°ãÕâ¸öÖÜÆÚÔÚÒ»¸öÐÇÆÚ×óÓÒ¡£
ºóÀ´ÔÚÍøÉÏËѵ½ÁËtcmalloc£¬ËµÊÇÕâ¸ö¶«Î÷¿ÉÒÔÈÃMySQLÔڸ߲¢·¢ÏÂÐÔÄÜÒ²ºÜÎȶ¨£¬Í¬Ê±Ò²ËµÁËMySQLÕâ¸öÎÊÌâÊÇÒòΪmallocÄÚ´æ·ÖÅ亯ÊýµÄbug£¬Õâ¸öbug»áʹ¸ß²¢·¢µÄMySQLÐÔÄܼ±¾çϽµ¡£
¾ö¶¨ÊÔÊÔ¡£
ϵͳÊÇ64λµÄRedHat Enterprise Linux 5.0 ¡£ÔÚ64λϵͳÏÂÐèÒª°²×°ÁíÍâÒ»¸ö°ülibunwind¡£È»ºóÏÂÔØtcmalloc°ü£¬°´Ä¬ÈÏ·½Ê½±àÒëºÍ°²×°³É¹¦ºóÔÚ mysqld_safe ÖмÓÈë
LD_PRELOAD="/usr/local/lib/libtcmalloc.so"
ÖØÆôMySQL¡£Ã»Óа취¿ÉÒÔÑéÖ¤tcmallocÊÇ·ñÆðЧ£¬Ö»ÄÜÔÙ¼ÌÐø¼à¿ØÏµÍ³µÄÔËÐÐ×´¿ö¡£
¾¹ýÒ»¸ö¶àÀñ°ÝÁË£¬Äã¿ÉÒÔ¿´¿´ÏÂÃæÒ»¸ö×¥×ÔmrtgµÄͼ£º
ÉÏÃæÁ½¸öͼÖУ¬µÚ ......
֮ǰ£¬Ò»Ö±À§ÄպܾõÄMySQLµÄÎÊÌâÒòΪÓÐÁËtcmallocºóµÃÒÔ½â¾ö¡£
ÎÊÌâÊÇ£ºÍøÕ¾·ÃÎÊÁ¿²»¸ß£¬¸ß·åʱ²¢·¢ÊýÔÚ300-400Ö®¼ä¡£CPU±È½Ï¸ß£¬ÔÚ30-80%Ö®¼ä²¨¶¯µÃÀ÷º¦£¬Ê¹ÓÃtopÃüÁî¿ÉÒÔ¿´µ½ÊÇmysql½ø³Ìµ¼Ö£¬Í¬Ê±ÓÃiostatºÍsar²é¿´iowaitÖµºÜ¸ßÔÚ20-30Ö®¼ä¡£
µ«ÊÇϵͳ»¹¿ÉÒÔÎȶ¨ÔËÐУ¬È»ºóÖÜÆÚÐԵijöÏÖswap·ÖÇøÕ¼ÓÃÂÊÅÊÉý£¬Ö±½Óµ¼ÖÂÓ¦ÓóÌÐòÎÞ·¨Á¬½ÓÊý¾Ý¿â¡£²»ÖªµÀÕâÊDz»ÊÇmysqlµÄswapµßô¤µÄÎÊÌ⡣û½â¾ö°ì·¨µÄʱºòÖ»ºÃ¾³£¼à¿ØÄÚ´æµÄʹÓÃÇé¿ö£¬Åöµ½swap¿ªÊ¼ÅÊÉýµÄʱºòÖØÆôMySQL·þÎñ¡£Ò»°ãÕâ¸öÖÜÆÚÔÚÒ»¸öÐÇÆÚ×óÓÒ¡£
ºóÀ´ÔÚÍøÉÏËѵ½ÁËtcmalloc£¬ËµÊÇÕâ¸ö¶«Î÷¿ÉÒÔÈÃMySQLÔڸ߲¢·¢ÏÂÐÔÄÜÒ²ºÜÎȶ¨£¬Í¬Ê±Ò²ËµÁËMySQLÕâ¸öÎÊÌâÊÇÒòΪmallocÄÚ´æ·ÖÅ亯ÊýµÄbug£¬Õâ¸öbug»áʹ¸ß²¢·¢µÄMySQLÐÔÄܼ±¾çϽµ¡£
¾ö¶¨ÊÔÊÔ¡£
ϵͳÊÇ64λµÄRedHat Enterprise Linux 5.0 ¡£ÔÚ64λϵͳÏÂÐèÒª°²×°ÁíÍâÒ»¸ö°ülibunwind¡£È»ºóÏÂÔØtcmalloc°ü£¬°´Ä¬ÈÏ·½Ê½±àÒëºÍ°²×°³É¹¦ºóÔÚ mysqld_safe ÖмÓÈë
LD_PRELOAD="/usr/local/lib/libtcmalloc.so"
ÖØÆôMySQL¡£Ã»Óа취¿ÉÒÔÑéÖ¤tcmallocÊÇ·ñÆðЧ£¬Ö»ÄÜÔÙ¼ÌÐø¼à¿ØÏµÍ³µÄÔËÐÐ×´¿ö¡£
¾¹ýÒ»¸ö¶àÀñ°ÝÁË£¬Äã¿ÉÒÔ¿´¿´ÏÂÃæÒ»¸ö×¥×ÔmrtgµÄͼ£º
ÉÏÃæÁ½¸öͼÖУ¬µÚ ......