≡
  • 网络编程
  • 数据库
  • CMS技巧
  • 软件编程
  • PHP笔记
  • JavaScript
  • MySQL
位置:首页 > 数据库 > SQL Server

Sql学习第一天——SQL 练习题(建表/sql语句)

人气:471 时间:2020-04-16

这篇文章主要为大家详细介绍了Sql学习第一天——SQL 练习题(建表/sql语句),具有一定的参考价值,可以用来参考一下。

感兴趣的小伙伴,下面一起跟随四海网的小编两巴掌来看看吧!

题目:来自Madrid且订单数少于3的消费者  

建表:

代码如下:

 
set nocount on --当 SET NOCOUNT 为 ON 时,不返回计数(表示受 Transact-SQL 语句影响的行数)。当 SET NOCOUNT 为 OFF 时,返回计数 
use SY 
GO 
if object_Id('dbo.Orders') is not null 
drop table dbo.Orders 
GO 
if object_Id('dbo.Customers') is not null 
drop table dbo.Customers 
GO 
create table dbo.Customers 
( 
customerid char(5) not null primary key , 
city varchar(10) not null 
); 
insert into dbo.Customers values('FISSA','Madrid'); 
insert into dbo.Customers values('FRNDO','Madrid'); 
insert into dbo.Customers values('KRLOS','Madrid'); 
insert into dbo.Customers values('MRPHS','Zion'); 

create table dbo.Orders 
( 
orderid int not null primary key , 
customerid char(5) null references customers(customerid) 
) 
insert into dbo.Orders values(1,'FRNDO'); 
insert into dbo.Orders values(2,'FRNDO'); 
insert into dbo.Orders values(3,'KRLOS'); 
insert into dbo.Orders values(4,'KRLOS'); 
insert into dbo.Orders values(5,'KRLOS'); 
insert into dbo.Orders values(6,'MRPHS'); 
insert into dbo.Orders values(7,null); 

------------------------------------------------------------------------------------------------------------------------------

 

做题分析:

代码如下:

 
select customerid as 消费者,count(customerid) as 订单数 
from dbo.Orders 
where customerid in ( 
select customerid 
from dbo.Customers 
where city = 'Madrid') 
group by customerid 
having count(customerid) < 3 

结果如图所示:

 

【图片暂缺】

--第一次想到的答案,突然发现少了一个来自Madrid的FISSA订单,FISSA订单数量为0,所以在Orders表中没有出现,所以上面的写法会少一个.

--推翻了上面的答案,又想到了用表的连接,而用内连接出现的情况会和上面的一样,所以我选择了左连接,如下:

代码如下:

 
select C.customerid as 消费者,count(O.customerid) as 订单数 
from dbo.Customers as C left join dbo.Orders as O on C.customerid = O.customerid 
where C.city= 'Madrid' 
group by C.customerid 
having count(C.customerid) < 3 

结果如图所示:

 

【图片暂缺】

--查询发现是正确的。

--分析查看不带条件的左连接

代码如下:

 
select * from dbo.Customers as C left join dbo.Orders as O on C.customerid = O.customerid 

代码如下:

 
select * from dbo.Customers as C left join dbo.Orders as O on C.customerid = O.customerid 

结果如图所示:

 

【图片暂缺】

--书中给的标准答案是:

代码如下:

 
select C.customerid , count(O.orderid) as numorders 
from dbo.Customers as C left join dbo.Orders as O on C.customerid = O.customerid 
where C.city= 'Madrid' 
group by C.customerid 
having count(O.orderid) < 3 
order by numorders 

结果如图所示:

 

【图片暂缺】

--书中给的只是多了一个order by 进行定义了排序方式(以numorders这一列的升序进行排序)

本文来自:http://www.q1010.com/179/8521-0.html

注:关于Sql学习第一天——SQL 练习题(建表/sql语句)的内容就先介绍到这里,更多相关文章的可以留意四海网的其他信息。

关键词:SQL SERVER

您可能感兴趣的文章

  • 真正高效的SQLSERVER分页查询(多种方案)
  • sqlserver数据库出现置疑的解决思路
  • sqlserver中delete、update中使用表别名和oracle的区别
  • SqlServer获取存储过程返回值的实例
  • sqlserver附加.mdf权限问题解决
  • 高效的SQLSERVER分页查询(推荐)
  • sqlserver 不能将值NULL插入列id(列不允许有空值解决)
  • 深入SQLServer中ISNULL与NULLIF的使用分析
  • SQLServer2000 报1053错误(服务没有及时响应或控制请求)的解决方法
  • 安装sqlserver2000时出现wowexec.exe无反应的解决方法
上一篇:SQL Server 2005/2008 日志压缩清理方法小结
下一篇:Sql学习第一天——SQL UNION 和 UNION ALL 操作符认识
热门文章
  • SQL Server SQL获取第一条记录的方法
  • SQL Server出现System.OutOfMemoryException异常的解决方法
  • SQL Server的 update from 语句的简单示例
  • SQL Server 数据库备份方法菜鸟教程
  • SQL Server 多表关联时在where语句中慎用trim()方法
  • SQL Server数据类型及长度限制详细说明
  • mybaits非配置原因,导致SqlSession was not registered for synchronization异常解析
  • SQL Server 收缩后对数据库的使用有影响吗?
  • SQL Server 格式导致的Excel导入sql出现异常的解决方法
  • SQL Server 连接服务器出现错误 7391的解决方法
  • 最新文章
    • SQL Server存储过程基本语法的简单示例
    • sql查询时增加自动编号和分页的简单示例
    • sql轻松应付百万数据的高效数据分页存储过程的简单示例
    • sql获取一条数据中所有字段的名称和值的实现方法
    • sql分割函数的简单示例
    • SQL Server异常捕获的简单示例
    • SQL SERVER回滚恢复误操作数据的实现方法
    • SQL Server函数或存储过程中抛出异常的实现方法
    • SQL Server创建数据库的完整代码
    • SQL Server创建数据库的命令用法示例

四海网收集整理一些常用的php代码,JS代码,数据库mysql等技术文章。