常用SQL语句总结

news2024/11/26 23:34:51

SQL语句

文章目录

  • SQL语句
  • 1 SQL语句简介
  • 2 DQL(数据查询语句)
  • 3 DML(数据操纵语句)
  • 4 DDL(数据定义语句)
  • 5 DCL(数据控制语句)
  • 6 TCL(事务控制语句)

在这里插入图片描述

1 SQL语句简介

SQL(Structured Query Language)语言用于管理和操作关系型数据库。它包括以下几种主要的语句类型:

  1. 数据查询语句(Data Query Language,简称DQL):用于从数据库中检索数据的语句。常见的DQL语句是SELECT语句,用于从数据库表中查询特定的数据行和列。
  2. 数据操纵语句(Data Manipulation Language,简称DML):用于操作数据库中的数据的语句。常见的DML语句包括INSERT、UPDATE和DELETE,分别用于插入、更新和删除数据库中的数据行。
  3. 数据定义语句(Data Definition Language,简称DDL):用于定义数据库结构的语句。常见的DDL语句包括CREATE、ALTER和DROP,分别用于创建、修改和删除数据库、表、列等对象。
  4. 数据控制语句(Data Control Language,简称DCL):用于控制数据库用户访问权限和安全性的语句。常见的DCL语句有GRANT和REVOKE,用于授予和撤销用户对数据库对象的访问权限。
  5. 事务控制语句(Transaction Control Language,简称TCL):用于控制数据库事务的语句。常见的TCL语句包括COMMIT、ROLLBACK和SAVEPOINT,用于提交、回滚和设置保存点以实现事务的管理。

这些不同类型的SQL语句提供了丰富的功能和灵活性,以满足不同的数据库操作需求。开发人员通过组合和使用这些语句,可以实现数据的查询、更新、定义和安全控制等操作,从而有效地管理数据库。

2 DQL(数据查询语句)

DQL(Data Query Language)是SQL语言的一个子集,用于从数据库中查询数据。以下是一些DQL语句的示例及其应用场景:

  1. SELECT:用于从数据库表中查询数据行和列。SELECT语句可以选择特定列或所有列。

    示例:SELECT * FROM employees; (查询所有员工数据)

  2. WHERE:用于在查询中设置条件,过滤满足条件的数据行。

    示例:SELECT * FROM customers WHERE city = ‘New York’; (查询居住在纽约的客户)

  3. DISTINCT:用于返回查询结果中的唯一值,去除重复的数据行。

    示例:SELECT DISTINCT country FROM customers; (查询唯一的国家列表)

  4. ORDER BY:用于对查询结果进行排序。

    示例:SELECT * FROM products ORDER BY price DESC; (按价格降序排列产品)

  5. GROUP BY:用于对查询结果进行分组汇总,常与聚合函数一起使用。

    示例:SELECT department, AVG(salary) FROM employees GROUP BY department; (按部门计算平均工资)

  6. JOIN:用于将多个表关联起来,通过共同的列进行匹配。

    示例:SELECT * FROM orders JOIN customers ON orders.customer_id = customers.customer_id; (查询订单和相应客户信息)

  7. LIMIT:用于限制查询结果返回的行数。

    示例:SELECT * FROM products LIMIT 10; (查询返回前10行产品数据)

这些是DQL语句的一些常见示例,通过使用DQL语句,可以从数据库中提取所需的数据,并根据需求进行排序、过滤、分组等操作。DQL在应用程序开发中非常常见,可用于构建动态的数据查询与显示功能,提供灵活的数据检索和分析能力

3 DML(数据操纵语句)

DML(Data Manipulation Language)用于操作数据库中的数据。以下是一些DML语句的示例及其应用场景:

  1. INSERT INTO:用于向数据库表中插入新的数据行。

    示例:INSERT INTO employees (name, age, salary) VALUES (‘John’, 30, 5000); (向员工表插入新的员工信息)

  2. UPDATE:用于更新数据库表中已有的数据行。

    示例:UPDATE customers SET city = ‘London’ WHERE customer_id = 1; (将ID为1的客户的城市更新为伦敦)

  3. DELETE FROM:用于删除数据库表中的数据行。

    示例:DELETE FROM orders WHERE order_date < ‘2022-01-01’; (删除早于2022年1月1日的订单数据)

这些DML语句用于对数据库中的数据进行新增、更新和删除操作。在应用程序开发中,DML语句经常用于数据的持久化和维护,例如用户注册、订单处理、数据更新等场景。通过执行这些语句,可以对数据库中的数据进行操作和改变,确保数据库与应用程序的数据一致性。

需要注意的是,执行DML语句时应谨慎,遵循数据完整性和安全性的原则,并充分考虑数据修改可能带来的影响。

4 DDL(数据定义语句)

DDL(Data Definition Language)用于定义数据库结构和对象的语句。以下是一些DDL语句的示例及其应用场景:

  1. CREATE TABLE:用于创建数据库表。

    示例:CREATE TABLE employees (id INT, name VARCHAR(50), age INT); (创建一个名为"employees"的表,包含id、name和age字段)

  2. ALTER TABLE:用于修改数据库表的结构,如添加、修改或删除列、约束等。

    示例:ALTER TABLE employees ADD COLUMN salary DECIMAL(10,2); (向"employees"表中添加一个名为salary的列)

  3. DROP TABLE:用于删除数据库表。

    示例:DROP TABLE employees; (删除名为"employees"的表)

  4. CREATE INDEX:用于创建索引,提高数据库查询的性能。

    示例:CREATE INDEX idx_name ON employees (name); (在"employees"表的name列上创建一个索引)

  5. CREATE VIEW:用于创建视图,类似于虚拟表,通过定义查询来简化数据访问。

    示例:CREATE VIEW active_customers AS SELECT * FROM customers WHERE status = ‘active’; (创建一个名为"active_customers"的视图,显示状态为"active"的客户)

  6. CREATE DATABASE:用于创建数据库。

    示例:CREATE DATABASE mydb; (创建名为"mydb"的数据库)

这些DDL语句用于定义数据库的结构和对象,如表、列、索引和视图等。在数据库设计和维护中,DDL语句起着重要的作用。开发人员可以使用DDL语句来创建、修改和删除数据库对象,确保数据库结构与应用程序需求一致。需要注意的是,执行DDL语句时应谨慎,因为对数据库结构的改变可能会对现有的数据和应用程序产生影响。在生产环境中,应谨慎地执行DDL语句,并在必要时备份数据库以防止意外情况的发生。

5 DCL(数据控制语句)

DCL(Data Control Language)用于控制数据库用户访问权限和安全性的语句。以下是一些DCL语句的示例及其应用场景:

  1. GRANT:用于赋予用户或用户组对数据库对象的权限。

    示例:GRANT SELECT, INSERT ON employees TO user1; (将SELECT和INSERT权限授予用户user1,使其对employees表有查询和插入的权限)

  2. REVOKE:用于撤销用户或用户组对数据库对象的权限。

    示例:REVOKE DELETE ON employees FROM user2; (从用户user2撤销对employees表的删除权限)

  3. DENY:用于拒绝用户对数据库对象的权限,与REVOKE不同之处在于,被拒绝的权限不能通过其他权限再次赋予。

    示例:DENY UPDATE ON employees TO user3; (拒绝用户user3对employees表的更新权限)

  4. SET ROLE:用于设置当前会话的角色。

    示例:SET ROLE admin; (将当前会话设置为admin角色)

这些DCL语句用于管理数据库用户的访问权限和安全控制。通过使用这些语句,数据库管理员可以精确地控制用户对数据库对象的操作权限,实施数据安全策略,并确保只有授权的用户能够访问和修改数据。这种权限控制可以防止未经授权的用户访问敏感数据,并提高数据库的安全性。

需要注意的是,在使用DCL语句时,应考虑权限的粒度和数据库安全策略,以确保权限的正确分配和撤销。同时,定期审查数据库权限和角色设置,及时检测和纠正可能存在的安全风险。

6 TCL(事务控制语句)

TCL(Transaction Control Language)用于管理数据库事务的语句。以下是一些TCL语句的示例及其应用场景:

  1. COMMIT:用于提交当前事务,将事务中的所有更改保存到数据库中。

    示例:COMMIT; (提交当前事务)

  2. ROLLBACK:用于回滚当前事务,撤销事务中的所有更改。

    示例:ROLLBACK; (回滚当前事务)

  3. SAVEPOINT:用于设置保存点,使得事务可以在特定点进行部分回滚。

    示例:SAVEPOINT sp1; (设置名为sp1的保存点)

  4. RELEASE SAVEPOINT:用于释放保存点。

    示例:RELEASE SAVEPOINT sp1; (释放名为sp1的保存点)

这些TCL语句用于管理数据库事务的提交、回滚和保存点控制。事务是数据库中一组操作的逻辑单元,要么全部成功执行提交,要么全部失败回滚。通过使用TCL语句,可以确保数据库操作的原子性、一致性、隔离性和持久性(ACID原则),从而保证数据的完整性和可靠性。

应用程序中经常使用TCL语句来管理数据库事务,尤其是在需要确保数据一致性和完整性的业务操作中,例如转账、订单处理等。通过正确使用TCL语句,可以避免数据丢失、冲突和不一致等问题,保证数据库操作的可靠性和稳定性。

滚和保存点控制。事务是数据库中一组操作的逻辑单元,要么全部成功执行提交,要么全部失败回滚。通过使用TCL语句,可以确保数据库操作的原子性、一致性、隔离性和持久性(ACID原则),从而保证数据的完整性和可靠性。

应用程序中经常使用TCL语句来管理数据库事务,尤其是在需要确保数据一致性和完整性的业务操作中,例如转账、订单处理等。通过正确使用TCL语句,可以避免数据丢失、冲突和不一致等问题,保证数据库操作的可靠性和稳定性。

需要注意的是,在使用TCL语句时,应合理划分事务的范围,选择合适的提交点和保存点,以及根据实际需求进行正确的提交或回滚操作。这有助于维护数据的一致性,并避免不必要的数据损失。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/835287.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【数据结构】二叉树 链式结构的相关问题

本篇文章来详细介绍一下二叉树链式结构经常使用的相关函数&#xff0c;以及相关的的OJ题。 目录 1.前置说明 2.二叉树的遍历 2.1 前序、中序以及后序遍历 2.2 层次遍历 3.节点个数相关函数实现 3.1 二叉树节点个数 3.2 二叉树叶子节点个数 3.3 二叉树第k层节点个数 3…

Crack:CAD Exchanger SDK 3.20 Web Toolkit 应用

在CAD Exchanger SDK 版本 3.20.0中&#xff0c;我们在 Web Toolkit 中包含了绘图、BIM 和 MCAD 查看器的示例&#xff0c;以展示如何使用每个工具可视化数据。这些查看器具有显示不同类型数据的特定功能&#xff0c;允许用户根据自己的需求单独使用它们。我们将继续增强每个查…

HTTP隧道识别与防御:机器学习的解决方案

随着互联网的快速发展&#xff0c;HTTP代理爬虫已成为数据采集的重要工具。然而&#xff0c;随之而来的是恶意爬虫对网络安全和数据隐私的威胁。为了更好地保护网络环境和用户数据&#xff0c;我们进行了基于机器学习的HTTP代理爬虫识别与防御的研究。以增强对HTTP代理爬虫的识…

【云原生】详细学习Docker-Swarm部署搭建和基本使用

个人主页&#xff1a;征服bug-CSDN博客 kubernetes专栏&#xff1a;云原生_征服bug的博客-CSDN博客 目录 Docker-Swarm编排 1.概述 2.docker swarm优点 3.节点类型 4.服务和任务 5.路由网格 6.实践Docker swarm 1.概述 Docker Swarm 是 Docker 的集群管理工具。它将 Doc…

百度智能云“千帆大模型平台”最新升级:接入Llama 2等33个模型!

今年3月&#xff0c;百度智能云推出“千帆大模型平台”。作为全球首个一站式的企业级大模型平台&#xff0c;千帆不但提供包括文心一言在内的大模型服务及第三方大模型服务&#xff0c;还提供大模型开发和应用的整套工具链&#xff0c;能够帮助企业解决大模型开发和应用过程中的…

适配器模式(AdapterPattern)

适配器模式 适配器模式&#xff08;Adapter Pattern&#xff09;是作为两个不兼容的接口之间的桥梁。这种类型的设计模式属于结构型模式&#xff0c;它结合了两个独立接口的功能。 优缺点 优点&#xff1a; 单一职责原则。你可以将接口或数据转换代码从程序主要业务逻辑中分…

硬件产品经理:硬件版本管理必不可少

目录 内容简介 工程变更单 文件夹结构、文件命名约定和部件号 硬件持续集成&#xff08;快速原型设计&#xff09; 结论 推荐学习 相关内容 个人简介 内容简介 今天就来谈谈版本管理这个话题。 在做产品的过程中&#xff1a; 有效的版本控制&#xff0c;以及适当的工…

pdf只读模式改成可编辑模式

pdf文件打开之后是只读模式&#xff0c;这个是因为设置了限制编辑&#xff0c;想要将PDF只读模式改为可编辑模式&#xff0c;我们只需要取消限制编辑就可以了。 不过也有可能是因为有些是阅读、编辑一体的PDF阅读器&#xff0c;这种可能需要我们手动转换一下模式。 取消PDF限…

[Linux]计算机软硬体系结构

[Linux]计算机软硬体系结构 文章目录 [Linux]计算机软硬体系结构冯诺依曼体系结构冯诺依曼体系结构的组成冯诺依曼体系结构中各部件的功能对存储器(内存)的理解对数据流的理解 了解操作系统操作系统的概念管理的概念管理的本质管理的精髓“先描述&#xff0c;再组织”计算机软硬…

工业RFID系统故障的排查与维护手册

在工业领域中&#xff0c;RFID系统扮演着至关重要的角色&#xff0c;用于实现物品追踪、自动化控制和生产流程优化。然而&#xff0c;由于复杂的工作环境和设备运行条件&#xff0c;RFID系统故障可能会发生&#xff0c;对工业生产造成不利影响。为了帮助您排查和解决RFID系统故…

企业微信v4.1.8 版本新功能介绍

一、效率工具与基础体验优化 邮件 1、邮件安全 当邮件发件人、邮件内容存在风险时&#xff0c;将提示风险并自动隐藏邮件中的图片&#xff0c;避免轻信邮件内容。 对存在伪造风险的昵称将直接以发件地址代替展示&#xff0c;减少误导。 对邮件中的包含钓鱼欺诈、病毒或恶意软…

Java:Arrays类的API

Arrays // 1、public static string toString(类型[] arr):返回数组的内容 int[] arr {10,20,30,40,50,60}; system.out.println(Arrays.tostring(arr));//[10,20,30,40,50,60]// 2、public static类型[] copyOfRange(类型[] arr&#xff0c;起始索引&#xff0c;结束索引)﹔拷…

U 盘安装 Windows 10/11 时找不到磁盘驱动器的解决方法

1. 问题 使用 U盘安装 Windows10/11 的时候到选择安装位置时发现列表是空的无法选择任何驱动器。 2. 解决方法 (1) 点击下载安装 Intel Rapid Storage Technology (IRST) 驱动程序&#xff1b; (2) 在 U盘启动盘中创建名为 driver 的文件夹&#xff1b; (3) 将下载好的驱…

冠达管理:次新股为什么不能碰?

在出资过程中许多人都期望能够找到一种愈加快速、高效地赚取金钱的办法&#xff0c;这使得不少人瞄准了次新股。但是&#xff0c;次新股终究是什么&#xff0c;为何有人提醒咱们不要去碰它们呢&#xff1f; 一、什么是次新股&#xff1f; 所谓次新股&#xff0c;指的是上市时刻…

编译JSqlParser4.6-4.7最新源代码

通过https://github.com/JSQLParser/JSqlParser 下载最新的JSqlParser4.6-4.7的源代码&#xff0c;maven导入后出现下面问题 没有找到相应的源代码&#xff0c;原来这部分代码是这个下面 是jjt后缀的文件&#xff0c;原来JSQLParser源码中SQL解析那部分是使用JAVACC来生成的&a…

【LeetCode】地下城游戏(动态规划)

地下城游戏 题目描述算法分析编程代码 链接: 地下城游戏 题目描述 算法分析 编程代码 class Solution { public:int calculateMinimumHP(vector<vector<int>>& dungeon) {int m dungeon.size();int n dungeon[0].size();vector<vector<int>> d…

Flutter 文件上传(七牛云)简单封装

前言&#xff1a;记录了七牛云上传图片的简单封装、若有不足 欢迎指正。 开始前准备&#xff1a; A、七牛sdk版本一定要和dart版本相对应&#xff08;推荐用any方式、让其自己去匹配&#xff09;&#xff1b; qiniu_flutter_sdk: any B、七牛上传文件所需的参数&#xff1a; …

谈谈python编程语言

目录 1.什么是python 2.python的发展历史 3.python的具体应用领域 4.就业前景 1.什么是python Python是一种高级编程语言&#xff0c;它具有简单易学、可读性强和功能丰富的特点。Python由Guido van Rossum于1991年开发&#xff0c;并成为一种通用的编程语言。 以下是一些Py…

蓝队的自我修养之如何从流量中检测 WebShell

HW期间&#xff0c;为防范钓鱼&#xff0c;即日起FreeBuf将取消投稿文章的一切外部链接。给您带来的不便&#xff0c;敬请谅解~ 背景 众所周知&#xff0c;攻防演练过程中&#xff0c;攻击队入侵企业网站时&#xff0c;通常要通过各种方式获取 webshell&#xff0c;从而获得企…