Mysql·ÖÇø
http://dev.mysql.com/doc/refman/5.1/zh/partitioning.html
²é¿´ÊÇ·ñÖ§³Ö·ÖÇø£ºSHOW VARIABLES LIKE '%partition%';
·ÖÇøÓï¾äCREATE TABLE ti (id INT, amount DECIMAL(7,2), tr_date DATE)
ENGINE=INNODB
PARTITION BY HASH(MONTH(tr_date))
PARTITIONS 6;
------------------------------------------------------ÍøÉÏ
ˮƽ·ÖÇø£¨Horizontal Partitioning£© ÕâÖÖÐÎʽ·ÖÇøÊǶԱíµÄÐнøÐзÖÇø£¬Í¨¹ýÕâÑùµÄ·½Ê½²»Í¬·Ö×éÀïÃæµÄÎïÀíÁзָîµÄÊý¾Ý¼¯µÃÒÔ×éºÏ£¬´Ó¶ø½øÐиöÌå·Ö¸î£¨µ¥·ÖÇø£©»ò¼¯Ìå·Ö¸î£¨1¸ö»ò¶à¸ö·ÖÇø£©¡£ËùÓÐÔÚ±íÖж¨ÒåµÄÁÐÔÚÿ¸öÊý¾Ý¼¯Öж¼ÄÜÕÒµ½£¬ËùÒÔ±íµÄÌØÐÔÒÀÈ»µÃÒÔ±£³Ö¡£
´¹Ö±·ÖÇø£¨Vertical Partitioning£© ÕâÖÖ·ÖÇø·½Ê½Ò»°ãÀ´ËµÊÇͨ¹ý¶Ô±íµÄ´¹Ö±»®·ÖÀ´¼õÉÙÄ¿±ê±íµÄ¿í¶È£¬Ê¹Ä³Ð©Ìض¨µÄÁб»»®·Öµ½Ìض¨µÄ·ÖÇø£¬Ã¿¸ö·ÖÇø¶¼°üº¬ÁËÆäÖеÄÁÐËù¶ÔÓ¦µÄÐС£
¾Ù¸ö¼òµ¥Àý×Ó£ºÒ»¸ö°üº¬ÁË´ótextºÍBLOBÁÐµÄ±í£¬ÕâЩtextºÍBLOBÁÐÓÖ²»¾³£±»·ÃÎÊ£¬Õâʱºò¾ÍÒª°ÑÕâЩ²»¾³£Ê¹ÓõÄtextºÍBLOBÁË»®·Öµ½ÁíÒ»¸ö·ÖÇø£¬ÔÚ±£Ö¤ËüÃÇÊý¾ÝÏà¹ØÐÔµÄͬʱ»¹ÄÜÌá¸ß·ÃÎÊËÙ¶È¡£
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¹þÏ£·ÖÇø¡£
·ÖÇø´øÀ´µÄºÃ´¦Ì«¶àÌ«¶àÁË£¬ÓжàÉÙ£¿°³Ò²²»ÖªµÀ£¬×Ô¼º²ÂÈ¥°É£¬ÒªÊǾõµÃûÓжàÉپͱðÓ㬷´Õý°³Ò²²»ÇóÄãÓᣲ»¹ýÔÚÕâÀﰳǿµ÷Á½µãºÃ´¦£º
ÐÔÄܵÄÌáÉý£¨Increased performance£© - ÔÚɨÃè²Ù×÷ÖУ¬Èç¹ûMySQLµÄÓÅ»¯Æ÷ÖªµÀÄĸö·ÖÇøÖвŰüº¬Ìض¨²éѯÖÐÐèÒªµÄÊý¾Ý£¬Ëü¾ÍÄÜÖ±½ÓȥɨÃèÄÇЩ·ÖÇøµÄÊý
Ïà¹ØÎĵµ£º
MySQLµ¼³öºÍµ¼ÈëSQL½Å±¾
µ¼³ösql½Å±¾£º
mysqldump -u Óû§Ãû -p Êý¾Ý¿âÃû > ´æ·ÅλÖÃ
mysqljump -u root -p test > c:\a.sql
µ¼Èësql½Å±¾£º
Òª½¨»·¾³±äÁ¿»òÕßÔÚbinµÄĿ¼Ï£¬mysqlÕâ¸öÃüÁî²ÅÄÜʶ±ð¡£
testÊÇÄãÒªµ¼½øÈ¥µÄÊý¾Ý¿âÃû×Ö£¬ÒªÌáǰ½¨ºÃ~~
mysql -u Óû§Ãû -p Êý¾Ý¿âÃû < ´æ·ÅλÖÃ
mysqljump -u ro ......
mysql ±¸·ÝºÍ»Ö¸´²ßÂÔ
ÎÄÕ·ÖÀà:Êý¾Ý¿â
ÔÚÊý¾Ý¿â±í¶ªÊ§»òË𻵵ÄÇé¿öÏ£¬±¸·ÝÄãµÄÊý¾Ý¿âÊǺÜÖØÒªµÄ¡£Èç¹û·¢Éúϵͳ±ÀÀ££¬Äã¿Ï¶¨ÏëÄܹ»½«ÄãµÄ±í¾¡¿ÉÄܶªÊ§×îÉÙµÄÊý¾Ý»Ö¸´µ½±ÀÀ£·¢ÉúʱµÄ״̬¡£±¾ÎÄÖ÷Òª¶ÔMyISAM±í×ö±¸·Ý»Ö¸´¡£
±¸·Ý²ßÂÔÒ»£ºÖ±½Ó¿½±´Êý¾Ý¿âÎļþ£¨²»ÍƼö£©
±¸·Ý²ßÂÔ¶þ£ºÊ¹ÓÃmysqlhotcopy±¸·ÝÊý¾Ý¿â£ ......
mysql> grant ȨÏÞ1,ȨÏÞ2,¡È¨ÏÞn on Êý¾Ý¿âÃû³Æ.±íÃû³Æ to Óû§Ãû@Óû§µØÖ· identified by ¡®Á¬½Ó¿ÚÁ; ȨÏÞ1,ȨÏÞ2,¡È¨ÏÞn´ú±íselect,insert,update,delete,create,drop,index,alter,grant,references,reload,shutdown,process,fileµÈ14¸öȨÏÞ¡£µ±È¨ÏÞ1,ȨÏÞ2,¡È¨ÏÞn±»all privileges»òÕßall´úÌæ£¬±íʾ¸³ÓèÓû§È«²¿ ......
Ìí¼Ó×ֶεĸñʽ
ALTER [ONLINE | OFFLINE] [IGNORE] TABLE tbl_name alter_specification [, alter_specification] ...alter_specification: table_option ... | ADD [COLUMN] col_name column_definition [FIRST | AFTER col_name ]
eg.
ALTER TABLE myTbl ADD COLUMN newItem VARCHAR(20) DEFAULT "0" ......
1.½¨±íʱ¾Í´´½¨×ÔÔöÁУº
create table test
(
id int auto_increment primary key,
name varchar(20) not null,
password varchar(20) not null
);
insert into test values(null,'aa','aa');
insert into test values(null,'bb','bb');
×¢Ò⣺
²åÈëÓï¾äʱ£¬×Ô ......