表的操作
创建表
示例:
[root@VM-8-9-centos db1]# pwd
/var/lib/mysql/db1
[root@VM-8-9-centos db1]# ll
total 20
-rw-r----- 1 mysql mysql 65 May 22 15:55 db.opt
-rw-r----- 1 mysql mysql 8700 May 22 17:05 users.frm
-rw-r----- 1 mysql mysql 0 May 22 17:05 users.MYD
-rw-r----- 1 mysql mysql 1024 May 22 17:05 users.MYI
查看数据库文件
[root@VM-8-9-centos mysql]# cat /etc/my.cnf # 查看配置文件中的 datadir
datadir=/var/lib/mysql
[root@VM-8-9-centos mysql]# cd /var/lib/mysql # 进入
[root@VM-8-9-centos mysql]# ls
auto.cnf client-cert.pem ib_buffer_pool ib_logfile1 mysql.sock private_key.pem server-key.pem
ca-key.pem client-key.pem ibdata1 ibtmp1 mysql.sock.lock public_key.pem sys
ca.pem db1 ib_logfile0 mysql performance_schema server-cert.pem
查看表
- 查看当前库中的所有表
show tables;
- 查看表的结构
desc 表名;
修改表
在项目实际开发中,经常修改某个表的结构,比如字段名字,字段大小,字段类型,表的字符集类型,表的存储引擎等等。我们还有需求,添加字段,删除字段等等。这时我们就需要修改表。
ALTER TABLE tablename ADD (column datatype [DEFAULT expr][,column datatype]...); // first - after
ALTER TABLE tablename MODIfy (column datatype [DEFAULT expr][,column datatype]...);
ALTER TABLE tablename DROP (column);
modify 与 change
1. MODIFY用于修改已有列的数据类型和约束条件,但不修改列的名称
2. CHANGE用于修改表的列名、数据类型和约束条件
因此,如果只需要修改列的数据类型和约束条件,使用MODIFY语句即可;如果需要修改列名、数据类型和约束条件,使用CHANGE语句
- 在users表添加二条记录
mysql> insert into users values(1,'a','b','1982-01-04'),(2,'b','c','1984-01-04');
- 在users表添加一个字段,用于保存图片路径
mysql> alter table users add assets varchar(100) comment '图片路径' after birthday;
- 修改name,将其长度改成60
mysql> alter table users modify name varchar(60);
- 删除password列
alter table users drop password; # 注意:删除字段一定要小心,删除字段及其对应的列数据都没了
- 修改表名为employee
mysql> alter table users rename to employee; # to:可以省掉
- 将name列修改为xingming
mysql>alter table employee change name xingming varchar(60); --新字段需要完整定义
- 查询表中数据
mysql> select * from users;
删除表
注意
表名:stu
+-------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| ID | int(10) | NO | PRI | NULL | |
| sn | int(11) | YES | UNI | NULL | |
| name | varchar(10) | YES | | NULL | |
+-------+-------------+------+-----+---------+-------+
modify: 修改表的属性 是 field type 后面的东西,还有就是修改属性时要带上 filed type
change: 修改file type
rename: 修改表名