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 表名; // 表被截断,不可回滚。永久丢失。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值