MySQL·ÖÇø£¨Partition£©¹¦ÄÜÊÔÑé
MySQL·ÖÇø£¨Partition£©¹¦ÄÜÊÔÑé2008-07-06 20:02Ŀ¼
[¸ÅÊö]
[·ÖÇø±íºÍδ·ÖÇø±íÊÔÑé¹ý³Ì]
[·ÖÇøÃüÁîÏê½â]
[¸ÅÊö]
×Ô5.1¿ªÊ¼¶Ô·ÖÇø(Partition)ÓÐÖ§³Ö£¬6.0Ó¦±È½ÏÎȶ¨
= ˮƽ·ÖÇø£¨¸ù¾ÝÁÐÊôÐÔ°´Ðз֣©=
¾Ù¸ö¼òµ¥Àý×Ó£ºÒ»¸ö°üº¬Ê®Ä귢Ʊ¼Ç¼µÄ±í¿ÉÒÔ±»·ÖÇøÎªÊ®¸ö²»Í¬µÄ·ÖÇø£¬Ã¿¸ö·ÖÇø°üº¬µÄÊÇÆäÖÐÒ»ÄêµÄ¼Ç¼¡£
=== ˮƽ·ÖÇøµÄ¼¸ÖÖģʽ£º===
* Range£¨·¶Î§£© – ÕâÖÖģʽÔÊÐíDBA½«Êý¾Ý»®·Ö²»Í¬·¶Î§¡£ÀýÈçDBA¿ÉÒÔ½«Ò»¸ö±íͨ¹ýÄê·Ý»®·Ö³ÉÈý¸ö·ÖÇø£¬80Äê´ú£¨1980's£©µÄÊý¾Ý£¬90Äê´ú£¨1990's£©µÄÊý¾ÝÒÔ¼°ÈκÎÔÚ2000Ä꣨°üÀ¨2000Ä꣩ºóµÄÊý¾Ý¡£
* Hash£¨¹þÏ££© – ÕâÖÐģʽÔÊÐíDBAͨ¹ý¶Ô±íµÄÒ»¸ö»ò¶à¸öÁеÄHash Key½øÐмÆË㣬×îºóͨ¹ýÕâ¸öHashÂ벻ͬÊýÖµ¶ÔÓ¦µÄÊý¾ÝÇøÓò½øÐзÖÇø£¬¡£ÀýÈçDBA¿ÉÒÔ½¨Á¢Ò»¸ö¶Ô±íÖ÷¼ü½øÐзÖÇøµÄ±í¡£
* Key£¨¼üÖµ£© – ÉÏÃæHashģʽµÄÒ»ÖÖÑÓÉ죬ÕâÀïµÄHash KeyÊÇMySQLϵͳ²úÉúµÄ¡£
* List£¨Ô¤¶¨ÒåÁÐ±í£© – ÕâÖÖģʽÔÊÐíϵͳͨ¹ýDBA¶¨ÒåµÄÁбíµÄÖµËù¶ÔÓ¦µÄÐÐÊý¾Ý½øÐзָÀýÈ磺DBA½¨Á¢ÁËÒ»¸öºá¿çÈý¸ö·ÖÇøµÄ±í£¬·Ö±ð¸ù¾Ý2004Äê2005ÄêºÍ2006ÄêÖµËù¶ÔÓ¦µÄÊý¾Ý¡£
* Composite£¨¸´ºÏģʽ£© - ºÜÉñÃØ°É£¬¹þ¹þ£¬ÆäʵÊÇÒÔÉÏģʽµÄ×éºÏʹÓöøÒÑ£¬¾Í²»½âÊÍÁË¡£¾ÙÀý£ºÔÚ³õʼ»¯ÒѾ½øÐÐÁËRange·¶Î§·ÖÇøµÄ±íÉÏ£¬ÎÒÃÇ¿ÉÒÔ¶ÔÆäÖÐÒ»¸ö·ÖÇøÔÙ½øÐÐhash¹þÏ£·ÖÇø¡£
= ´¹Ö±·ÖÇø£¨°´Áз֣©=
¾Ù¸ö¼òµ¥Àý×Ó£ºÒ»¸ö°üº¬ÁË´ótextºÍBLOBÁÐµÄ±í£¬ÕâЩtextºÍBLOBÁÐÓÖ²»¾³£±»·ÃÎÊ£¬Õâʱºò¾ÍÒª°ÑÕâЩ²»¾³£Ê¹ÓõÄtextºÍBLOBÁË»®·Öµ½ÁíÒ»¸ö·ÖÇø£¬ÔÚ±£Ö¤ËüÃÇÊý¾ÝÏà¹ØÐÔµÄͬʱ»¹ÄÜÌá¸ß·ÃÎÊËÙ¶È¡£
[·ÖÇø±íºÍδ·ÖÇø±íÊÔÑé¹ý³Ì]
*´´½¨·ÖÇø±í,°´ÈÕÆÚµÄÄê·Ý²ð·Ö
mysql> CREATE TABLE part_tab ( c1 int default NULL, c2 varchar(30) default NULL, c3 date default NULL) engine=myisam
PARTITION BY RANGE (year(c3)) (PARTITION p0 VALUES LESS THAN (1995),
PARTITION p1 VALUES LESS THAN (1996) , PARTITION p2 VALUES LESS THAN (1997) ,
PARTITION p3 VALUES LESS THAN (1998) , PARTITION p4 VALUES LESS THAN (1999) ,
PARTITION p5 VALUES LESS THAN (2000) , PARTITION p6 VALUES LESS THAN (2001) ,
PARTITION p7 VALUES LESS THAN (2002) , PARTITION p8 VALUES LESS THAN (2003) ,
PARTITION p9 VALUES LESS THAN (2004) , PARTITION p10 VALUES LESS THAN (2010),
PARTITION p11 VALUES LESS THAN MAXVAL
Ïà¹ØÎĵµ£º
×Ö¶ÎpageNum
1£¬6£¬9£¬11
Ï£ÍûÅÅÐò˳ÐòΪ1£¬6£¬9£¬11
µ«ÊÇʵ¼ÊÅÅÐòΪ1£¬11£¬6£¬9
ºóÀ´·¢ÏÖÊÇÒòΪpageNumÕâ¸ö×Ö¶ÎÊÇvarcharÀàÐ͵IJ»ÊÇintÐÍ£¬ËùÒÔÅÅÐò»á³öÎÊÌâ¡£
ÍøÉϵĽâ¾ö·½·¨Îª
order by pageNum+0
order by pageNum×1
²»ÖªµÀΪʲôorder by pageNum×1 Êý¾Ý¿âͨ²»¹ý
µ«ÊÇpageNum+0ÊǺÃÓÃµÄ ......
½øÈëcmd
===================
1.µ¼³öÊý¾Ý¿â£¨sql½Å±¾£©
mysqldump -u Óû§Ãû -p Êý¾Ý¿âÃû > µ¼³öµÄÎļþÃû
¡¡¡¡mysqldump -u root -p db_name > test_db.sql
¡¡¡¡2.mysqlµ¼³öÊý¾Ý¿âÒ ......
Ò»¡¢´ÓÄÄÀïÈëÊÖ
µ±Ò»Ì¨MYSQL·þÎñÆ÷´î½¨Íê³É²¢¿ÉÒÔÕý³£ÔËÐÐʱ£¬ÊDz»ÊÇÎÒÃǵĽŲ½¾ÍÍ£Ö¹ÁË£¬×ÔÒÔΪ¿ÉÒÔ¿ªÊ¼Ê¹ÓÃÁË£¬¶ÔרҵÈËÊ¿À´ËµÆäʵ»¹ÐèÒª¸ü¶àµÄÏà¹ØÓÅ»¯ºÍÉèÖá£ÔõôȥÓÅ»¯£¿ÔõôȥÉèÖã¿Ê×ÏÈÎÒÃǵÃÕÒµ½ËüµÄÆ¿¾±£¬ÎÒÏÖÔÚËùÁ˽âµÄÓÐÁ½ÖÖ·½·¨£¬Ò»ÊÇ»ù×¼²âÊÔ£¬¶þ¾ÍÊdzÌÐò·ÖÎö£¬ËûÃÇÓÐ×ÅÃÜÇеÄÁªÏµ ......
MySQL±¸·Ý»¹ÔÊý¾Ý¿âÅú´¦Àí
ÔÚÈÕ³£¹¤×÷ÖУ¬ÎÒÃÇÍùÍùÐèÒª¶ÔMySQLÊý¾Ý¿â½øÐб¸·Ý£¬ÓÐʱ¿ÉÒÔͨ¹ý¿½±´Õû¸öÎļþ£¬ÓÐʱͨ¹ý±¸·ÝÕû¸ö¿â»¹ÓеÄʱºòÎÒÃǾÍÖ»ÐèÒª±¸·Ýij¸ö±í¡£
1¡¢±¸·ÝÊý¾Ý¿â(µ¥¸ö±í±¸·Ý) bk_table.bat
mysqldump -h127.0.0.1 -P3306 -uroot -proot --default-character-set=gbk -t database1 table1>tabl ......
¸´ÖƼǼ,²ÉÓÃ×Ô²éѯ·½Ê½
sql
INSERT INTO `table` ('id','aa','bb','cc') SELECT 'id','aa','bb','cc' from `table` (WHERE .....)
Tips:
/**
* ¸´ÖÆÐ¼Í¼µÄʱºò,¿ÉÄÜÒª¸üÐÂid»òÕßÊDz¿·ÖÊý¾Ý(¼ÙÉèid×ÔÔö¼ÓµÄÇé¿ö)
*
* text_aa Ϊ¹Ì¶¨Öµ ,¿ÉÔڽű¾µ÷ÓÃÖи³±äÁ¿Öµ Èç($aa)
* ×¢Òâ'text_aa' Óë `cc` µÄÇø±ð ......