SQL 面试题(一)

问题来自于CSDN问答,练练SQL吧。

测试数据SQL代码:

if OBJECT_ID('td_ls_2') is not null
    drop table td_ls_2
go
if OBJECT_ID('td_ls_1') is not null
    drop table td_ls_1
go


create table td_ls_1
(
    dh varchar(18) primary key,
    Id_gsjg int,
    Ymd_rz varchar(8),
    Id_ck int,
    Id_hyk int,
    Id_user int
)
go
create table td_ls_2
(
    dh varchar(18) foreign key references td_ls_1(dh),
    Id_sp int,
    sl int,
    Dj_hs decimal(10,1),
    Je_hs decimal(10,1),
    Flag_cx varchar(4)
)
go

insert into td_ls_1 values('LS0010111052600010',2,'20110526',2,5,14);
insert into td_ls_1 values('LS0010111052600012',2,'20110526',3,0,14);
insert into td_ls_1 values('LS0010111052700016',1,'20110527',1,0,18);
insert into td_ls_1 values('LS0010111052700018',2,'20110527',2,17,18);
insert into td_ls_1 values('LS0010111052800022',1,'20110528',1,17,14);
insert into td_ls_1 values('LS0010111052800023',2,'20110528',3,0,125);
insert into td_ls_1 values('LS0010111052900026',3,'20110529',4,0,14);

go

insert into td_ls_2 values('LS0010111052600010',4053,1,8,8,'no');
insert into td_ls_2 values('LS0010111052600010',202,2,7.3,14.6,'no');
insert into td_ls_2 values('LS0010111052600012',2131,2,7.6,15.2,'tjcx');
insert into td_ls_2 values('LS0010111052600012',2104,1,16.9,16.9,'tjcx');
insert into td_ls_2 values('LS0010111052700016',404,20,1,20,'tjcx');
insert into td_ls_2 values('LS0010111052700018',2383,2,8.3,16.6,'no');
insert into td_ls_2 values('LS0010111052800022',377,2,1.6,3.2,'tjcx');
insert into td_ls_2 values('LS0010111052800022',3310,3,1.4,4.2,'no');
insert into td_ls_2 values('LS0010111052800022',404,25,1,25,'tjcx');
insert into td_ls_2 values('LS0010111052800023',2131,2,7.6,15.2,'tjcx');
insert into td_ls_2 values('LS0010111052900026',3310,2,1.4,2.8,'no');

答案:

1、

select a.Id_hyk as 会员卡,a.dh as 单号,a.Ymd_rz as 日期,b.Id_sp as 商品ID,b.Je_hs as 金额 
from td_ls_1 a inner join td_ls_2 b on a.dh = b.dh order by 会员卡

2、

select a.Ymd_rz as 日期,sum(b.Je_hs) as 销售金额 from td_ls_1 a 
inner join td_ls_2 b on a.dh = b.dh 
where a.Id_gsjg = 2 
group by a.Ymd_rz

3、有两种方法:1、可以设置主外键关联,这样删除主表时就能同时删除子表记录(级联删除);2、先删子表记录再删主表记录

if OBJECT_ID('aa') is not null 
  drop table aa;
with a as(
  select a.dh from td_ls_1 a inner join td_ls_2 b on a.dh = b.dh where a.Ymd_rz = '20110529'
)
select * into aa from a;

--先删子表再删主表
delete from td_ls_2 where dh in (select dh from aa);
delete from td_ls_1 where dh in (select dh from aa);

4、

select a.Id_user as 收银员,sum(b.Je_hs) as 销售金额 
from td_ls_1 a inner join td_ls_2 b on a.dh = b.dh
group by Id_user 
order by 销售金额 desc
原文地址:https://www.cnblogs.com/guwei4037/p/6021318.html