SQL 将变量定义为Table类型Sql学习第一天——SQL 练习题(建表/sql数据库语句)
题目:来自Madrid且订单数少于3的消费者,建表:,复制具体相关代码 具体相关代码如下:,set nocount on --当 SET NOCOUNT 为 ON 时,不返回计数(表示受 Transact-SQL 数据库语句影响的行数)。当 SET NOCOUNT 为 OFF 时,返回计数 use,做题分析:,复制具体相关代码 具体相关代码如下:,select customerid as 消费者,count(customerid) as 订单数 from dbo.Orders where customerid in ( select custo,--第一次想到的答案,突然发现少了一个来自Madrid的FISSA订单,FISSA订单数量为0,所以在Orders表中没有出现,所以上面的写法会少一个. --推翻了上面的答案,又想到了用表的连接,而用,复制具体相关代码 具体相关代码如下:,select C.customerid as 消费者,count(O.customerid) as 订单数 from dbo.Customers as C left join dbo.Orders a,--查询发现是正确的。 --分析查看不带条件的左连接,复制具体相关代码 具体相关代码如下:,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 ,--书中给的只是多了一个order by 进行定义了排序相关方式(以numorders这一列的升序进行排序)
在平时定义sql数据库语句中的变量时通常咱们定义的都是像char,varchar,nvarchar,int........,那如何让变量作为一个像虚拟表一样呢,其实很简单。
基本语法:
复制具体相关代码 具体相关代码如下:
declare @t table(列名1 列的数据类型1 , 列名2 列的数据类型2 , ...............)
insert into @t(列名1 ,列名2 ,...............) values (...............)
[code]
或者
[code]
insert into @t(列名1 ,列名2 ,...............) (select ....from....)
实验用表一(PeopleInfo):
id name phone
XC1 李某 123333333
XC2 小小 785555555
例如:
复制具体相关代码 具体相关代码如下:
declare @t table(id nvarchar(3),[name] nvarchar(10) )
insert into @t(id,[name])
(select id, [name] from PeopleInfo where [Name] like '李%')
select * from @t
结果:
id name
XC1 李某