MySQL数据库语言学习之DML

对表结构的增删改?

对于表结构的修改,这里不讲了,大家使用工具完成即可,因为在实际开发中表一旦设计好之后,对表结构的修改是很少的,修改表结构,成本过高!!

修改表结构就是对之前的设计进行了否定,即使需要修改表结构,我们也可以直接使用工具操作。

修改表结构的语句不会出现在Java代码当中。

什么是对表结构的修改?

添加一个字段 ,删除一个字段 ,修改一个字段! ! !

出现在java 代码当中的sql 包括:

insert delete update select (这些都是表中的数据操作。)

数据操作语言(凡是对表中++数据++的增删改均为DML

Insert 增 delete 删 update

  1. 插入数据insert
语法格式:

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

要求:字段的数量和值的数量相同,并且数据类型要对应相同。

需要注意的地方:

当一条insert 语句执行成功之后,表格当中必然会多一行记录。

即使多的这一行记录当中某些字段是NULL ,后期也没有办法再执行

insert 语句插入数据了,只能使用update 进行更新。

// 字段可以省略不写,但是后面的value 对数量和顺序都有要求。

一次插入多行数据:

insert into t_student

(no,name,sex,classno,birth)

values

(3,'rose','1','gaosi2ban','1952-12-14'),

(4,'laotie','1','gaosi2ban','1955-12-14');

插入日期insert

插入数据?

insert into t user(id,name ,birth) values(1, 'zhangsan','01-10-19901'):

// 1990年10月1日

出问题了:

原因是类型不匹配。

数据库birth是date类型,这里给了一个字符串varchar

怎么办?

可以使用str_to_date函数进行类型转换。

str to date函数可以将字符串转换成日期类型date?

语法格式:

str to date('字符串日期',日期格式);

Str_to_date函数可以把字符串varchar转换成日期date类型数据

通常使用在插入insert方面,因为插入的时候需要一个日期类型的数据,

需要通过该函数将字符串转换成date。

但是,

如果你提供的日期字符串是这个格式,str to date数就不需要了!!!

%Y-%m-%d

Mysql中的日期格式:

%Y 年

%m 月

%d 日

%h 时

%i 分

%s 秒

insert into t_user(id,name ,birth) values(1,'zhangsan',str to date('01-10-1990','%d_%m_%Y'));

查询的时候可以以某个特定的日期格式展示吗?

date format( 日期类型数据,' 日期格式')

这个函数可以将日期类型转换成特定格式的字符串

date和datetime两个类型的区别?

date是短日期: 只包括年月日信息。

datetime是长日期: 包括年月日时分秘信息。

在mysql当中怎么获取系统当前时间?

now() 函数,并且获取的时间带有: 时分秘信息! !!! 是datetime类型的

  1. 修改数据:update

语法格式:

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

注意:没有条件整张表数据全部更新

mysql> update t_user set name = 'jack',birth = '2000-1-15',create_time = now() where create_time = '2024-03-21 09:14:41';

  1. 删除数据?

语法格式:

delete from 表名 where 条件;

注意:没有条件全部删除。

mysql> delete from t_user where id = 2;

增删改查有一个术语:CRUD操作

Create(增) Retrieve(检索) Update(修改) Delete(删除)

快速删除表中数据怎么删除大表中的数据?(重点)
  • 删除表?

drop table 表名; // 这个通用。

drop table if exists 表名; // oracle不支持这种写法

  • 删除大表中的数据。

Delete from emp4; //DML语句

缺点:空间不释放,效率较低

优点:后悔可回滚rollback恢复!

  • truncate语句删除数据的原理?

用法: truncate table 表名; //DDL操作

优点:效率比较高,表被一次截断,物理删除,快速。

缺点:不支持回滚

大表非常大,上亿条记录? ? ? ?

删除的时候,使用delete,也许需要执行1个小时才能删除完! 效率较低。

可以选择使用truncate删除表中的数据。只需要不到1秒钟的时间就删除结束。效率较高。

但是!!!使用truncate之前,必须仔细询问客户是否真的要删除,并警告删除之后不可恢复!

truncate table 表名; // 表被截断,不可回滚。永久丢失。

相关推荐
码农小站12 分钟前
ClickHouse 时间范围查询:精准筛选「本月数据」
数据库
paopaokaka_luck38 分钟前
基于SpringBoot+Vue的非遗文化传承管理系统(websocket即时通讯、协同过滤算法、支付宝沙盒支付、可分享链接、功能量非常大)
java·数据库·vue.js·spring boot·后端·spring·小程序
运营黑客1 小时前
Grok 4,来了。
人工智能·学习·ai·aigc
小疯仔1 小时前
navicat导出数据库的表结构
数据库
TOSUN同星1 小时前
干货分享 | TSMaster DBC编辑器操作指南:功能详解+实战示例
数据库·oracle·编辑器·汽车·软件工程
LIN-JUN-WEI2 小时前
[ESP32]VSCODE+ESP-IDF环境搭建及blink例程尝试(win10 win11均配置成功)
c语言·开发语言·ide·vscode·单片机·学习·编辑器
huihui4502 小时前
一天一道Sql题(day01)
数据库
~尼卡~2 小时前
软考(软件设计师)数据库原理:事务管理,备份恢复,并发控制
数据库·软件设计师-软考
八九燕来2 小时前
Django双下划线查询
数据库·django·sqlite
眠りたいです3 小时前
Mysql常用内置函数,复合查询及内外连接
linux·数据库·c++·mysql