一.写在前面的话 转眼又是一年清明节,话说清明时节雨纷纷,武汉的天气伴随着这个清明节下了一场暴雨,整个城市如海一样,朋友圈渗透着清明节武汉看海的节奏。今年又没有回老家祭祖,但是心里依然是怀念着那些亲人,虽说他们已离我们远去,然而那些血浓于水
一.写在前面的话
转眼又是一年清明节,话说“清明时节雨纷纷”,武汉的天气伴随着这个清明节下了一场暴雨,整个城市如海一样,朋友圈渗透着清明节武汉看海的节奏。今年又没有回老家祭祖,但是心里依然是怀念着那些亲人,虽说他们已离我们远去,然而那些血浓于水的亲情是一辈子无法忘记的,在心里深深的想念他们。生活继续,激情永恒!时刻保持着奋斗的节奏,为那些爱我们的和我爱的人,好好活着,做一个斗士,让我们都能够获得幸福!继续我们的学习吧!在这里首先分享海子的一首诗:
面对大河我无限惭愧,
我年华虚度,空有一身疲倦,
和所有以梦为马的诗人一样,
岁月易逝,一点不剩。
------ 摘自《海子的诗》
二.查询缺少值的查询
在这里我们加入要查询2008年每一天的订单有多少?首先我们可以查询下订单表的订单日期在2008年的所有订单信息。
<span>1</span> <span>select</span> distinct orderdate,count(*) <span>as</span> N<span>'</span><span>每日订单量</span><span>'</span> <span>from</span><span> sales.orders </span><span>2</span> <span>where</span> orderdate between <span>'</span><span>20080101</span><span>'</span> and <span>'</span><span>20081231</span><span>'</span> <span>3</span> group by orderdate
查询结果如图:
从上面可以看出来,每天的订单的数量根据orderdate分组以后统计出来啦,但是我们发现有的日期是不存在的,比如2008-01-01、2008-01-02....却没有发现2008-01-03日期的订单数量,加入我们要求看到每天的订单了?(这种要求大多数来源于财务报表的统计),这就要求我们进行表构造,我们可以构造一个包含2008年的每一年日期,然后进行表关不就得出来每一天的都包含的订单嘛。说着我就开始做吧,先开始构造一个包含2008年每一天的表。
<span>1</span> <span> create table nums </span><span>2</span> <span> ( </span><span>3</span> n <span>int</span> <span>4</span> <span> ); </span><span>5</span> <span>6</span> <span>select</span> * <span>from</span> nums;
创建一个nums空表,用来保存连续的日期。接着就可以往表里面插入一些数据。
<span>1</span> declare @i <span>int</span><span>; </span><span>2</span> <span>set</span> @i=<span>0</span><span>; </span><span>3</span> <span>while</span> @i400 <span>4</span> <span> begin </span><span>5</span> <span>set</span> @i=@i+<span>1</span><span>; </span><span>6</span> <span> insert into nums(n) values(@i); </span><span>7</span> end
可以看到表里面插入和1到400有序的数字:
接着我们就可以构造连续日期了,日期的相加前面已经学习过dateadd(),如果想一起学习一下,可以看一下前面的笔记:
sqlserver学习笔记1:http://www.cnblogs.com/liupeng61624/p/4354983.html
sqlserver学习笔记2:http://www.cnblogs.com/liupeng61624/p/4367580.html
sqlserver学习笔记3:http://www.cnblogs.com/liupeng61624/p/4375135.html
sqlserver学习笔记4:http://www.cnblogs.com/liupeng61624/p/4388959.html
继续说日期的相加,在这里我们通过日期相加,就可以构造2008年的每一天:
<span>1</span> <span>select</span> dateadd(day,n,<span>'</span><span>20071231</span><span>'</span><span>) </span><span>2</span> <span>from</span> nums;
构造的日期结果如图:
日期构造完以后,那么我们就可以利用这个结果集跟订单表Sales.orders进行一个连接。
<span>1</span> <span>select</span> dateadd(day,f.n,<span>'</span><span>20071231</span><span>'</span>),count(orderid) <span>as</span> N<span>'</span><span>每日订单数量</span><span>'</span> <span>2</span> <span>from</span><span> nums f left join sales.orders m on </span><span>3</span> dateadd(day,f.n,<span>'</span><span>20071231</span><span>'</span>)=<span> m.orderdate </span><span>4</span> group by dateadd(day,f.n,<span>'</span><span>20071231</span><span>'</span><span>) </span><span>5</span> order by dateadd(day,f.n,<span>'</span><span>20071231</span><span>'</span>)
结果如图所示:
(2)子查询,即查询结果可以作为一个查询条件。
例如:我们要查询雇员表(Hr.employees)里面年龄最小的雇员信息。sql语句可以这样写:
<span>1</span> <span>select</span> max(birthdate) <span>as</span> N<span>'</span><span>生日</span><span>'</span> <span>2</span> <span>from</span> hr.employees
在这里我们知道可以用聚合函数max进行查询,但是加入我们还要查询出年龄最小的名字,即lastname,sql语句如下,可以发现报错,因为max聚合函数,是对一组结果进行处理,而lastname并不包含在聚合函数中,故报错。
那么在这里我们就要用到子查询来处理,可以讲年龄最小的结果作为查询结果来进一步查询。
<span>1</span> <span>select</span><span> birthdate,lastname </span><span>2</span> <span>from</span><span> hr.employees </span><span>3</span> <span>where</span> birthdate= <span>4</span> <span> ( </span><span>5</span> <span>select</span><span> max(birthdate) </span><span>6</span> <span>from</span><span> hr.employees </span><span>7</span> )
查询结果如图所示:
继续子查询,加入我们要将下订单最贵的那个客户找出来,给颁发一个Svip级别荣誉,并且找出他所在的国家已经他个人的一些基本信息。
根据上面子查询,我们可以这样写我们的sql,首在这里视图Sales.OrderValues里面存储的是订单的一些价格信息。故我们对这张视图进行操作。
- 首先找出订单最贵的信息
<span>1</span> <span>2</span> <span>select</span> max(val) <span>as</span> N<span>'</span><span>最贵订单</span><span>'</span> <span>3</span> <span>from</span> Sales.OrderValues
2. 然后找出最贵订单的顾客ID是多少
<span>1</span> <span>select</span> custid <span>from</span><span> Sales.OrderValues </span><span>2</span> <span>where</span> val=<span>( </span><span>3</span> <span>select</span> max(val) <span>as</span> N<span>'</span><span>最贵订单</span><span>'</span> <span>4</span> <span>from</span><span> Sales.OrderValues </span><span>5</span> )
3. 接着我们就可以在顾客表里面找出ID等于查询来的这个ID,同时查找出所在国家。
<span> 1</span> <span>select</span><span> custid,contactname,country </span><span> 2</span> <span>from</span> sales.customers <span>where</span> custid= <span> 3</span> <span> ( </span><span> 4</span> <span>select</span> custid <span>from</span><span> Sales.OrderValues </span><span> 5</span> <span>where</span> val= <span> 6</span> <span> ( </span><span> 7</span> <span>select</span> max(val) <span>as</span> N<span>'</span><span>最贵订单</span><span>'</span> <span> 8</span> <span>from</span><span> Sales.OrderValues </span><span> 9</span> <span> ) </span><span>10</span> )
结果如图所示:
三.相关子查询,即查询的嵌套另一个查询,其中有涉及到相互关联的条件。
例如:我们要查询每个顾客下的订单数量,前面我们已经学习过,有两种方法都可以实现:
1.用group......by分组
<span>1</span> <span>select</span> custid, count(*) <span>as</span> N<span>'</span><span>订单数量</span><span>'</span> <span>from</span><span> sales.orders </span><span>2</span> group by custid order by custid
2.利用count.....over
<span>1</span> <span>select</span> distinct custid,count(*) over (partition by custid) <span>as</span> N<span>'</span><span>订单数量</span><span>'</span> <span>2</span> <span>from</span> sales.orders
第三种方式我们就用相关子查询来解决,可以这样理解:就是我们没查一位顾客的订单数量就是去订单表里面顾客Id相同的都取出来,然后利用聚合函数求和。顾客ID我们可以从顾客表里面取出来,然后这个ID就等于订单表里面的ID。所以根据分析我们写sql如下:
<span>1</span> <span>select</span><span> n.custid,n.contactname, </span><span>2</span> <span> ( </span><span>3</span> <span>select</span> count(*<span>) </span><span>4</span> <span>from</span><span> sales.orders m </span><span>5</span> <span>where</span> m.custid=<span>n.custid </span><span>6</span> ) <span>as</span> N<span>'</span><span>订单数量</span><span>'</span> <span>7</span> <span>from</span> sales.customers n
其结果如图所示:
这样也可以把顾客下的订单数量算出来,这里就是利用到了外层查询跟内层查询条件作为比对求和。也就是我们说的相关子查询。
四.多值子查询
例如:我们要查询存在顾客但却没有供应商的国家,即这个国家中有顾客,没有供应商公司。
一般情况下:我们会采用常用的sql写法:
<span>1</span> <span>2</span> <span>select</span> distinct m.country <span>from</span><span> sales.customers m </span><span>3</span> <span>where</span> m.country not <span>in</span> <span>4</span> <span> ( </span><span>5</span> <span>select</span> n.country <span>from</span><span> production.suppliers n </span><span>6</span> )
结果如图所示:
既然有了not.....in写法,当然存在exists的写法,同样可以实现要求,exists对于结果集若存在则返回true,不存在返回false。我们可以这样理解:外层查询将country传递到内层查询,看看存不存在其中,其中内存查询包含多个结果,所以就叫做多值子查询。所以sql语句可以这样写:
<span>1</span> <span>select</span> distinct m.country <span>from</span><span> sales.customers m </span><span>2</span> <span>where</span><span> not exists </span><span>3</span> <span> ( </span><span>4</span> <span>select</span> n.country <span>from</span><span> production.suppliers n </span><span>5</span> <span>where</span> n.country=<span> m.country </span><span>6</span> )
结果如图所示:
可以看到其结果跟not.....in查出来的结果一样,满足条件。
五.复杂子查询
(1)例如:假如我们要查询所有订单当前订单的前一个订单和后一个订单信息,这里我们先分析:
1.首先我们先可以查询出所有的订单。
<span>1</span> <span>select</span><span> distinct custid </span><span>2</span> <span>from</span> sales.orders
2.然后查询比当前订单Id小于的订单,同时这个订单是小于当前订单中最大的那个订单(即紧挨着的订单)。
<span>1</span> <span>select</span><span> distinct </span><span>2</span> <span> ( </span><span>3</span> <span>select</span> max(custid) <span>from</span> <span>4</span> sales.orders m <span>where</span> m.custid n.custid <span>5</span> ) <span>as</span> N<span>'</span><span>前一个订单</span><span>'</span>,n.custid <span>as</span> N<span>'</span><span>当前订单</span><span>'</span> <span>6</span> <span>7</span> <span>from</span> sales.orders n
3.同理,可以查出大于当前订单的那个紧挨着的那个订单。
<span> 1</span> <span>select</span><span> distinct </span><span> 2</span> <span> ( </span><span> 3</span> <span>select</span> max(custid) <span>from</span> <span> 4</span> sales.orders m <span>where</span> m.custid n.custid <span> 5</span> ) <span>as</span> N<span>'</span><span>前一个订单</span><span>'</span>,n.custid <span>as</span> N<span>'</span><span>当前订单</span><span>'</span><span>, </span><span> 6</span> <span> ( </span><span> 7</span> <span>select</span> min(custid) <span>from</span> <span> 8</span> sales.orders p <span>where</span> p.custid><span> n.custid </span><span> 9</span> ) <span>as</span> N<span>'</span><span>后一个订单</span><span>'</span> <span>10</span> <span>from</span> sales.orders n
其结果如图所示:
(2)累计聚合
累计聚合在财务统计中,经常用到,比如2007年卖出多少,2008年卖出多少,那么2008年累计卖出就是2007年加上2008年卖出的总和,即累计聚合。
在这里我们有视图Sales.OrderTotalsByYear,其中统计的是每一年的订单总量。
<span>1</span> <span>select</span> * <span>from</span> Sales.OrderTotalsByYear
我们可以看到2007年有25489张订单,2008年有16247张订单,2006年有9581张订单。加入我们要求每年累计卖了多少订单,就要用到累计聚合。
<span>1</span> <span>select</span><span> n.orderyear, </span><span>2</span> <span>( </span><span>3</span> <span>select</span><span> sum(qty) </span><span>4</span> <span>from</span><span> Sales.OrderTotalsByYear m </span><span>5</span> <span>where</span> m.orderyearn.orderyear <span>6</span> ) <span>as</span> N<span>'</span><span>累计订单数量</span><span>'</span> <span>7</span> <span>from</span><span> Sales.OrderTotalsByYear n </span><span>8</span> order by n.orderyear;
结果如图所示:
今天就学习到这,下次接着学习CTE,有了CTE会让我们的查询更加爽,特别是在用到递归的时候。
希望各位大牛给出指导,不当之处虚心接受学习!谢谢!

对于 SQL Server 数据库中已存在同名对象,需要采取以下步骤:确认对象类型(表、视图、存储过程)。如果对象为空,可使用 IF NOT EXISTS 跳过创建。如果对象有数据,使用不同名称或修改结构。使用 DROP 删除现有对象(谨慎操作,建议备份)。检查架构更改,确保没有引用删除或重命名的对象。

当 SQL Server 服务无法启动时,可采取以下步骤解决:检查错误日志以确定根本原因。确保服务帐户具有启动服务的权限。检查依赖项服务是否正在运行。禁用防病毒软件。修复 SQL Server 安装。如果修复不起作用,重新安装 SQL Server。

要查看 SQL Server 端口号:打开 SSMS,连接到服务器。在对象资源管理器中找到服务器名称,右键单击它,然后选择“属性”。在“连接”选项卡中,查看“TCP 端口”字段。

SQL Server 数据库文件通常存储在以下默认位置:Windows: C:\Program Files\Microsoft SQL Server\MSSQL\DATALinux: /var/opt/mssql/data可通过修改数据库文件路径设置来自定义数据库文件位置。

问题发现这次使用的是SqlServer数据库,之前并没有使用过,但是问题不大,我按照需求文档的步骤连接好SqlServer之后,启动SpringBoot项目,发现了一个报错,如下:刚开始我以为是SqlServer连接问题呢,于是便去查看数据库,发现数据库一切正常,我首先第一时间问了我的同事,他们是否有这样的问题,发现他们并没有,于是我便开始了我最拿手的环节,面向百度编程。开始解决具体报错信息是这样,于是我便开始了百度报错:ERRORc.a.d.p.DruidDataSource$CreateCo

SQL Server 英文安装可通过以下步骤更改为中文:下载相应语言包;停止 SQL Server 服务;安装语言包;更改实例语言;更改用户界面语言;重启应用程序。

可以通过以下步骤查询 SQL Server 数据库日志:1. 打开 SQL Server Management Studio,连接到数据库服务器;2. 展开“管理”节点,导航到“SQL Server 日志”;3. 选择要查询的日志文件,右键单击并选择“查看日志文件”;4. 浏览日志记录。其他查询日志方法:使用 Transact-SQL 查询、PowerShell Cmdlet。

有网友反馈,在win11上无法安装sqlserver这款软件,不知道是怎么回事,根据目前的测试来看,win11存在硬盘问题,部分接口硬盘无法安装这款软件。win11为啥不能安装sqlserver:答:win11不能安装sqlserver是硬盘的问题。1、据了解,win11存在对于硬盘的检测bug。2、这导致sqlserver无法在“三星m.2接口”硬盘上安装。3、因此,如果我们要安装的话,需要准备一块其他硬盘。4、然后将该硬盘安装到电脑里,如果没有额外插槽的话就要换掉之前的硬盘。5、安装完成后,


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

安全考试浏览器
Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

ZendStudio 13.5.1 Mac
功能强大的PHP集成开发环境

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

SublimeText3汉化版
中文版,非常好用

EditPlus 中文破解版
体积小,语法高亮,不支持代码提示功能