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


总结

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

相关推荐
晋阳十二夜5 小时前
【压力测试之_Jmeter链接Oracle数据库链接】
数据库·oracle·压力测试
GDAL6 小时前
Node.js v22.5+ 官方 SQLite 模块全解析:从入门到实战
数据库·sqlite·node.js
DCTANT7 小时前
【原创】国产化适配-全量迁移MySQL数据到OpenGauss数据库
java·数据库·spring boot·mysql·opengauss
程序员岳焱9 小时前
Java 与 MySQL 性能优化:MySQL全文检索查询优化实践
后端·mysql·性能优化
喜欢敲代码的程序员9 小时前
SpringBoot+Mybatis+MySQL+Vue+ElementUI前后端分离版:项目搭建(一)
spring boot·mysql·elementui·vue·mybatis
AI、少年郎9 小时前
Oracle 进阶语法实战:从多维分析到数据清洗的深度应用(第四课)
数据库·oracle
赤橙红的黄9 小时前
自定义线程池-实现任务0丢失的处理策略
数据库·spring
钢铁男儿10 小时前
C# 委托(调用带引用参数的委托)
java·mysql·c#
叁沐10 小时前
MySQL 02 日志系统:一条SQL更新语句是如何执行的?
mysql
DataGear10 小时前
如何在DataGear 5.4.1 中快速制作SQL服务端分页的数据表格看板
javascript·数据库·sql·信息可视化·数据分析·echarts·数据可视化