MySQLÖи÷ÖÖ×ֶεÄÈ¡Öµ·¶Î§
ʱ¼ä:2005-09-29 20:59:14 À´Ô´:techtarget.com.cn ×÷Õß:techtarget.com.cn
¡¡¡¡TINYINT
¡¡¡¡-128 - 127
¡¡¡¡TINYINT UNSIGNED
¡¡¡¡0 - 255
¡¡¡¡SMALLINT
¡¡¡¡-32768 - 32767
¡¡¡¡SMALLINT UNSIGNED
¡¡¡¡0 - 65535
¡¡¡¡MEDIUMINT
¡¡¡¡-8388608 - 8388607
¡¡¡¡MEDIUMINT UNSIGNED
¡¡¡¡0 - 16777215
¡¡¡¡INT »ò INTEGER
¡¡¡¡-2147483648 - 2147483647
¡¡¡¡INT UNSIGNED »ò INTEGER UNSIGNED
¡¡¡¡0 - 4294967295
¡¡¡¡BIGINT
¡¡¡¡-9223372036854775808 - 9223372036854775807
¡¡¡¡BIGINT UNSIGNED
¡¡¡¡0 - 18446744073709551615
¡¡¡¡FLOAT
¡¡¡¡-3.402823466E+38 - -1.175494351E-38
¡¡¡¡0
¡¡¡¡1.175494351E-38 - 3.402823466E+38
¡¡¡¡DOUBLE »ò DOUBLE PRECISION »ò REAL
¡¡¡¡-1.7976931348623157E+308 - -2.2250738585072014E-308
¡¡¡¡0
¡¡¡¡2.2250738585072014E-308 - 1.7976931348623157E+308
¡¡¡¡DECIMAL[(M,[D])] »ò NUMERIC(M,D)
¡¡¡¡ÓÉM(Õû¸öÊý×ֵij¤¶È,°üÀ¨Ð¡Êýµã,СÊýµã×ó±ßµÄλÊý,СÊýµãÓұߵÄλÊý,µ«²»°üÀ¨¸ººÅ)ºÍD(СÊýµãÓұߵÄλÊý)À´¾ö¶¨,MȱʡΪ10,DȱʡΪ0
¡¡¡¡DATE
¡ ......
1.µ¼³öÕû¸öÊý¾Ý¿â
¡¡¡¡mysqldump -u Óû§Ãû -p Êý¾Ý¿âÃû > µ¼³öµÄÎļþÃû
¡¡¡¡mysqldump -u wcnc -p smgp_apps_wcnc > wcnc.sql
2.µ¼³öÒ»¸ö±í
¡¡¡¡mysqldump -u Óû§Ãû -p Êý¾Ý¿âÃû ±íÃû> µ¼³öµÄÎļþÃû
¡¡¡¡mysqldump -u wcnc -p smgp_apps_wcnc users> wcnc_users.sql
3.µ¼³öÒ»¸öÊý¾Ý¿â½á¹¹
¡¡¡¡mysqldump -u wcnc -p -d --add-drop-table smgp_apps_wcnc >d:\wcnc_db.sql
¡¡¡¡-d ûÓÐÊý¾Ý --add-drop-table ÔÚÿ¸öcreateÓï¾ä֮ǰÔö¼ÓÒ»¸ödrop table
4.µ¼ÈëÊý¾Ý¿â
¡¡¡¡³£ÓÃsourceÃüÁî
¡¡¡¡½øÈëmysqlÊý¾Ý¿â¿ØÖÆ̨£¬
¡¡¡¡Èçmysql -u root -p
¡¡¡¡mysql>use Êý¾Ý¿â
¡¡¡¡È»ºóʹÓÃsourceÃüÁºóÃæ²ÎÊýΪ½Å±¾Îļþ(ÈçÕâÀïÓõ½µÄ.sql)
¡¡¡¡mysql>source d:\\test.sql
......
1¡¢È·¶¨Êý¾Ý¿âĬÈϱàÂ룬±ÈÈç±àÂëΪutf8,½«¶ÁÈë;¾¶±àÂëͬÑùÉèΪutf8£¬ÃüÁîΪ£ºset names utf8;
2¡¢source d:/20080613.sql µ¼ÈëÊý¾Ý¡£ÑéÖ¤Êý¾Ý¿âÖеÄÊý¾ÝÊÇ·ñ´æÔÚÂÒÂë¡£
3¡¢Èç¹ûÈÔÈ»´æÔÚÂÒÂëÎÊÌ⣬Õâʱºò¾ÍÒª¿¼ÂǸı䵼ÈëÎļþµÄ±àÂ룬ÊÔ×ŵ¼È룬ֱÖÁûÓÐÂÒÂë³öÏÖ¡£
ÍøÒ³Êý¾Ý´æÈëÂÒÂëÎÊÌâÒÀÕÕÒÔÉÏ·½·¨Í¬Ñù¿ÉÒÔ½â¾ö¡£¿É½«ÍøÒ³±àÂë¸ÄΪÓëÊý¾Ý¿âÏàͬµÄ±àÂë¡£ÎÊÌâ×ÔÈ»½â¾ö¡£
ÁíÍ⣬ÔÚwindowsÖÐÎļþ·¾¶ d:\ftptemp\test.sql Ӧд³É d:/ftptemp/test.sql ......
ÔÚ³ÌÐò¿ª·¢ÖУ¬ÓÐʱ»á±»×Ö·ûÂÒÂëµÄÎÊÌâËùÀ§ÈÅ¡£¶Ô´Ë£¬±ØÐëÀí½â MySQL µÄ×Ö·û¼¯±àÂëÉèÖõÄÔÀí£ºÔÚMySQLÖУ¬Ä¬ÈÏʹÓõÄÊÇlartin1£¬Ò²¾ÍÊÇISO8859-1×Ö·û¼¯±àÂë¡£ÕâÊÇÒ»ÖÖ8λµÄ±àÂ룬ÊÊÓÃÓÚËùÓÐÎ÷Å·×Ö·û¡£¶ø¶ÔÓÚºº×ÖµÈÊDz»ºÏÊʵġ£×îºÃ¡¢×îͨÓõıàÂë¸ñʽÊÇutf-8£¬UTF-8£¨8 λԪ Universal Character Set£¯Unicode Transformation Format£©ÊÇÒ»ÖÖÕë¶ÔUnicode µÄ¿É±ä³¤¶È×Ö½Ú±àÂëµÄUnicode×Ö·û¼¯¡£Ëü¶ÔÓ¢ÎÄʹÓÃ8루¼´Ò»¸ö×Ö½Ú£©£¬ÖÐÎÄʹÓÃ24루Èý¸ö×Ö½Ú£©À´±àÂë¡£ËùÒÔ¶ÔÓÚ8λµÄÎ÷Å·×Ö·û¼¯À´Ëµ£¬¸üÄܱȽϽÚÊ¡¿Õ¼ä£¬¶øÓÖÄܹ»ÓÐЧµØ±íʾºº×ÖµÈ×Ö·û¡£ MySQL·þÎñÆ÷¶Ô×Ö·û¼¯ºÍУ¶Ô¹æÔòÓÐ4¸ö¼¶±ðµÄĬÈÏÉèÖ㺷þÎñÆ÷¼¶¡¢Êý¾Ý¿â¼¶¡¢±í¼¶ºÍÁ¬½Ó¼¶¡£
Ò»¡¢MySQLĬÈÏ×Ö·û¼¯
MySQL¶ÔÓÚ×Ö·û¼¯µÄÖ¸¶¨¿ÉÒÔϸ»¯µ½Ò»¸öÊý¾Ý¿â£¬Ò»ÕÅ±í£¬Ò»ÁУ¬Ó¦¸ÃÓÃʲô×Ö·û¼¯¡£µ«ÊÇ£¬´«Í³µÄ³ÌÐòÔÚ´´½¨Êý¾Ý¿âºÍÊý¾Ý±íʱ²¢Ã»ÓÐʹÓÃÄÇô¸´ÔÓµÄÅäÖã¬ËüÃÇÓõÄÊÇĬÈϵÄÅäÖÃ:
(1)±àÒëMySQL ʱ£¬Ö¸¶¨ÁËÒ»¸öĬÈϵÄ×Ö·û¼¯£¬Õâ¸ö×Ö·û¼¯ÊÇ latin1£»
(2)°²×°MySQL ʱ£¬¿ÉÒÔÔÚÅäÖÃÎļþ (my.ini) ÖÐÖ¸¶¨Ò»¸öĬÈϵĵÄ×Ö·û¼¯£¬Èç¹ûûָ¶¨£¬Õâ¸öÖµ¼Ì³Ð×Ô±àÒëʱָ¶¨µÄ£»
(3)Æô¶¯mysqld ʱ£¬¿ÉÒÔÔ ......
¶Ômysql´æ´¢¹ý³ÌµÄ¼òµ¥Ó¦ÓÃ
Ïò±íÖвåÈëÄ£ÄâÊý¾Ý£¬¼ì²é·ÖҳЧ¹ûÊÇ·ñ³ö´í¡£
create procedure dowhile()
begin
declare cnt INT default 0;
while cnt<100 do
INSERT INTO `test`.`news` (`F_ID` ,`F_TITLE` ,`F_CLASSID` ,`F_ISUP` ,`F_CONTENT` ,`F_SOURCE` ,`F_DATETIME` ,`F_READCOUNT` )VALUES (NULL , 'title', '2', '', 'content', '', '', '');
set cnt=cnt+1;
end while;
end//
-----------------------------------------
×¢Òâ:ÉèÖÃdelimiter //
²Î¿¼:http://dev.mysql.com/doc/refman/5.1/zh/stored-procedures.html
¸½:mysql 5.0´æ´¢¹ý³Ìѧϰ×ܽá
Ò».´´½¨´æ´¢¹ý³Ì
1.»ù±¾Óï·¨£º
create procedure sp_name()
begin
………
end
2.²ÎÊý´«µÝ
¾ÙÀý:
mysql> delimiter //
mysql> CREATE PROCEDURE simpleproc (OUT param1 INT)
-> BEGIN
-> SELECT COUNT(*) INTO param1 from t;
-> END//
Query OK, 0 rows affected (0.00 sec)
mysql> delimiter ;
mysql> CALL simp ......
1.ʲôÊÇUDF? UDF(user-defined function)ÊÇmysqlΪÓû§ÌṩµÄ×Ô¶¨Ò庯ÊýµÄÀ©Õ¹½Ó¿Ú¡£Ëü±¾ÖÊÉϺÍmysqlÌṩµÄmax¡¢minºÍcountµÈº¯ÊýÀàËÆ¡£ 2.UDF¿ÉÒÔ×öʲô? UDFÊÇ×Ô¶¨Ò庯Êý£¬ËùÒÔËüÄÜ×öʲôÍêÈ«È¡¾öÓÚÄãµÄʵÏÖ¡£UDF¿ÉÒÔÔÚÆÕͨµÄsql¡¢triggerÒÔ¼°store procedure±»µ÷ÓᣠÈç¹û×Ô¶¨ÒåÒ»¸ötcp_send(ip,port,msg)µÄº¯Êý£¬ÄÇô¾Í¿ÉÒÔͨ¹ýµ÷ÓÃ"SELECT tcp_send(¡®127.0.0.1¡¯, ¡®9090¡¯, ¡®a msg¡¯)¡±ÊµÏÖºÍ127.0.0.1:9090µÄͨÐÅ¡£ UDFÔÚtriggerÖÐʹÓ㺠´´½¨±í£º CREATE TABLE test.tab1 (a int); ´´½¨´¥·¢Æ÷£º DELIMITER // use test; // CREATE TRIGGER tab1_insert AFTER UPDATE ON test.tab1 FOR EACH ROW BEGIN SET @result = (SELECT http_post('127.0.0.1', '9090', OLD.a)); END; // DELIMITER ; 3. UDF+triggerµÄʵ¼ÊÓ¦Óà ӦÓÃ1£ºÊµÏÖÊý¾Ý¿âÖ÷¶¯½øÐÐcache¸üРӦÓÃ2£ºÊµÏÖ²»Í¬ÏµÍ³¼äµÄÊý¾Ý´«µÝ 4. UDF DEMO ½üÆÚÍƳö¡ ......