一文带你学透SQL语言的核心之DML操作

 更新时间:2023年06月07日 10:44:24   作者:陈橘又青  
DML(Data Manipulation Language)是SQL语言的核心部分,其主要用于对数据库的数据进行增删改查,在学习数据时,学习DML操作是必不可少的一部分,本文就带大家详细了解SQL语言的核心DML操作,需要的朋友可以参考下

我们已经基本学会了写SQL来操作数据库,但在命令行中写SQL时,往往有体验感差,效率低等问题,今天开始我们就学习一下在MySQL的图形化客户端Navicat中执行SQL语句

Navicat 为数据库管理、开发和维护提供了一款直观而强大的图形界面,大大的提高了工作效率,建议在学习中也使用这款开发工具。接下来,在Navicat中新建查询,我们就可以编写SQL并且执行SQL语句了。

1.添加数据

给指定列添加数据:

insert into 表名(列名1,列名2...) values(值1,值2...);

​​​​​给全部列添加数据:

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

批量添加数据:

insert into 表名(列名1,列名2...) values(值1,值2...),(值1,值2...),(值1,值2...)...;

批量添加数据(省略字段名):

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

在开发过程中添加数据的时间是不建议省略字段名的,这样降低了代码的可读性,使效率下降。下面是添加数据的小案例:

查询表中的所有数据的方法是:

select * from 表名;

后面会用到的。

需求:往下面的tb_user表中添加一条数据。

insert into tb_user(id,name) values(2,'李四');

添加成功:

2.修改数据

修改表的数据:

update 表名 set 列名1=值1,列名2=值2...[where 条件];

在修改数据时,也可以不使用where条件,此时的操作是修改整列数据,这样的操作是很危险的。

需求:把下面tb_user表中的张三的密码改为abc23

update tb_user set passwor d ='abc123' where name='张三';

修改成功:

3.删除数据

删除表的数据:

delete from 表名 [where 条件];

在删除某条数据时,如果不使用where条件,将会导致删除整个表的数据。

需求:删除tb_user表中的李四记录。

delete from tb_user where name='李四';

操作成功:

4.查询数据

下面给出一些SQL语言的DML查询数据的例子:

  • 查询student表中所有数据
SELECT * FROM student;
  • 查询student表中所有年龄大于等于18岁的学生数据
SELECT * FROM student WHERE age >= 18;
  • 查询student表中男生(gender为’男’)的平均年龄
SELECT AVG(age) FROM student WHERE gender = '男';
  • 查询student表中年龄最大的学生的信息
SELECT * FROM student WHERE age = (SELECT MAX(age) FROM student);
  • 查询student表中,各性别(gender)的学生数量
SELECT gender, COUNT(*) FROM student GROUP BY gender;
  • 查询student表中,年龄排名前三的学生的姓名和年龄
SELECT name, age FROM (
    SELECT name, age, RANK() OVER (ORDER BY age DESC) AS rank
    FROM student
) AS tbl WHERE rank <= 3;

上面这些例子涉及到了查询全部数据、条件查询、聚合函数、子查询、分组和排序等多种查询方式。在实际应用中,可根据需要选择不同的查询方式来获取所需的数据。

5.注意事项

  • 在学习DML操作时,需要注意以下几点:
  • 注意SQL语句的语法和格式,不要犯错。
  • 在进行数据修改操作时,一定要谨慎,尤其是DELETE语句,一定要确认数据删除的范围和内容。
  • 在进行数据查询操作时,要明确查询的条件和要检索的列名,以避免不必要的查询负担。
  • 在进行复杂查询操作时,要深入理解SQL语言的实现原理和查询优化技术,以提高数据操作效率和质量。

6.总结

学习DML操作是学习数据操作的重要基础步骤,只有熟练掌握并灵活运用DML操作,才能更好地管理和利用数据。

到此这篇关于一文带你学透SQL语言的核心之DML操作的文章就介绍到这了,更多相关SQL语言之DML操作内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • mysql中cast函数用法小结

    mysql中cast函数用法小结

    在MySQL中,CAST函数用于将一个表达式转换为指定的数据类型,本文主要介绍了mysql中cast函数用法小结,具有一定的参考价值,感兴趣的可以了解一下
    2023-12-12
  • MySQL系列之九 mysql查询缓存及索引

    MySQL系列之九 mysql查询缓存及索引

    缓存SELECT操作或预处理查询的结果集和SQL语句,当有新的SELECT语句或预处理查询语句请求,先去查询缓存,判断是否存在可用的记录集,判断标准:与缓存的SQL语句,是否完全一样,区分大小写
    2021-07-07
  • Mysql使用insert插入多条记录 批量新增数据

    Mysql使用insert插入多条记录 批量新增数据

    这篇文章主要介绍了Mysql使用insert插入多条记录批量新增数据,需要的朋友可以参考下
    2017-08-08
  • mysql-5.7.42升级到mysql-8.2.0(二进制方式)

    mysql-5.7.42升级到mysql-8.2.0(二进制方式)

    随着数据量的增长和业务需求的变更,我们可能需要升级MySQL,本文主要介绍了mysql-5.7.42升级到mysql-8.2.0(二进制方式),具有一定的参考价值,感兴趣的可以了解一下
    2024-03-03
  • MySQL新建用户中的%到底包不包括localhost?

    MySQL新建用户中的%到底包不包括localhost?

    操作MySQL的时候发现,有时只建了%的账号,可以通过localhost连接,有时候却不可以,网上搜索也找不到满意的答案,干脆手动测试一波
    2019-02-02
  • Idea连接MySQL数据库出现中文乱码的问题

    Idea连接MySQL数据库出现中文乱码的问题

    这篇文章主要介绍了Idea连接MySQL数据库出现中文乱码的问题,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-04-04
  • MySQL索引失效的问题解决

    MySQL索引失效的问题解决

    索引可以大大提高查询速度和效率,但如果索引失效了,查询的效率会变得非常低,本文主要介绍了MySQL索引失效的问题解决,感兴趣的可以了解一下
    2024-05-05
  • mysql中DCL常用的用户和权限控制

    mysql中DCL常用的用户和权限控制

    这篇文章主要介绍了mysql中DCL常用的用户和权限控制,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-03-03
  • MySQL如何让一个表中可以有多个自增列

    MySQL如何让一个表中可以有多个自增列

    这篇文章主要介绍了MySQL如何让一个表中可以有多个自增列,自增列可使用 auto_increment 来实现,当一个列被标识为 auto_increment 之后,在添加时如果不给此列设置任何值,或给此列设置 NULL 值时,那么它会使用自增的规则来填充此列
    2022-06-06
  • mysql 开启慢查询 如何打开mysql的慢查询日志记录

    mysql 开启慢查询 如何打开mysql的慢查询日志记录

    mysql慢查询日志对于跟踪有问题的查询非常有用,可以分析出当前程序里有很耗费资源的sql语句,那如何打开mysql的慢查询日志记录呢,接下来将详细为您介绍
    2012-11-11

最新评论