ȸ¿ø°¡ÀԡžÆÀ̵ð/ºñ¹øã±â
ȨÀ¸·Î


mysql ÆÁ
13³â Àü
MySQL °ü·Ã
root¾ÏÈ£º¯°æ¼³Á¤
PLEASE REMEMBER TO SET A PASSWORD FOR THE MySQL root USER !
This is done with:
/usr/bin/mysqladmin -u root -p password 'new-password'
/usr/bin/mysqladmin -u root -h ns.dbakorea.pe.kr -p password 'new-password'

½©¿¡¼­´Â mysqlÀÌ µÇ´Âµ¥ PHP¿¡¼­ mysql.sock error¸¦ ³»¸é¼­ MySQLÀÌ ¾ÈµÇ´Â °æ¿ì
mysql.sockÀº /tmp ¾Æ´Ï¸é /var/lib/mysql¿¡ »ý±â°Ô µÈ´Ù.
³ªÀÇ °æ¿ì, /var/lib/mysql¿¡ mysql.sockÆÄÀÏÀÌ Àִµ¥ PHP¿¡¼­´Â /tmp¿¡¼­ ãÀ¸·ÁÇϸ鼭 ¿¡·¯¸¦ ¹ß»ýÇß´Ù.
/usr/bin/safe_mysqldÆÄÀÏ¿¡¼­ ´ÙÀ½°ú °°ÀÌ ¼öÁ¤ÇÑ´Ù.
ÁÖ¼®(#)ÀÌ ´Þ¸° °ÍÀÌ ¿ø·¡°ÍÀÌ°í ±× ¹Ø¿¡ Àִ°ÍÀÌ ¼öÁ¤ÇÑ °ÍÀÌ´Ù.

# MYSQL_UNIX_PORT=${MYSQL_UNIX_PORT:-/var/lib/mysql/mysql.sock}
MYSQL_UNIX_PORT=${MYSQL_UNIX_PORT:-/tmp/mysql.sock}

À§¿Í °°ÀÌ ÇÏ´Ï /usr/bin/mysqlÀÌ /var/lib/mysql/mysql.sock¿¡¼­ ¼ÒÄÏÆÄÀÏÀ» ãÀ¸·Á Çß´Ù.
socket fileÀ» ÁöÁ¤ÇÏ´Â --socketÀ̶ó´Â ¿É¼ÇÀ¸·Î ´ÙÀ½°ú °°ÀÌ ÁöÁ¤ÇÏ¸é µÈ´Ù.

mysql --socket=/tmp/mysql.sock -u dbakorea -p db_test

ÇÏÁö¸¸ mysql½ÇÇà½Ã¸¶´Ù ÀÌ·¸°Ô ½áÁà¾ßÇÑ´Ù´Â °ÍÀÌ »ó´çÈ÷ ±ÍÂú´Ù. ¿É¼ÇÀÌ ¹Ù·Î Àû¿ëµÇ°Ô ¼³Á¤ÇÏÀÚ.
mysqlÀº ¼³Á¤»çÇ×À» ´ÙÀ½ 3°¡Áö ÆÄÀÏ¿¡¼­ °Ë»öÇÑ´Ù.

/etc/my.cnf            global options(MySQL ÀüüÀûÀ¸·Î »ç¿ëµÇ´Â ¿É¼Ç Á¤ÀÇ)
mysql-data-dir/my.cnf  Æ¯Á¤ DB¿¡ Àû¿ëµÇ´Â option (/var/lib/mysql/my.cnf)
~/.my.cnf              »ç¿ëÀÚ °¢°¢ÀÇ ¼³Á¤('~'¹®ÀÚ´Â »ç¿ëÀÚÀÇ È¨µð·ºÅ丮´Â ÀǹÌ)

/usr/share/mysqlµð·ºÅ丮¿¡ ¿¹Á¦°¡ ÀÖÀ¸¹Ç·Î Âü°íÇÑ´Ù.
¼ÒÄÏÆÄÀÏÀÇ ÁöÁ¤Àº ´ÙÀ½ÁÙÀ» ³Ö¾îÁÖ¸é µÈ´Ù.

socket          = /tmp/mysql.sock


== /etc/my.cnf¿¹ ==
# The following options will be passed to all MySQL clients
[client]
#password       = your_password
port            = 3306
socket          = /tmp/mysql.sock

# Here follows entries for some specific programs

# The MySQL server
[mysqld]
port            = 3306
socket          = /tmp/mysql.sock


# root¾ÏÈ£¼³Á¤
% mysqladmin -u root password 'º¯°æ¾ÏÈ£'  root·Î ·Î±×ÀÎÇÏ¿© ÇؾßÇÔ
or
% mysqladmin -u root -p±âÁ¸¾ÏÈ£ password 'º¯°æ¾ÏÈ£'  root·Î ·Î±×ÀÎÇÏ¿© ÇؾßÇÔ

DB»ý¼º
mysql> create database DB¸í ( or % mysqladmin -u root -p create DB¸í )

DB»èÁ¦
mysql> drop_database DB¸í

MySQL ¿¬°á
mysql -u »ç¿ëÀÚ -p DB¸í ( or % mysqladmin -u root -p drop DB¸í )

µ¥ÀÌÅÍÆÄÀÏ ½ÇÇà(sql*loader±â´É)
mysql>load data local infile "µ¥ÀÌÅÍÆÄÀÏ" into table Å×À̺í¸í ;
µ¥ÀÌÅÍÆÄÀÏ¿¡¼­ Ä÷³±¸ºÐÀº Åǹ®ÀÚ, Null°ªÀº /n·Î ÀÔ·Â

ÁúÀÇ ÆÄÀÏ ½ÇÇà
½©ÇÁ·ÒÇÁÆ®»ó¿¡¼­
mysql -u »ç¿ëÀÚ -p DB¸í < ÁúÀÇÆÄÀÏ
or
mysqlÇÁ·ÒÇÁÆ®»ó¿¡¼­
mysql> source ÁúÀÇÆÄÀÏ

½©ÇÁ·ÒÇÁÆ®»ó¿¡¼­ ÁúÀÇ ½ÇÇà
dbakorea@lion board]$ mysql mysql -u root -pxxxx -e
>            "INSERT INTO db VALUES(
>            'localhost', 'aaa', 'aaa',
>            'Y', 'Y', 'Y', 'Y', 'Y', 'Y', 'Y', 'Y', 'Y', 'Y')"


»ç¿ëÀÚ »ý¼º & »ç¿ëÀÚ¿¡°Ô DBÇÒ´ç
shell> mysql --user=root -p mysql

mysql> INSERT INTO user VALUES('localhost','»ç¿ëÀÚ',PASSWORD('ºñ¹Ð¹øÈ£'),'Y','Y','Y','Y','Y','Y','Y',
'Y','Y','Y','Y','Y','Y','Y');
mysql> INSERT INTO user VALUES('%','»ç¿ëÀÚ',PASSWORD('ºñ¹Ð¹øÈ£'),'Y','Y','Y','Y','Y','Y','Y','Y','Y',
'Y','Y','Y','Y','Y');

mysql> INSERT INTO db(Host,Db,User,Select_priv,Insert_priv,Update_priv,Delete_priv,Create_priv,Drop_priv)
VALUES ('localhost','DB¸í','»ç¿ëÀÚ','Y','Y','Y','Y','Y','Y');
mysql> INSERT INTO db(Host,Db,User,Select_priv,Insert_priv,Update_priv,Delete_priv,Create_priv,Drop_priv)
VALUES('%','DB¸í','»ç¿ëÀÚ','Y','Y','Y','Y','Y','Y');

mysql> FLUSH PRIVILEGES; (or shell prompt: mysqladmin -u root -pxxxx reload)


DB, Å×À̺í¸ñ·Ïº¸±â
mysql> show databases;
mysql> show tables;

»ç¿ë DB¼±ÅÃ
mysql> use DB¸í

Å×ÀÌºí±¸Á¶
mysql> describe Å×À̺í¸í

À妽º º¸±â
show index from Å×À̺í¸í

Å×À̺í¸í º¯°æ
mysql> rename table test to test2;

Á¢¼Ó
mysql {-h Á¢¼ÓÈ£½ºÆ®} -u »ç¿ëÀÚ -p »ç¿ëDB
-h·Î ´Ù¸¥ ¼­¹ö¿¡ Á¸ÀçÇÏ´Â MySQLÁ¢¼Ó½Ã ´ÙÀ½°ú °°ÀÌ MySQL DB¿¡ ¼³Á¤ÇØÁà¾ß ÇÑ´Ù.
mysql> INSERT INTO user VALUES('Á¢±ÙÀ» Çã¿ëÇÒ È£½ºÆ®ip','»ç¿ëÀÚ',PASSWORD('ºñ¹Ð¹øÈ£'),'Y','Y','Y',
'Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y');
mysql> INSERT INTO db(Host,Db,User,Select_priv,Insert_priv,Update_priv,Delete_priv,Create_priv,Drop_priv)
VALUES('Á¢±ÙÀ» Çã¿ëÇÒ È£½ºÆ®ip','»ç¿ëDB','»ç¿ëÀÚ','Y','Y','Y','Y','Y','Y');
mysql> FLUSH PRIVILEGES; or ½¯ÇÁ·ÒÇÁÆ®»ó¿¡¼­ % mysqladmin -u root -p flush-privileges

¹öÀüüũ
mysql> select version();

°Ë»öÁ¶°Ç(where)
regular expressionÀ» Áö¿øÇÏ´Ù´Ï ½Å±âÇϱº..
mysql> select * from work where ¿­¸í regexp "Á¤±ÔÇ¥Çö½Ä";

Ä÷³ÀÇ Ãß°¡, »èÁ¦(¿À¶óŬ°ú µ¿ÀÏ)
alter table Å×À̺í¸í add Ä÷³¸í µ¥ÀÌÅÍŸÀÔ;
alter table Å×À̺í¸í del Ä÷³¸í;


¹é¾÷ & º¹±¸
mysqldump {-h È£½ºÆ®} -u »ç¿ëÀÚ -p DB¸í > ¹é¾÷ÆÄÀÏ
mysql {-h È£½ºÆ®} -u »ç¿ëÀÚ -p DB¸í < ¹é¾÷ÆÄÀÏ

mysqldump -u root -p --opt db_dbakorea > dbakorea.sql
mysqldump -u root -p --opt db_board | mysql ---host=remote-host -C database (»óÀÌÇÑ ¸Ó½®)
mysql -u dbakorea -p db_dbakorea < dbakorea.sql      


mysqldump -u root -p --opt db_dbakorea | mysql ---host=ns.dbakorea.pe.kr -C db_dbakorea

Å×ÀÌºí °Ë»ç
isamchk

¿À¶óŬ sysdate¿Í µ¿ÀÏ
insert into test values('12', now());

À¯´Ð½º time()ÇÔ¼ö ¸®ÅÏ°ª »ç¿ë
FROM_UNIXTIME(954788684)
UNIX_TIMESTAMP("2001-04-04 :04:04:04")

MySQL µðÆúÆ® DB&·Î±×ÆÄÀÏ À§Ä¡
/var/lib/mysql
/var/libµð·ºÅ丮´Â ¿©·¯ ÇÁ·Î¼¼½ºµéÀÌ »ç¿ëÇÏ´Â µ¥ÀÌÅ͸¦ ÀúÀåÇÏ´Â ÀÏÁ¾ÀÇ ÆÄÀϽýºÅÛ»óÀÇ µ¥ÀÌÅͺ£ÀÌ
½º¶ó°í º¼ ¼ö ÀÖ´Ù.

replace
ÇØ´ç ·¹ÄÚµå Á¸ÀçÇϸé updateÇÏ°í, Á¸ÀçÇÏÁö ¾Ê´Â´Ù¸é insertÇÑ´Ù.(insert¹®¹ý°ú µ¿ÀÏ)
replace into test values('maddog','kang myung gyu')'

explain
explain ÁúÀǹ®: ÁöÁ¤ÇÑ ÁúÀǹ®ÀÌ ¾î¶»°Ô ½ÇÇàµÉ °ÇÁö¸¦ º¸¿©ÁÜ
mysql> explain select u.uid, u.name, a.name from sm_user u, sm_addr a where u.uid=a.uid;    
+-------+------+-----------------+-----------------+---------+-------+------+-------+
| table | type | possible_keys   | key             | key_len | ref   | rows | Extra |
+-------+------+-----------------+-----------------+---------+-------+------+-------+
| u     | ALL  | PRIMARY         | NULL            |    NULL | NULL  |  370 |       |
| a     | ref  | sm_addr_uid_idx | sm_addr_uid_idx |      11 | u.uid |   11 |       |
+-------+------+-----------------+-----------------+---------+-------+------+-------+
2 rows in set (0.01 sec)

temporary table
Å©±â°¡ Å« Å×ÀÌºí¿¡ ÀÖ´Â subset¿¡ ´ëÇÑ ÁúÀǶó¸é subsetÀ» temporary table¿¡ ÀúÀåÇÑ ÈÄ
ÁúÀÇÇÏ´Â °ÍÀÌ ´õ ºü¸¦ °æ¿ì°¡ ÀÖ´Ù.
create temporary table (...);
create temporary table (...) type=heap; µð½ºÅ©°¡ ¾Æ´Ñ ¸Þ¸ð¸®¿¡ Å×ÀÌºí »ý¼º

==============================================================================
MySQL Ư¼ºÁ¤¸®
==============================================================================
primary keyÁö¿ø
index Áö¿ø(15°³Ä÷³, 256byte±îÁö)
foreign key, check, references±â´É Áö¿øÇÏÁö ¾ÊÀ½(Çü½Ä»ó ÀÖÀ½)

mysql> CREATE TABLE test (
        id INT NOT NULL,
        last_name CHAR(30) NOT NULL,
        first_name CHAR(30) NOT NULL,
        PRIMARY KEY (id),
        INDEX name (last_name,first_name));
        
MySQL¿¡¼­ÀÇ Stored Script°³³ä => SQL server language
commit-rollback°³³ä => lock tables
ÃßõÃßõ : 321 Ãßõ ¸ñ·Ï
¹øÈ£ Á¦¸ñ
2,885
input ÀÔ·Â ÇÊµå ¾ÕµÚ °ø¹é ½Ç½Ã°£ Á¦°Å
2,884
Placeholder Æ÷Ä¿½º½Ã °¨Ãß±â
2,883
MySQL Áߺ¹µÈ µ¥ÀÌÅ͸¦ »èÁ¦
2,882
MySQL Áߺ¹ µ¥ÀÌÅÍ È®ÀÎ
2,881
sessionStorage.getItem ¿Í sessionStorage.setItem
2,880
Á¦ÀÌÄõ¸® ·£´ýÀ¸·Î ¹è°æ»ö º¯°æ
2,879
preg match¿¡ °üÇÑ Á¤±Ô½Ä
2,878
Stream an audio file with MediaPlayer ¿Àµð¿À ÆÄÀÏ ½ºÆ®¸®¹Ö Çϱâ
2,877
Audio Streaming PHP Code
2,876
PHP $ SERVER ȯ°æ º¯¼ö Á¤¸®
2,875
Vimeo (ºñ¸Þ¿À) API ¸¦ »ç¿ëÇÏ¿© Ç÷¹À̾î ÄÁÆ®·ÑÇϱâ
2,874
iframe »ç¿ë½Ã ÇÏ´Ü¿¡ ¹ß»ýÇÏ´Â °ø¹é Á¦°Å¹æ¹ý
2,873
¾ÆÀÌÇÁ·¹ÀÓ(iframe) Àüüȭ¸é °¡´ÉÇÏ°Ô Çϱâ
2,872
ºÎÆ®½ºÆ®·¦(bootstrapk)¿¡¼­ »ç¿ëÇÏ´Â class¸í Á¤¸®
2,871
ºÎÆ®½ºÆ®·¦ CSS
2,870
Å©·Ò¿¡¼­ ¸¶Áø Á¶Àý
2,869
PHP ÇöÀç ÆäÀÌÁöÀÇ µµ¸ÞÀθíÀ̳ª urlµîÀÇ Á¤º¸ ¾Ë¾Æ¿À±â
2,868
PHP preg match all()
2,867
PHP ·Î À¥ÆäÀÌÁö ±Ü¾î¿À±â ¸ðµç ¹æ¹ý ÃÑÁ¤¸®!
2,866
[PHP] ¿ø°ÝÁö ÆÄÀÏ ÁÖ¼Ò ³ëÃâ ¾ÈÇÏ°í curl·Î ´Ù¿î·Îµå ¹Þ±â
2,865
PHP ÇÔ¼ö Á¤¸®
2,864
¾ÆÀÌÇÁ·¹ÀÓ(iframe) ºñÀ² À¯ÁöÇϸ鼭 Å©±â Á¶ÀýÇÏ´Â ¹æ¹ý
2,863
PHP ¹è¿­¿¡¼­ ¹«ÀÛÀ§·Î Çϳª »Ì¾ÆÁÖ´Â array rand() ÇÔ¼ö
2,862
PHP Á¤±Ô½Ä Á¤¸®
2,861
PHP Á¤±Ô½ÄÀ» È°¿ëÇÑ ÅÂ±× ¹× ƯÁ¤ ¹®ÀÚ¿­ Á¦°Å ¹× ÃßÃâ ¹æ¹ý
2,860
php Å©·Ñ¸µ ¶Ç´Â ÆÄ½Ì ÇÔ¼ö, Á¤±Ô½Ä ¸ðÀ½
2,859
Á¦ÀÌÄõ¸® ±âº» ¸í·É¾î
2,858
À¥ÆäÀÌÁö °¡·Î ¸ðµå¼¼·Î ¸ðµå ÀνÄÇϱâ
2,857
¸ð¹ÙÀÏ À¥ È­¸é °­Á¦ ȸÀü(°¡·Î¸ðµå °íÁ¤)
2,856
[HTML5]¿¡¼­ frameset ´ëü ¹æ¹ý°ú iframe ¼Ó¼º
¸ñ·Ï
¹ÂÁ÷Æ®·ÎÆ® ºÎ»ê±¤¿ª½Ã ºÎ»êÁø±¸ °¡¾ßµ¿ ¤Ó °³ÀÎÁ¤º¸Ãë±Þ¹æħ
Copyright ¨Ï musictrot All rights reserved.