MySql超详细讲解表的用法

作者:在人间负债^ 时间:2024-01-28 02:06:29 

1. 建表的语法

建表属于 DDL 语句,DDL 语句包括:create、drop、alter…

create table 表名(字段1 数据类型, 字段2 数据类型 ... );

表名:建议以 t_ 或者 tbl_ 开始,可读性强。见名知意。

字段名:见名知意。

表名和字段名都属于标识符。

2. mysql中的数据类型

  • varchar

最长 255

可变长度的字符串。

比较智能,节省空间。

会根据实际的数据长度分配空间。

  • char

最长 255

定长字符串

不管实际的数据长度是多少。

分配固定长度的空间去存储数据。

使用不恰当的时候,可能会导致空间的浪费。

varchar 动态的分配空间,速度慢

char 固定的分配空间,速度快 具体的选择根据实际情况来选择 比如:姓名:varchar;性别:char

  • int

最长 11

数字中的整数型。

等同于 java 中的 int。

  • bigint

数字中的长整型。

等同于 java 中的 long 。

  • float

单精度浮点型数据。

  • double

双精度浮点型数据。

  • date

短日期类型。

  • datetime

长日期类型。

  • clob

字符大对象。

最多可以存储 4G 的字符串。

比如:存储一篇文章,存储一个说明。

超过 255 个字符的都要采用 CLOB 字符大对象来存储。

  • blob

二进制大对象。

专门用来存储图片、声音、视频等流媒体数据。

往 BLOB 类型的字段上插入数据的时候,例如插入一个图片、视频等。

你需要使用 IO 流才行。

3. 模拟表

  • t_movie 电影表(专门存储电影信息的)

  • no(bigint):编号

  • name(varchar):名字

  • history(clob):故事情节

  • playtime(date):上映日期

  • time(double):时长

  • image(blob):海报

  • type(cahr):类型

4. 创建一个学生表

学号、姓名、年龄、性别、邮箱地址

1. 创建表(create-DDL)

mysql> create table t_student (no int, name varchar(32), sex char(1), age int(3), email varchar(255));

MySql超详细讲解表的用法

MySql超详细讲解表的用法

2. 插入数据(insert-DML)

语法格式

insert into 表名(字段名1, 字段名2, 字段名3...) values(值1, 值2, 值3...);

注意:字段名和值要一一对应。(数量要对应。数据类型要对应。)

mysql> insert into t_student(no, name, sex, age, email) values(1, 'zhangsan', 'm', 20, 'zhangsan@123.com');
mysql> insert into t_student(no, name, sex, age, email) values(1, 'lisi', 'm', 20, 'lisi@123.com');

MySql超详细讲解表的用法

mysql> insert into t_student(no) values(3);

没有给其他字段指定值的时候,默认值是 null

MySql超详细讲解表的用法

insert 语句中的字段名可以省略,省略的话默认是全部写上了,所以按照一一对应原则,values 中的值要全部写上。

3. 插入日期

format:数字格式化

format(数字, '格式')

str_to_date:将字符串 varchar 类型转换成 date 类型

str_to_date('字符串日期', '日期格式')

date_format:将 date 类型转换成具有一定格式的 varchar 类型

mysql> create table t_user(id int, name varchar(32), birth date);

MySql超详细讲解表的用法

插入数据?

mysql> insert into t_user(id, name, birth) values(1, 'zhangsan', str_to_date('01-01-1990', '%d-%m-%Y'));

str_to_date 将字符串类型的日期转换成 date 类型的日期

MySql超详细讲解表的用法

但是!!!如果提供的字符串日期格式是%Y_%m-%d的话,就不需要str_to_date函数了,mysql会自动转换。

mysql> insert into t_user(id, name, birth) values(2, 'lisi', '1990-10-01');

MySql超详细讲解表的用法

4. date和datetime的区别

date:短日期,只包括 年月日

dateime:长日期,包括 年月日时分秒

短日期默认格式:%Y-%m-%d

长日期默认格式:%Y-%m-%d %h:%i:%s

在 mysql 中 now() 函数可以获取系统当前时间,是长时间格式

5. 更新(update-DML)

语法格式

update 表名 set 字段1=值1, 字段2=值2 ... where 条件;

注意:如果没有限制条件,会导致所有的数据全部进行更新

mysql> update t_user set name = 'jack', birth = '2022-9-2' where id = 2;

MySql超详细讲解表的用法

mysql> select * from t_user;

MySql超详细讲解表的用法

6. 删除(delete-DML)

语法格式

delete from 表名 where 条件;

注意:如果没有条件,整张表的数据都会被删除。

mysql> delete from t_user where id = 2;

MySql超详细讲解表的用法

mysql> delete from t_user;

MySql超详细讲解表的用法

5. 快速创建表(复制表)

原理:

将一个查询结果当做一张表新建!!! 这个可以完成表的快速复制!!! 表创建出来,同时表中的数据也存在了!!!

mysql> create table emp2 as select * from emp;

MySql超详细讲解表的用法

6. 快速删除表中数据

delete 语句(DML)删除数据的原理?

  1. 表中的数据被删除了,但是这个数据在硬盘上的真实存储空间不会被释放!!!

  2. 这种删除的缺点是:删除效率比较低。

  3. 这种删除的优点是:支持回滚,后悔了可以再恢复数据!!!

truncate 语句(DDL)删除数据的原理?

  • 这种删除属于物理删除。

  • 这种删除的缺点是:不支持回滚。

  • 这种删除的优点是:效率较低。

truncate table 表名;

来源:https://blog.csdn.net/qq_52354698/article/details/126667279

标签:Mysql,表
0
投稿

猜你喜欢

  • Postman使用详解

    2023-09-03 05:59:36
  • python脚本后台执行方式

    2021-02-12 20:57:58
  • mysql 查询表中平均分最低的班级

    2024-01-22 05:23:45
  • 详解利用装饰器扩展Python计时器

    2023-04-08 20:32:16
  • YOLOv5车牌识别实战教程(四)模型优化与部署

    2021-04-22 01:32:27
  • Python实现投影法分割图像示例(二)

    2021-04-19 01:53:18
  • 详解Python装饰器之@property

    2021-06-25 15:55:45
  • SQL查询超时的设置方法(关于timeout的处理)

    2024-01-15 21:07:55
  • Python面向对象类编写细节分析【类,方法,继承,超类,接口等】

    2023-01-01 11:23:13
  • 记一次vue-webpack项目优化实践详解

    2023-07-02 16:37:22
  • python基本语法练习实例

    2021-02-25 06:50:07
  • vscode 配置eslint和prettier正确方法

    2022-12-31 04:54:44
  • python接口自动化测试数据和代码分离解析

    2022-12-29 06:00:11
  • python读取文件名并改名字的实例

    2021-03-19 12:45:37
  • python实现高斯投影正反算方式

    2022-11-17 08:58:19
  • Django 查询数据库并返回页面的例子

    2024-01-15 20:08:37
  • asp如何显示存储在数据库BLOB字段中的图像?

    2010-06-08 09:31:00
  • 在SUSE10环境下安装和配置MySQL数据库

    2008-12-17 15:03:00
  • python用tkinter开发的扫雷游戏

    2022-05-16 18:39:40
  • 基于JS实现十种酷炫的网页特效

    2024-04-17 09:56:53
  • asp之家 网络编程 m.aspxhome.com