2010-03-06
Mysql commands
This is a list of handy MySQL commands that I use time and time again. At the bottom are statements, clauses, and functions you can use in MySQL. Below that are PHP and Perl API functions you can use to interface with MySQL. To use those you will need to build PHP with MySQL functionality. To use MySQL with Perl you will need to use the Perl modules DBI and DBD::mysql.
Below when you see # it means from the unix shell. When you see mysql> it means from a MySQL prompt after logging into MySQL.
Below when you see # it means from the unix shell. When you see mysql> it means from a MySQL prompt after logging into MySQL.
To login (from unix shell) use -h only if needed.
# [mysql dir]/bin/mysql -h hostname -u root -p
Create a database on the sql server.
mysql> create database [databasename];
List all databases on the sql server.
mysql> show databases;
Switch to a database.
mysql> use [db name];
To see all the tables in the db.
mysql> show tables;
To see database's field formats.
mysql> describe [table name];
To delete a db.
mysql> drop database [database name];
To delete a table.
mysql> drop table [table name];
Show all data in a table.
mysql> SELECT * FROM [table name];
Returns the columns and column information pertaining to the designated table.
mysql> show columns from [table name];
Show certain selected rows with the value "whatever".
mysql> SELECT * FROM [table name] WHERE [field name] = "whatever";
Show all records containing the name "Bob" AND the phone number '3444444'.
mysql> SELECT * FROM [table name] WHERE name = "Bob" AND phone_number = '3444444';
Show all records not containing the name "Bob" AND the phone number '3444444' order by the phone_number field.
mysql> SELECT * FROM [table name] WHERE name != "Bob" AND phone_number = '3444444' order by phone_number;
Show all records starting with the letters 'bob' AND the phone number '3444444'.
mysql> SELECT * FROM [table name] WHERE name like "Bob%" AND phone_number = '3444444';
Show all records starting with the letters 'bob' AND the phone number '3444444' limit to records 1 through 5.
mysql> SELECT * FROM [table name] WHERE name like "Bob%" AND phone_number = '3444444' limit 1,5;
Use a regular expression to find records. Use "REGEXP BINARY" to force case-sensitivity. This finds any record beginning with a.
mysql> SELECT * FROM [table name] WHERE rec RLIKE "^a";
Show unique records.
mysql> SELECT DISTINCT [column name] FROM [table name];
Show selected records sorted in an ascending (asc) or descending (desc).
mysql> SELECT [col1],[col2] FROM [table name] ORDER BY [col2] DESC;
Return number of rows.
mysql> SELECT COUNT(*) FROM [table name];
Sum column.
mysql> SELECT SUM(*) FROM [table name];
Join tables on common columns.
mysql> select lookup.illustrationid, lookup.personid,person.birthday from lookup left join person on lookup.personid=person.personid=statement to join birthday in person table with primary illustration id;
Creating a new user. Login as root. Switch to the MySQL db. Make the user. Update privs.
# mysql -u root -p
mysql> use mysql;
mysql> INSERT INTO user (Host,User,Password) VALUES('%','username',PASSWORD('password'));
mysql> flush privileges;
mysql> use mysql;
mysql> INSERT INTO user (Host,User,Password) VALUES('%','username',PASSWORD('password'));
mysql> flush privileges;
Change a users password from unix shell.
# [mysql dir]/bin/mysqladmin -u username -h hostname.blah.org -p password 'new-password'
Change a users password from MySQL prompt. Login as root. Set the password. Update privs.
# mysql -u root -p
mysql> SET PASSWORD FOR 'user'@'hostname' = PASSWORD('passwordhere');
mysql> flush privileges;
mysql> SET PASSWORD FOR 'user'@'hostname' = PASSWORD('passwordhere');
mysql> flush privileges;
Recover a MySQL root password. Stop the MySQL server process. Start again with no grant tables. Login to MySQL as root. Set new password. Exit MySQL and restart MySQL server.
# /etc/init.d/mysql stop
# mysqld_safe --skip-grant-tables &
# mysql -u root
mysql> use mysql;
mysql> update user set password=PASSWORD("newrootpassword") where User='root';
mysql> flush privileges;
mysql> quit
# /etc/init.d/mysql stop
# /etc/init.d/mysql start
# mysqld_safe --skip-grant-tables &
# mysql -u root
mysql> use mysql;
mysql> update user set password=PASSWORD("newrootpassword") where User='root';
mysql> flush privileges;
mysql> quit
# /etc/init.d/mysql stop
# /etc/init.d/mysql start
Set a root password if there is on root password.
# mysqladmin -u root password newpassword
Update a root password.
# mysqladmin -u root -p oldpassword newpassword
Allow the user "bob" to connect to the server from localhost using the password "passwd". Login as root. Switch to the MySQL db. Give privs. Update privs.
# mysql -u root -p
mysql> use mysql;
mysql> grant usage on *.* to bob@localhost identified by 'passwd';
mysql> flush privileges;
mysql> use mysql;
mysql> grant usage on *.* to bob@localhost identified by 'passwd';
mysql> flush privileges;
Give user privilages for a db. Login as root. Switch to the MySQL db. Grant privs. Update privs.
# mysql -u root -p
mysql> use mysql;
mysql> INSERT INTO db (Host,Db,User,Select_priv,Insert_priv,Update_priv,Delete_priv,Create_priv,Drop_priv) VALUES ('%','databasename','username','Y','Y','Y','Y','Y','N');
mysql> flush privileges;
or
mysql> grant all privileges on databasename.* to username@localhost;
mysql> flush privileges;
mysql> use mysql;
mysql> INSERT INTO db (Host,Db,User,Select_priv,Insert_priv,Update_priv,Delete_priv,Create_priv,Drop_priv) VALUES ('%','databasename','username','Y','Y','Y','Y','Y','N');
mysql> flush privileges;
or
mysql> grant all privileges on databasename.* to username@localhost;
mysql> flush privileges;
To update info already in a table.
mysql> UPDATE [table name] SET Select_priv = 'Y',Insert_priv = 'Y',Update_priv = 'Y' where [field name] = 'user';
Delete a row(s) from a table.
mysql> DELETE from [table name] where [field name] = 'whatever';
Update database permissions/privilages.
mysql> flush privileges;
Delete a column.
mysql> alter table [table name] drop column [column name];
Add a new column to db.
mysql> alter table [table name] add column [new column name] varchar (20);
Change column name.
mysql> alter table [table name] change [old column name] [new column name] varchar (50);
Make a unique column so you get no dupes.
mysql> alter table [table name] add unique ([column name]);
Make a column bigger.
mysql> alter table [table name] modify [column name] VARCHAR(3);
Delete unique from table.
mysql> alter table [table name] drop index [colmn name];
Load a CSV file into a table.
mysql> LOAD DATA INFILE '/tmp/filename.csv' replace INTO TABLE [table name] FIELDS TERMINATED BY ',' LINES TERMINATED BY '\n' (field1,field2,field3);
Dump all databases for backup. Backup file is sql commands to recreate all db's.
# [mysql dir]/bin/mysqldump -u root -ppassword --opt >/tmp/alldatabases.sql
Dump one database for backup.
# [mysql dir]/bin/mysqldump -u username -ppassword --databases databasename >/tmp/databasename.sql
Dump a table from a database.
# [mysql dir]/bin/mysqldump -c -u username -ppassword databasename tablename > /tmp/databasename.tablename.sql
Restore database (or database table) from backup.
# [mysql dir]/bin/mysql -u username -ppassword databasename < /tmp/databasename.sql
Create Table Example 1.
mysql> CREATE TABLE [table name] (firstname VARCHAR(20), middleinitial VARCHAR(3), lastname VARCHAR(35),suffix VARCHAR(3),officeid VARCHAR(10),userid VARCHAR(15),username VARCHAR(8),email VARCHAR(35),phone VARCHAR(25), groups VARCHAR(15),datestamp DATE,timestamp time,pgpemail VARCHAR(255));
Create Table Example 2.
mysql> create table [table name] (personid int(50) not null auto_increment primary key,firstname varchar(35),middlename varchar(50),lastnamevarchar(50) default 'bato');
MYSQL Statements and clauses
ALTER DATABASE ALTER TABLE ALTER VIEW ANALYZE TABLE BACKUP TABLE CACHE INDEX CHANGE MASTER TO CHECK TABLE CHECKSUM TABLE COMMIT CREATE DATABASE CREATE INDEX CREATE TABLE CREATE VIEW DELETE DESCRIBE DO DROP DATABASE DROP INDEX DROP TABLE DROP USER DROP VIEW EXPLAIN FLUSH GRANT HANDLER INSERT JOIN KILL LOAD DATA FROM MASTER LOAD DATA INFILE LOAD INDEX INTO CACHE LOAD TABLE...FROM MASTER LOCK TABLES OPTIMIZE TABLE PURGE MASTER LOGS RENAME TABLE REPAIR TABLE REPLACE RESET RESET MASTER RESET SLAVE RESTORE TABLE REVOKE ROLLBACK ROLLBACK TO SAVEPOINT SAVEPOINT SELECT SET SET PASSWORD SET SQL_LOG_BIN SET TRANSACTION SHOW BINLOG EVENTS SHOW CHARACTER SET SHOW COLLATION SHOW COLUMNS SHOW CREATE DATABASE SHOW CREATE TABLE SHOW CREATE VIEW SHOW DATABASES SHOW ENGINES SHOW ERRORS SHOW GRANTS SHOW INDEX SHOW INNODB STATUS SHOW LOGS SHOW MASTER LOGS SHOW MASTER STATUS SHOW PRIVILEGES SHOW PROCESSLIST SHOW SLAVE HOSTS SHOW SLAVE STATUS SHOW STATUS SHOW TABLE STATUS SHOW TABLES SHOW VARIABLES SHOW WARNINGS START SLAVE START TRANSACTION STOP SLAVE TRUNCATE TABLE UNION UNLOCK TABLES USEString Functions
AES_DECRYPT AES_ENCRYPT ASCII BIN BINARY BIT_LENGTH CHAR CHAR_LENGTH CHARACTER_LENGTH COMPRESS CONCAT CONCAT_WS CONV DECODE DES_DECRYPT DES_ENCRYPT ELT ENCODE ENCRYPT EXPORT_SET FIELD FIND_IN_SET HEX INET_ATON INET_NTOA INSERT INSTR LCASE LEFT LENGTH LOAD_FILE LOCATE LOWER LPAD LTRIM MAKE_SET MATCH AGAINST MD5 MID OCT OCTET_LENGTH OLD_PASSWORD ORD PASSWORD POSITION QUOTE REPEAT REPLACE REVERSE RIGHT RPAD RTRIM SHA SHA1 SOUNDEX SPACE STRCMP SUBSTRING SUBSTRING_INDEX TRIM UCASE UNCOMPRESS UNCOMPRESSED_LENGTH UNHEX UPPERDate and Time Functions
ADDDATE ADDTIME CONVERT_TZ CURDATE CURRENT_DATE CURRENT_TIME CURRENT_TIMESTAMP CURTIME DATE DATE_ADD DATE_FORMAT DATE_SUB DATEDIFF DAY DAYNAME DAYOFMONTH DAYOFWEEK DAYOFYEAR EXTRACT FROM_DAYS FROM_UNIXTIME GET_FORMAT HOUR LAST_DAY LOCALTIME LOCALTIMESTAMP MAKEDATE MAKETIME MICROSECOND MINUTE MONTH MONTHNAME NOW PERIOD_ADD PERIOD_DIFF QUARTER SEC_TO_TIME SECOND STR_TO_DATE SUBDATE SUBTIME SYSDATE TIME TIMEDIFF TIMESTAMP TIMESTAMPDIFF TIMESTAMPADD TIME_FORMAT TIME_TO_SEC TO_DAYS UNIX_TIMESTAMP UTC_DATE UTC_TIME UTC_TIMESTAMP WEEK WEEKDAY WEEKOFYEAR YEAR YEARWEEKMathematical and Aggregate Functions
ABS ACOS ASIN ATAN ATAN2 AVG BIT_AND BIT_OR BIT_XOR CEIL CEILING COS COT COUNT CRC32 DEGREES EXP FLOOR FORMAT GREATEST GROUP_CONCAT LEAST LN LOG LOG2 LOG10 MAX MIN MOD PI POW POWER RADIANS RAND ROUND SIGN SIN SQRT STD STDDEV SUM TAN TRUNCATE VARIANCEFlow Control Functions
CASE IF IFNULL NULLIFCommand-Line Utilities
comp_err isamchk make_binary_distribution msql2mysql my_print_defaults myisamchk myisamlog myisampack mysqlaccess mysqladmin mysqlbinlog mysqlbug mysqlcheck mysqldump mysqldumpslow mysqlhotcopy mysqlimport mysqlshow perrorPerl API - using functions and methods built into the Perl DBI with MySQL
available_drivers begin_work bind_col bind_columns bind_param bind_param_array bind_param_inout can clone column_info commit connect connect_cached data_sources disconnect do dump_results err errstr execute execute_array execute_for_fetch fetch fetchall_arrayref fetchall_hashref fetchrow_array fetchrow_arrayref fetchrow_hashref finish foreign_key_info func get_info installed_versions last_insert_id looks_like_number neat neat_list parse_dsn parse_trace_flag parse_trace_flags ping prepare prepare_cached primary_key primary_key_info quote quote_identifier rollback rows selectall_arrayref selectall_hashref selectcol_arrayref selectrow_array selectrow_arrayref selectrow_hashref set_err state table_info table_info_all tables trace trace_msg type_info type_info_all Attributes for HandlesPHP API - using functions built into PHP with MySQL
mysql_affected_rows mysql_change_user mysql_client_encoding mysql_close mysql_connect mysql_create_db mysql_data_seek mysql_db_name mysql_db_query mysql_drop_db mysql_errno mysql_error mysql_escape_string mysql_fetch_array mysql_fetch_assoc mysql_fetch_field mysql_fetch_lengths mysql_fetch_object mysql_fetch_row mysql_field_flags mysql_field_len mysql_field_name mysql_field_seek mysql_field_table mysql_field_type mysql_free_result mysql_get_client_info mysql_get_host_info mysql_get_proto_info mysql_get_server_info mysql_info mysql_insert_id mysql_list_dbs mysql_list_fields mysql_list_processes mysql_list_tables mysql_num_fields mysql_num_rows mysql_pconnect mysql_ping mysql_query mysql_real_escape_string mysql_result mysql_select_db mysql_stat mysql_tablename mysql_thread_id mysql_unbuffered_query
2010-03-05
Một số lệnh quản lý MySQL Server
Giới thiệu Một số lệnh quản lý MySQL Server
Kết nối vào MySQL Server từ dòng lệnh
Để kết nối vào MySQL server, bạn hãy chạy lệnh mysql (file mysql.exe trong thư mục Bin của MySQL trên Windows hoặc file mysql trong thư mục bin của MySQL trên Linux). Đây là một MySQL Client với giao diện text, giao tiếp với người dùng qua dòng lệnh (command line).
Câu lệnh trên sẽ kết nối vào MySQL Server ở địa chỉ 192.168.0.1 với username là test, mật mã là test và sử dụng CSDL có tên là test_db. Nếu không có tham số -h 192.168.0.1, mysql sẽ mặc định kết nối vào server localhost.
Nếu bạn không muốn cung cấp mật mã trong câu lệnh kết nối thì bạn chỉ cần cung cấp tham số -p, mysql sẽ nhắc bạn nhập vào mật mã sau. VD:
Nếu bạn không cung cấp tên của CSDL cần sử dụng, thì mặc định sau khi kết nối sẽ không có CSDL nào được mở ra để bạn sử dụng cả. VD:
Sau khi kết nối thành công, để thoát khoải chế độ dòng lệnh của mysql và trở về hệ điều hành, bạn có thể nhấn Ctrl-C, hoặc \q và Enter.
Lưu ý: Đa phần các lệnh về quản trị MySQL server đòi hỏi bạn phải login vào server với account có quyền cao nhất (vd account root).
Chọn CSDL để làm việc
Sau khi kết nối thành công vào MySQL Server, bạn có thể chọn hoặc CSDL để làm việc bằng câu lệnh USE tên_CSDL:
(cuối câu lệnh SQL bạn nhớ thêm dấu chấm phảy
Bạn cũng có thể liệt kê danh sách các CSDL trong hệ thống bằng lệnh:
SHOW DATABASES;
bạn có thể nhận được kết quả tương tự như sau:
+----------+
| Database |
+----------+
| mysql |
| test |
+----------+
2 rows in set (1.20 sec)
Tài liệu tham khảo:
Dien dan Tin hoc - Tutorial Room - Quản lý MySQL Server sử dụng lệnh trên ConsoleHiển thị thông tin về table
Sau khi kết nối và chọn CSDL để làm việc xong, bạn có thể liệt kê danh sách các table trong CSDL bằng lệnh:
bạn có thể nhận được kết quả tương tự như sau:
+---------------------------+
| Tables_in_mysql |
+---------------------------+
| columns_priv |
| db |
| func |
| help_category |
| help_keyword |
| help_relation |
| help_topic |
| host |
| tables_priv |
| time_zone |
| time_zone_leap_second |
| time_zone_name |
| time_zone_transition |
| time_zone_transition_type |
| user |
+---------------------------+
15 rows in set (0.58 sec)
Bạn cũng có thể liệt kê thông tin chi tiết về table bằng lệnh SHOW TABLE STATUS.
sẽ trả về câu lệnh SQL dùng để tạo table db tương tự như sau:
CREATE TABLE `db` (
`Host` char(60) binary NOT NULL default '',
`Db` char(64) binary NOT NULL default '',
`User` char(16) binary NOT NULL default '',
`Select_priv` enum('N','Y') NOT NULL default 'N',
`Insert_priv` enum('N','Y') NOT NULL default 'N',
`Update_priv` enum('N','Y') NOT NULL default 'N',
`Delete_priv` enum('N','Y') NOT NULL default 'N',
`Create_priv` enum('N','Y') NOT NULL default 'N',
`Drop_priv` enum('N','Y') NOT NULL default 'N',
`Grant_priv` enum('N','Y') NOT NULL default 'N',
`References_priv` enum('N','Y') NOT NULL default 'N',
`Index_priv` enum('N','Y') NOT NULL default 'N',
`Alter_priv` enum('N','Y') NOT NULL default 'N',
`Create_tmp_table_priv` enum('N','Y') NOT NULL default 'N',
`Lock_tables_priv` enum('N','Y') NOT NULL default 'N',
PRIMARY KEY (`Host`,`Db`,`User`),
KEY `User` (`User`)
) TYPE=MyISAM COMMENT='Database privileges';
Tài liệu tham khảo:
Để tạo CSDL mới, MySQL cung cấp cho ta lệnh CREATE DATABASE:
Câu lệnh trên sẽ tạo 1 CSDL mới có tên là db_name. Bạn cũng có thể xoá bỏ một CSDL với lệnh DROP DATABASE:
Tuy nhiên, CSDL mà đã bị xoá rồi thì không thể khôi phục lại được, cho nên bạn hãy cẩn thận khi dùng lệnh DROP DATABASE.
Và bạn cũng có thể xem lại cú pháp câu lệnh CREATE DATABASE của 1 CSDL đã có sẵn bằng lệnh SHOW CREATE DATABASE:
Để tạo account mới và gán quyền truy cập vào MySQL server cho account đó, MySQL cung cấp cho ta lệnh GRANT. Cú pháp đơn giản của lệnh GRANT như sau:
GRANT ALL PRIVILEGES ON *.* TO 'nbthanh'@'localhost' IDENTIFIED BY 'my_password';
Lệnh trên sẽ tạo 1 account có username là nbthanh với mật mã là my_password, được phép kết nối từ localhost và có mọi quyền trên tất cả các CSDL có trên hệ thống.
GRANT SELECT ON *.* TO 'nbthanh'@'%' IDENTIFIED BY 'my_password2';
Lệnh trên sẽ tạo 1 account có username là nbthanh với mật mã là my_password2, được phép kết nối từ bất cứ nơi đâu ngoại trừ localhost, nhưng chỉ có quyền đọc (SELECT) trên tất cả các CSDL có trên hệ thống.
Đôi khi bạn sẽ có nhu cầu đổi mật mã cho 1 account mà không muốn thay đổi lại các quyền hiện có của account đó, MySQL cung cấp lệnh SET PASSWORD để thực hiện thao tác này:
Lệnh trên sẽ đổi mật mã của account nbthanh, kết nối từ localhost, thành new_password.
Lệnh trên sẽ đổi mật mã của account nbthanh, kết nối từ bất cứ nơi đâu ngoại trừ localhost, thành new_password2.
Và cuối cùng, để xoá account ra khỏi hệ thống, MySQL cung cấp cho ta lệnh DROP USER:
Xoá account có username là nbthanh, kết nối từ localhost, ra khỏi hệ thống (lệnh này không xoá các account khác như 'nbthanh'@'%').
Xoá account có username là nbthanh, kết nối từ bất cứ nơi đâu ngoài trừ localhost, ra khỏi hệ thống (lệnh này không xoá các account khác như 'nbthanh'@'localhost').
Lưu ý: Đôi khi bạn cần phải thực hiện lệnh FLUSH PRIVILEGES; sau khi thực hiện các thao tác thêm/xoá/thay đổi account thì các thao tác mới có hiệu lực.
Tài liệu tham khảo:
__________________Kết nối vào MySQL Server từ dòng lệnh
Để kết nối vào MySQL server, bạn hãy chạy lệnh mysql (file mysql.exe trong thư mục Bin của MySQL trên Windows hoặc file mysql trong thư mục bin của MySQL trên Linux). Đây là một MySQL Client với giao diện text, giao tiếp với người dùng qua dòng lệnh (command line).
Mã:
mysql -h 192.168.0.1 -u test -ptest test_db
Nếu bạn không muốn cung cấp mật mã trong câu lệnh kết nối thì bạn chỉ cần cung cấp tham số -p, mysql sẽ nhắc bạn nhập vào mật mã sau. VD:
Mã:
mysql -h localhost -u myuser -p mydb
Mã:
mysql -u root -p
Lưu ý: Đa phần các lệnh về quản trị MySQL server đòi hỏi bạn phải login vào server với account có quyền cao nhất (vd account root).
Chọn CSDL để làm việc
Sau khi kết nối thành công vào MySQL Server, bạn có thể chọn hoặc CSDL để làm việc bằng câu lệnh USE tên_CSDL:
Mã:
USE mysql;
Bạn cũng có thể liệt kê danh sách các CSDL trong hệ thống bằng lệnh:
SHOW DATABASES;
bạn có thể nhận được kết quả tương tự như sau:
+----------+
| Database |
+----------+
| mysql |
| test |
+----------+
2 rows in set (1.20 sec)
Tài liệu tham khảo:
- Cú pháp lệnh USE của MySQL: http://dev.mysql.com/doc/mysql/en/USE.html.
- Cú pháp lệnh SHOW DATABASES: http://dev.mysql.com/doc/mysql/en/SHOW_DATABASES.html.
Dien dan Tin hoc - Tutorial Room - Quản lý MySQL Server sử dụng lệnh trên ConsoleHiển thị thông tin về table
Sau khi kết nối và chọn CSDL để làm việc xong, bạn có thể liệt kê danh sách các table trong CSDL bằng lệnh:
Mã:
SHOW TABLES;
+---------------------------+
| Tables_in_mysql |
+---------------------------+
| columns_priv |
| db |
| func |
| help_category |
| help_keyword |
| help_relation |
| help_topic |
| host |
| tables_priv |
| time_zone |
| time_zone_leap_second |
| time_zone_name |
| time_zone_transition |
| time_zone_transition_type |
| user |
+---------------------------+
15 rows in set (0.58 sec)
Bạn cũng có thể liệt kê thông tin chi tiết về table bằng lệnh SHOW TABLE STATUS.
- Lệnh SHOW TABLE STATUS; không tham số sẽ liệt kê thông tin về tất cả các table có trong CSDL hiện tại.
- Lệnh SHOW TABLE STATUS FROM db_name; sẽ liệt kê thông tin về tất cả các table trong CSDL có tên là db_name.
- Lệnh SHOW TABLE STATUS FROM db_name LIKE 'tbl_name'; sẽ liệt kê thông tin về table có tên là tbl_name trong CSDL db_name;
- và lệnh SHOW TABLE STATUS LIKE 'tbl_name'; sẽ liệt kê thông tin về table có tên là tbl_name trong CSDL hiện tại.
- Name: tên của table.
- Engine: kiểu của table (VD: InnoDB, MYISAM...).
- Version: phiên bản của table.
- Row_format: kiểu dòng của table (Fixed, Dynamic hoặc Compressed).
- Rows: số lượng dòng có trong table (lưu ý: với một số kiểu table như InnoDB số lượng dòng chỉ là ước lượng chứ không chính xác, bạn cần dùng lệnh SELECT COUNT(*) FROM tbl_name; để lấy chính xác số dòng).
- Avg_row_length: kích thước/độ dài trung bình của một dòng trong table.
- Data_length: kích thước của file lưu trữ table.
- Max_data_length: kích thước tối đa của file lưu trữ table.
- Index_length: kích thước của file index.
- Data_free: dung lượng được cấp phát nhưng chưa được sử dụng trong file.
- Auto_increment: giá trị tiếp theo của cột có kiểu AUTO_INCREMENT trong table.
- Create_time: thời điểm table được tạo.
- Update_time: thời điểm table được cập nhật lần cuối.
- Check_time: thời điểm table được kiểm tra lần cuối.
- Collation: lưu trữ thông tin về charset sử dụng trong table.
- Checksum: giá trị kiểm tra checksum của table.
- Create_options: lưu trữ các thông tin của lệnh CREATE TABLE khi tạo table.
- Comment: thông tin chú thích về table.
Mã:
SHOW CREATE TABLE db;
CREATE TABLE `db` (
`Host` char(60) binary NOT NULL default '',
`Db` char(64) binary NOT NULL default '',
`User` char(16) binary NOT NULL default '',
`Select_priv` enum('N','Y') NOT NULL default 'N',
`Insert_priv` enum('N','Y') NOT NULL default 'N',
`Update_priv` enum('N','Y') NOT NULL default 'N',
`Delete_priv` enum('N','Y') NOT NULL default 'N',
`Create_priv` enum('N','Y') NOT NULL default 'N',
`Drop_priv` enum('N','Y') NOT NULL default 'N',
`Grant_priv` enum('N','Y') NOT NULL default 'N',
`References_priv` enum('N','Y') NOT NULL default 'N',
`Index_priv` enum('N','Y') NOT NULL default 'N',
`Alter_priv` enum('N','Y') NOT NULL default 'N',
`Create_tmp_table_priv` enum('N','Y') NOT NULL default 'N',
`Lock_tables_priv` enum('N','Y') NOT NULL default 'N',
PRIMARY KEY (`Host`,`Db`,`User`),
KEY `User` (`User`)
) TYPE=MyISAM COMMENT='Database privileges';
Tài liệu tham khảo:
- Cú pháp lệnh SHOW TABLES: http://dev.mysql.com/doc/mysql/en/SHOW_TABLES.html.
- Cú pháp lệnh SHOW TABLE STATUS: http://dev.mysql.com/doc/mysql/en/SH...LE_STATUS.html.
- Cú pháp lệnh SHOW CREATE TABLE: http://dev.mysql.com/doc/mysql/en/SH...ATE_TABLE.html.
Để tạo CSDL mới, MySQL cung cấp cho ta lệnh CREATE DATABASE:
Mã:
CREATE DATABASE db_name;
Mã:
DROP DATABASE db_name;
Và bạn cũng có thể xem lại cú pháp câu lệnh CREATE DATABASE của 1 CSDL đã có sẵn bằng lệnh SHOW CREATE DATABASE:
Mã:
SHOW CREATE DATABASE db_name;
Mã:
GRANT quyền ON tên_csdl TO tên_user IDENTIFIED BY 'mật_mã';
- Quyền có dạng như sau:
- ALL PRIVILEGES: tất cả mọi quyền.
- ALTER: cho phép user sử dụng lệnh ALTER TABLE.
- CREATE: cho phép user sử dụng lệnh CREATE TABLE.
- CREATE TEMPORARY TABLES: cho phép user sử dụng lệnh CREATE TEMPORARY TABLE.
- CREATE VIEW: cho phép user sử dụng lệnh CREATE VIEW.
- DELETE: cho phép user sử dụng lệnh DELETE.
- DROP: cho phép user sử dụng lệnh DROP TABLE.
- FILE: cho phép user sử dụng lệnh SELECT ... INTO OUTFILE và LOAD DATE INFILE.
- INDEX: cho phép user sử dụng lệnh CREATE INDEX và DROP INDEX.
- INSERT: cho phép user sử dụng lệnh INSERT.
- LOCK TABLES: cho phép user sử dụng lệnh LOCK TABLES trên những table nào user có quyền SELECT.
- PROCESS: cho phép user sử dụng lệnh SHOW FULL PROCESSLIST.
- RELOAD: cho phép user sử dụng lệnh FLUSH.
- SELECT: cho phép user sử dụng lệnh SELECT.
- SHOW DATABASES: khi user sử dụng lệnh SHOW DATABASES, danh sach của toàn bộ các CSDL trong hệ thống.
- SHOW VIEW: cho phép user sử dụng lệnh SHOW CREATE VIEW.
- UPDATE: cho phép user sử dụng lệnh UPDATE.
- Tên_CSDL có dạng như sau:
- *.*: toàn bộ các CSDL và table trên hệ thống.
- db_name.*: giới hạn quyền trên CSDL có tên là db_name và các table của CSDL này.
- db_name.tbl_name: giới hạn quyền trên table có tên tbl_name trên CSDL có tên db_name.
- Tên_user có dạng như sau:
- 'nbthanh'@'localhost': account với username nbthanh có thể kết nối từ localhost.
- 'nbthanh'@'%': account với username nbthanh có thể kết nối từ bất kỳ nơi nào trừ localhost.
- Nếu trong câu lệnh GRANT không có phần IDENTIFIED BY 'mật_mã' thì account sẽ được tạo với mật mã là rỗng.
GRANT ALL PRIVILEGES ON *.* TO 'nbthanh'@'localhost' IDENTIFIED BY 'my_password';
Lệnh trên sẽ tạo 1 account có username là nbthanh với mật mã là my_password, được phép kết nối từ localhost và có mọi quyền trên tất cả các CSDL có trên hệ thống.
GRANT SELECT ON *.* TO 'nbthanh'@'%' IDENTIFIED BY 'my_password2';
Lệnh trên sẽ tạo 1 account có username là nbthanh với mật mã là my_password2, được phép kết nối từ bất cứ nơi đâu ngoại trừ localhost, nhưng chỉ có quyền đọc (SELECT) trên tất cả các CSDL có trên hệ thống.
Đôi khi bạn sẽ có nhu cầu đổi mật mã cho 1 account mà không muốn thay đổi lại các quyền hiện có của account đó, MySQL cung cấp lệnh SET PASSWORD để thực hiện thao tác này:
Mã:
SET PASSWORD FOR 'nbthanh'@'localhost' = PASSWORD('new_password');
Mã:
SET PASSWORD FOR 'nbthanh'@'%' = PASSWORD('new_password2');
Và cuối cùng, để xoá account ra khỏi hệ thống, MySQL cung cấp cho ta lệnh DROP USER:
Mã:
DROP USER 'nbthanh'@'localhost';
Mã:
DROP USER 'nbthanh'@'%';
Lưu ý: Đôi khi bạn cần phải thực hiện lệnh FLUSH PRIVILEGES; sau khi thực hiện các thao tác thêm/xoá/thay đổi account thì các thao tác mới có hiệu lực.
Tài liệu tham khảo:
- Những gì trình bày ở trên chỉ là một phần sơ lược rất nhỏ trong toàn bộ những gì bạn cần phải nằm vững khi quản trị một MySQL Server. Để quản trị tốt một MySQL Server, bạn hãy nắm kỹ phần Database Administration trong MySQL Manual: http://dev.mysql.com/doc/mysql/en/My...istration.html.
- Cú pháp lệnh CREATE DATABASE: http://dev.mysql.com/doc/mysql/en/CREATE_DATABASE.html.
- Cú pháp lệnh DROP DATABASE: http://dev.mysql.com/doc/mysql/en/DROP_DATABASE.html.
- Cú pháp lệnh SHOW CREATE DATABASE: http://dev.mysql.com/doc/mysql/en/SH..._DATABASE.html.
- Cú pháp lệnh GRANT: http://dev.mysql.com/doc/mysql/en/GRANT.html.
- Cú pháp lệnh SET PASSWORD: http://dev.mysql.com/doc/mysql/en/SET_PASSWORD.html.
- Cú pháp lệnh DROP USER: http://dev.mysql.com/doc/mysql/en/DROP_USER.html.
- Cú pháp lệnh FLUSH PRIVILEGES: http://dev.mysql.com/doc/mysql/en/FLUSH.html.