English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية
テーブルを作成する
create table 表名
create table if not exists 表名
mysql> create database company; Query OK, 1 row affected (0.00 sec) mysql> use company; データベースが変更されました mysql> create table if not exists t_dept( -> deptno int, -> dname varchar(20), -> loc varchar(40)); クエリ OK, 0 行が影響を受けました (0.20 sec) mysql> show tables; +-------------------+ | Tables_in_company | +-------------------+ | t_dept | +-------------------+ 1 row in set (0.00 sec) mysql>
現在のデータベースのすべてのテーブルを表示する
show tables;
mysql> show tables; +-------------------+ | Tables_in_company | +-------------------+ | t_dept | +-------------------+ 1 row in set (0.00 sec)
テーブルの構造を確認する
describe 表名
省略形
desc 表名
mysql> describe t_dept; +--------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +--------+-------------+------+-----+---------+-------+ | deptno | int(11) | はい | | NULL | | | dname | varchar(20) | はい | | NULL | | | loc | varchar(40) | はい | | NULL | | +--------+-------------+------+-----+---------+-------+ 3 セット内の行 (0.00 秒) mysql> desc t_dept; +--------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +--------+-------------+------+-----+---------+-------+ | deptno | int(11) | はい | | NULL | | | dname | varchar(20) | はい | | NULL | | | loc | varchar(40) | はい | | NULL | | +--------+-------------+------+-----+---------+-------+ 3 セット内の行 (0.00 秒)
テーブルの詳細を確認する
show create table 表名
mysql> show create table t_dept; +--------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | Table | Create Table | +--------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | t_dept | CREATE TABLE `t_dept` ( `deptno` int(11) DEFAULT NULL, `dname` varchar(20) DEFAULT NULL, `loc` varchar(40) DEFAULT NULL ) ENGINE=InnoDB DEFAULT CHARSET=utf88 | +--------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------+ 1 row in set (0.00 sec) show create table t_dept \G mysql> show create table t_dept \G *************************** 1. row *************************** Table: t_dept Create Table: CREATE TABLE `t_dept` ( `deptno` int(11) DEFAULT NULL, `dname` varchar(20) DEFAULT NULL, `loc` varchar(40) DEFAULT NULL ) ENGINE=InnoDB DEFAULT CHARSET=utf88 1 row in set (0.00 sec)
表を削除する
drop table 表名
drop table if exists 表名
mysql> drop table if exists t_dept; クエリ OK, 0 行が影響を受けました (0.12 sec) mysql> show tables; Empty set (0.00 sec)
修改表名
ALTER TABLE old_table_name RENAME [TO] new_table_name
old_table_name 原表名
new_table_name 新表名
将t_dept修改为tab_dept
mysql> alter table t_dept rename tab_dept; クエリ OK, 0 行が影響を受けました (0.09 sec) mysql> show tables; +-------------------+ | Tables_in_company | +-------------------+ | tab_dept | +-------------------+ 1 row in set (0.00 sec) mysql> desc tab_dept; +--------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +--------+-------------+------+-----+---------+-------+ | deptno | int(11) | はい | | NULL | | | dname | varchar(20) | はい | | NULL | | | loc | varchar(40) | はい | | NULL | | +--------+-------------+------+-----+---------+-------+ 3 セット内の行 (0.00 秒)
为表增加一个字段默认在最后
ALTER TABLE table_name ADD 属性名 属性类型
为tab_dept增加一个字段descri varchar(20)
mysql> desc tab_dept; +--------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +--------+-------------+------+-----+---------+-------+ | deptno | int(11) | はい | | NULL | | | dname | varchar(20) | はい | | NULL | | | loc | varchar(40) | はい | | NULL | | +--------+-------------+------+-----+---------+-------+ 3 セット内の行 (0.00 秒) mysql> alter table tab_dept add descri varchar(20); クエリ OK, 0 行が影響を受けました (0.33 sec) レコード: 0 重複: 0 警告: 0 mysql> desc tab_dept; +--------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +--------+-------------+------+-----+---------+-------+ | deptno | int(11) | はい | | NULL | | | dname | varchar(20) | はい | | NULL | | | loc | varchar(40) | はい | | NULL | | | descri | varchar(20) | はい | | NULL | | +--------+-------------+------+-----+---------+-------+ 4 セット内の行 (0.00 秒)
在表的第一个位置增加一个字段
ALTER TABLE table_name ADD 属性名 属性类型 first
mysql> alter table tab_dept add id int first; クエリ OK, 0 行が影響を受けました (0.38 sec) レコード: 0 重複: 0 警告: 0 mysql> desc tab_dept; +--------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +--------+-------------+------+-----+---------+-------+ | id | int(11) | はい | | NULL | | | deptno | int(11) | はい | | NULL | | | dname | varchar(20) | はい | | NULL | | | loc | varchar(40) | はい | | NULL | | | descri | varchar(20) | はい | | NULL | | +--------+-------------+------+-----+---------+-------+ 5 セット内の行 (0.00 秒)
在表的指定字段之后增加字段
ALTER TABLE table_name ADD 属性名 属性类型 AFTER 属性名
mysql> alter table tab_dept add comm varchar(20) after dname; クエリ OK, 0 行が影響を受けました (0.31 sec) レコード: 0 重複: 0 警告: 0 mysql> desc tab_dept; +--------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +--------+-------------+------+-----+---------+-------+ | id | int(11) | はい | | NULL | | | deptno | int(11) | はい | | NULL | | | dname | varchar(20) | はい | | NULL | | | comm | varchar(20) | はい | | NULL | | | loc | varchar(40) | はい | | NULL | | | descri | varchar(20) | はい | | NULL | | +--------+-------------+------+-----+---------+-------+ 6 セット内の行 (0.00 秒)
删除字段
ALTER TABLE table_name DROP 属性名
mysql> alter table tab_dept drop comm; クエリ OK, 0 行が影響を受けました (0.32 sec) レコード: 0 重複: 0 警告: 0 mysql> desc tab_dept; +--------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +--------+-------------+------+-----+---------+-------+ | id | int(11) | はい | | NULL | | | deptno | int(11) | はい | | NULL | | | dname | varchar(20) | はい | | NULL | | | loc | varchar(40) | はい | | NULL | | | descri | varchar(20) | はい | | NULL | | +--------+-------------+------+-----+---------+-------+ 5 セット内の行 (0.00 秒)
フィールドの変更-修改字段数据类型
ALTER TABLE table_name MODIFY 属性名 数据类型
mysql> alter table tab_dept modify descri int; クエリ OK, 0 行が影響を受けました (0.45 sec) レコード: 0 重複: 0 警告: 0 mysql> desc tab_dept; +--------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +--------+-------------+------+-----+---------+-------+ | id | int(11) | はい | | NULL | | | deptno | int(11) | はい | | NULL | | | dname | varchar(20) | はい | | NULL | | | loc | varchar(40) | はい | | NULL | | | descri | int(11) | はい | | NULL | | +--------+-------------+------+-----+---------+-------+ 5 セット内の行 (0.00 秒)
フィールドの変更-修改字段名称
ALTER TABLE table_name CHANGE 旧属性名 新属性名 旧数据类型
mysql> alter table tab_dept change id deptid int; クエリ OK, 0 行が影響を受けました (0.07 sec) レコード: 0 重複: 0 警告: 0 mysql> desc tab_dept; +--------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +--------+-------------+------+-----+---------+-------+ | deptid | int(11) | はい | | NULL | | | deptno | int(11) | はい | | NULL | | | dname | varchar(20) | はい | | NULL | | | loc | varchar(40) | はい | | NULL | | | descri | int(11) | はい | | NULL | | +--------+-------------+------+-----+---------+-------+ 5 セット内の行 (0.00 秒)
フィールドの変更-同時にフィールド名とデータ型を変更
ALTER TABLE table_name CHANGE 旧属性名 新属性名 新データ型
mysql> alter table tab_dept change deptid id varchar(32); クエリ OK, 0 行が影響を受けました (0.49 sec) レコード: 0 重複: 0 警告: 0 mysql> desc tab_dept; +--------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +--------+-------------+------+-----+---------+-------+ | id | varchar(32) | はい | | NULL | | | deptno | int(11) | はい | | NULL | | | dname | varchar(20) | はい | | NULL | | | loc | varchar(40) | はい | | NULL | | | descri | int(11) | はい | | NULL | | +--------+-------------+------+-----+---------+-------+ 5 セット内の行 (0.00 秒)
変更順序
ALTER TABLE table_name MODIFY 属性名1 データ型 FIRST|AFTER 属性名2
2属性は必須です
deptnoを最初の位置に配置
mysql> alter table tab_dept modify deptno int first; クエリ OK, 0 行が影響を受けました (0.33 sec) レコード: 0 重複: 0 警告: 0 mysql> desc tab_dept; +--------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +--------+-------------+------+-----+---------+-------+ | deptno | int(11) | はい | | NULL | | | id | varchar(32) | はい | | NULL | | | dname | varchar(20) | はい | | NULL | | | loc | varchar(40) | はい | | NULL | | | descri | int(11) | はい | | NULL | | +--------+-------------+------+-----+---------+-------+ 5 セット内の行 (0.00 秒)
IDを最後に配置
mysql> alter table tab_dept modify deptno int after descri; クエリ OK, 0 行が影響を受けました (0.29 sec) レコード: 0 重複: 0 警告: 0 mysql> desc tab_dept; +--------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +--------+-------------+------+-----+---------+-------+ | id | varchar(32) | はい | | NULL | | | dname | varchar(20) | はい | | NULL | | | loc | varchar(40) | はい | | NULL | | | descri | int(11) | はい | | NULL | | | deptno | int(11) | はい | | NULL | | +--------+-------------+------+-----+---------+-------+ 5 セット内の行 (0.00 秒) mysql> alter table tab_dept modify deptno int first; クエリ OK, 0 行が影響を受けました (0.34 sec) レコード: 0 重複: 0 警告: 0 mysql> alter table tab_dept modify id int after descri; クエリ OK, 0 行が影響を受けました (0.47 sec) レコード: 0 重複: 0 警告: 0 mysql> desc tab_dept; +--------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +--------+-------------+------+-----+---------+-------+ | deptno | int(11) | はい | | NULL | | | dname | varchar(20) | はい | | NULL | | | loc | varchar(40) | はい | | NULL | | | descri | int(11) | はい | | NULL | | | id | int(11) | はい | | NULL | | +--------+-------------+------+-----+---------+-------+ 5 セット内の行 (0.00 秒)