《MySQL对数据库中表的结构的操作》

文章目录


以下的数据库表的操作全是基于user_db这个数据库操作的,表是基于user_db这个数据库中的user表操作的。

一、建表

cpp 复制代码
CREATE TABLE table_name (
field1 datatype,
field2 datatype,
field3 datatype
) character set 字符集 collate 校验规则 engine 存储引擎;

字符集和校验规则不写就使用数据库的默认的字符集和校验规则。

engine后面跟表的存储引擎,不同的存储引擎,保存的文件不同。

eg:

cpp 复制代码
create  table users (
 id int,
 name varchar(20) comment '用户名',
 password char(32) comment '密码是32位的md5值',
 birthday date comment '生日'
) character set utf8 engine MyISAM;

二、查看表结构

desc 表名

还可以这样查看创建表时的信息:

show create table user1 \G;

\G选项可以去掉,去掉后就是这样:

所有能查看到数据库,表的操作痕迹的本质都是服务器保存下来了这些操作记录。

三、修改表

1.改表名字

alter table 原表名 rename to 新表名;

2.添加表记录

insert into user values(...);

比如:

mysql> insert into users values(1,'a','b','1982-01-04'),(2,'b','c','1984-01-04');

3.添加表的更多字段

比如:

alter tables user add image_path varchar(128) comment '用户图像路径';

在user表中添加一个image_path字段,保存用户头像路径。

还可以这样写:

alter tables user add image_path varchar(128) comment '用户图像路径' after birthday;

指明该image_path字段要跟在birthday字段后面。

4.修改表的字段

alter table user modify name varchar(60)

将name字段的可变类型改成60大小。(原来是20)

alter table user change name xingming varchar(60);

将name列修改成xingming列,并设置字段属性为varchar(60);

5. 删除表的字段

alter table user drop + 字段名

注意:删除表字段的时候,务必保证没有数据了,或者删除后不影响,否则删除就是永久性的,谨慎!

四、修改表的数据

1.删除表的数据

假如想要删除一个id为123的数据行。

delete from + 表名 + where id=123;

2.修改表的数据

假如想要将id='123'所在行的qq修改成'26653'

update + 表名 set qq='26653' where id='123';

3.向表中添加数据

insert into + 表名(要添加的数据类型) values(要添加的数据);

比如想从student表中添加一行数据,student表有几个字段:

1.id 2.name 3.telephone

则添加的指令是:

insert into student(id,name,telephone) values(123,'张三','197401');

像上面这种,全部都添加的,可以把数据名省略:

insert into student values(123,'张三','197401');

如果只需要添加其中一个或几个类型:

insert into student(name) values('张三');


总结

以上的操作都是对表的结构的操作。

相关推荐
若兰幽竹2 小时前
【从零开始编写数据库:基于Python语言实现数据库ToyDB的ACID特性】
数据库·python
宇钶宇夕2 小时前
S7-200 SMART CPU 密码清除全指南:从已知密码到忘记密码的解决方法
运维·服务器·数据库·程序人生·自动化
周杰伦的稻香2 小时前
MySQL密码管理器“mysql_config_editor“
数据库·mysql
云朵大王2 小时前
SQL 视图与事务知识点详解及练习题
java·大数据·数据库
czhc11400756633 小时前
LINUX712 MYSQL;磁盘分区;NFS
数据库·mysql·adb
叁沐3 小时前
MySQL 13 为什么表数据删掉一半,表文件大小不变?
mysql
不太可爱的大白3 小时前
Mysql:分库分表
数据库·mysql
四季豆豆豆3 小时前
博客项目 laravel vue mysql 第四章 分类功能
vue.js·mysql·laravel
十五年专注C++开发4 小时前
hiredis: 一个轻量级、高性能的 C 语言 Redis 客户端库
开发语言·数据库·c++·redis·缓存
憨堡包^—^4 小时前
Docker —— MySQL主从复制集群
mysql·docker·容器