SQL的定义、组成及基本语法

嵌入式技术

1330人已加入

描述

一、SQL定义

SQL (Structured Query Language) 是具有数据操纵和数据定义等多种功能的数据库语言,这种语言具有交互性特点,能为用户提供极大的便利,数据库管理系统应充分利用SQL语言提高计算机应用系统的工作质量与效率。SQL语言不仅能独立应用于终端,还可以作为子语言为其他程序设计提供有效助力,该程序应用中,SQL可与其他程序语言一起优化程序功能,进而为用户提供更多更全面的信息。        

SQL Server数据库包括Microsoft SQL Server以及Sybase SQL Server两个子数据库,该数据库能否正常运行直接关系着整个计算机系统的运行安全。

二、简介

在大数据时代中,数据库系统的数据类型与规模在不断扩增,这给数据库管理带来了一定的挑战。在社会生产生活中,对于数据库的应用范围逐步增大,提升数据库开发及应用的效率,是保障我国社会生产生活高效运转的关键。

SQL作为一种操作命令集, 以其丰富的功能受到业内人士的广泛欢迎, 成为提升数据库操作效率的保障。SQL Server数据库的应用,能够有效提升数据请求与返回的速度,有效应对复杂任务的处理,是提升工作效率的关键。      

由于SQL Servers数据库管理系统具有较高的数据管理性能,因其优越的性能,应用范围非常广,大量应用于服务器和客户体系结构中。SQL Servers数据库的性质主要由以下几个方面体现:系统的吞吐量、响应时间以及并行处理能力, 发出请求服务器回应的速度、还有不同屏幕之间切换的速度等等。

三、组成

在正式学习SQL语言之前,首先让我们对SQL语言有一个基本认识,介绍一下SQL语言的组成:       

一个SQL数据库是表(Table)的集合,它由一个或多个SQL模式定义。

一个SQL表由行集构成,一行是列的序列(集合),每列与行对应一个数据项。

一个表或者是一个基本表或者是一个视图。基本表是实际存储在数据库的表,而视图是由若干基本表或其他视图构成的表的定义。

一个基本表可以跨一个或多个存储文件,一个存储文件也可存放一个或多个基本表。每个存储文件与外部存储上一个物理文件对应。

用户可以用SQL语句对视图和基本表进行查询等操作。在用户角度来看,视图和基本表是一样的,没有区别,都是关系(表格)。

SQL用户可以是应用程序,也可以是终端用户。SQL语句可嵌入在宿主语言的程序中使用,宿主语言有FORTRAN,COBOL,PASCAL,PL/I,C和Ada语言等。SQL用户也能作为独立的用户接口,供交互环境下的终端用户使用。

四、SQL基本语法

SQL 示例:

select city_name,count(order_id)as order_cnt

from dw.table_name

where dt='2023-01-01'

group by city_name

having count(order_id) >1000

order by city_name

SQL语句基本结构:

【select】  column_list               ---结果集:列名、常量或函数,逗号分隔

【from】 dw.table_name             ---数据源:库名+表名或子查询,库和表之间以点号连接

【where】 search_conditions     ---条件过滤:筛选要获取的数据,多个条件以and或or连接

【group by】 group_by_list        ---分组:对指定字段进行分组,多与聚合函数结合使用

【having 】search_conditions    ---二次过滤:与group by组合使用,对group by分组后再次过滤

【order by】 order_by_list          ---排序:查询结果按照指定字段进行排序,全局排序

SQL语句执行顺序:

select --- >from-->where-->group by -->having--> order by

第一步:select语句,选取经过上述流程后的结果集。

第二步:from语句,选择要操作的表。

第三步:where语句,在from后的表中设置筛选条件,筛选出符合条件的记录。

第四步:group by语句,把筛选出的记录进行分组。

第五步:having语句,设置条件筛选分组后的数据。

第六步:order by语句,将select后的结果集按照顺序展示出来。

注意:

掌握SQL语句执行流程非常重要,是理解并写好SQL语句的前提。根据实际业务逻辑要执行的数据库操作对应到SQL语句的执行流程,能够帮助我们快速写出相应功能的标准SQL语句。

SQL语句使用说明:

【select】

作用:选取结果集。

位置:位于SQL语句开始。

【from】

作用:from后接要操作的数据表。

数据表形式:单个表、多个并列的表、多个进行join的表。

位置:位于select之后。

【where】

作用:设置条件,过滤记录。

位置:位于from之后。

where语句中的运算符:

运算符 描述
= 等于
<> 不等于。注:一些版本中也可为!=。
> 大于
< 小于
>= 大于等于
<= 小于
BETWEEN 在某个范围内
LIKE 匹配某种模式
IN 在多个可能值之中

where语句中的条件类型:

逻辑运算:

AND:且,同时满足多个条件的值。

OR:或,满足多个条件中至少一个即可。

特殊条件:

IS NULL:空值判断。

BETWEEN:在范围之间的值。

IN:在多个可能值之中。

LIKE:模糊查询。

【group by】

作用:用于结合结合聚合函数,对一个列或多个列结果集进行分组。

位置:一般位于where后或者SQL语句末尾位置。

【having】

作用:筛选分组后的各组数据,一般和聚合函数结合使用。

位置:一般位于SQL语句末尾。

常用聚合函数:

函数 作用
sum(列名) 求和
max(列名) 最大值
min(列名) 最小值
avg(列名) 平均值
first(列名) 第一条记录
last(列名) 最后一条记录
count(列名) 统计记录数   注:count(*)为统计所有记录数

【order by】

作用:用于对结果集按照一个或者多个列进行排序。

位置:一般位于SQL语句末尾。

排序:

默认按照升序对记录进行排序,如果按照降序对记录进行排序,需加DESC关键字。

order by多列时,先按照第一个column_name排序,再按照第二个column_name排序。

排序实例:

order by A       # A升序排列

order by A desc,B   # A 降序(优先),B 升序排列

order by A ,B desc  #  A 升序(优先),B 降序排列

【where和having区别】

where在group by前, having在group by 之后。

where中不能使用聚合函数,having中可以使用聚合函数。原因:因为聚合函数是针对结果集进行的,但where是在查询结果集之前进行,故where中不能使用聚合函数;having是针对结果集做筛选的,故一般把聚合函数放在having中。

  审核编辑:汤梓红

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分