《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('张三');


总结

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

相关推荐
hef2884 小时前
如何生成特定SQL的AWR报告_@awrsqrpt.sql深度剖析单条语句性能
jvm·数据库·python
xcjbqd05 小时前
Python API怎么加Token认证_JWT生成与验证拦截器实现
jvm·数据库·python
二月十六6 小时前
SQL Server 2022 新语法:IS [NOT] DISTINCT FROM 彻底解决 NULL 比较难题
数据库·sqlserver
~ rainbow~6 小时前
前端转型全栈(四)——常见的错误及解决方案
数据库·oracle·全栈
数厘6 小时前
2.1SQL 学习:先懂数据库概念再学 SQL
数据库·sql·学习
Cat_Rocky6 小时前
redis哨兵模式
数据库·redis
广师大-Wzx6 小时前
一篇文章看懂MySQL数据库(下)
java·开发语言·数据结构·数据库·windows·python·mysql
hef2887 小时前
golang如何使用range over func_golang range over func迭代器使用方法
jvm·数据库·python
qq_380619168 小时前
html如何查看windows
jvm·数据库·python
爱学习的小邓同学8 小时前
MySQL --- MySQL数据库基础
数据库·mysql