27,579
社区成员
发帖
与我相关
我的任务
分享
create table [Table1](
[name] nvarchar(10),[time] datetime,[Class] nvarchar(10))
INSERT INTO [Table1]([name],[time],[Class])VALUES('第一个','2011-10-24','A班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第一个','2011-10-24','B班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第二个','2011-10-24','A班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第二个','2011-10-24','B班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第三个','2011-10-24','A班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第五个','2011-10-24','A班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第四个','2011-10-23','A班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第五个','2011-10-23','B班')
go
select * from Table1 -----执行结果如下:
第一个 2011-10-24 00:00:00.000 A班
第一个 2011-10-24 00:00:00.000 B班
第二个 2011-10-24 00:00:00.000 A班
第二个 2011-10-24 00:00:00.000 B班
第三个 2011-10-24 00:00:00.000 A班
第五个 2011-10-24 00:00:00.000 A班
第四个 2011-10-23 00:00:00.000 A班
第五个 2011-10-23 00:00:00.000 B班
--想要得到的结果如下:
第一个 2011-10-24 00:00:00.000 A班
第一个 2011-10-24 00:00:00.000 B班
第二个 2011-10-24 00:00:00.000 A班
第二个 2011-10-24 00:00:00.000 B班
第三个 2011-10-24 00:00:00.000 A班
第三个 2011-10-24 00:00:00.000 B班 --添加
第五个 2011-10-24 00:00:00.000 A班
第五个 2011-10-24 00:00:00.000 B班 --添加
第四个 2011-10-23 00:00:00.000 A班
第四个 2011-10-23 00:00:00.000 B班 --添加
第五个 2011-10-23 00:00:00.000 A班 --添加
第五个 2011-10-23 00:00:00.000 B班
--简化一下 去掉连接
create table [Table1](
[name] nvarchar(10),[time] datetime,[Class] nvarchar(10))
INSERT INTO [Table1]([name],[time],[Class])VALUES('第一个','2011-10-24','A班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第一个','2011-10-24','B班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第二个','2011-10-24','A班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第二个','2011-10-24','B班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第三个','2011-10-24','A班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第五个','2011-10-24','A班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第四个','2011-10-23','A班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第五个','2011-10-23','B班')
go
select * into #t
from(
select
name,a.time,b.Class
from
((select distinct name,time from Table1)a cross join (select class from Table1)b )
group by
name,a.time,b.Class
)t
select * from #t
drop table Table1 ,#t
/*name time Class
---------- ----------------------- ----------
第二个 2011-10-24 00:00:00.000 A班
第二个 2011-10-24 00:00:00.000 B班
第三个 2011-10-24 00:00:00.000 A班
第三个 2011-10-24 00:00:00.000 B班
第四个 2011-10-23 00:00:00.000 A班
第四个 2011-10-23 00:00:00.000 B班
第五个 2011-10-23 00:00:00.000 A班
第五个 2011-10-23 00:00:00.000 B班
第五个 2011-10-24 00:00:00.000 A班
第五个 2011-10-24 00:00:00.000 B班
第一个 2011-10-24 00:00:00.000 A班
第一个 2011-10-24 00:00:00.000 B班
(12 行受影响)
*/
插入的时候就不要order by 了
create table [Table1](
[name] nvarchar(10),[time] datetime,[Class] nvarchar(10))
INSERT INTO [Table1]([name],[time],[Class])VALUES('第一个','2011-10-24','A班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第一个','2011-10-24','B班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第二个','2011-10-24','A班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第二个','2011-10-24','B班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第三个','2011-10-24','A班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第五个','2011-10-24','A班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第四个','2011-10-23','A班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第五个','2011-10-23','B班')
go
select * into #t
from(
select
name,a.time,b.Class
from
((select distinct name,time from Table1)a cross join (select time,class from Table1)b )
where
a.time=b.time
group by
name,a.time,b.Class
)t
select * from #t
drop table Table1 ,#t
/*name time Class
---------- ----------------------- ----------
第二个 2011-10-24 00:00:00.000 A班
第二个 2011-10-24 00:00:00.000 B班
第三个 2011-10-24 00:00:00.000 A班
第三个 2011-10-24 00:00:00.000 B班
第四个 2011-10-23 00:00:00.000 A班
第四个 2011-10-23 00:00:00.000 B班
第五个 2011-10-23 00:00:00.000 A班
第五个 2011-10-23 00:00:00.000 B班
第五个 2011-10-24 00:00:00.000 A班
第五个 2011-10-24 00:00:00.000 B班
第一个 2011-10-24 00:00:00.000 A班
第一个 2011-10-24 00:00:00.000 B班
(12 行受影响)
*/
insert into
#tb
select
*
from
(上面那一串)t--这个t不能掉了
create table [Table1](
[name] nvarchar(10),[time] datetime,[Class] nvarchar(10))
INSERT INTO [Table1]([name],[time],[Class])VALUES('第一个','2011-10-24','A班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第一个','2011-10-24','B班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第二个','2011-10-24','A班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第二个','2011-10-24','B班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第三个','2011-10-24','A班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第五个','2011-10-24','A班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第四个','2011-10-23','A班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第五个','2011-10-23','B班')
go
insert into [Table1]
select * from
(select distinct name,[time] from [Table1]) a,
(select distinct [class] from [Table1]) b
except
select * from [Table1]
select * from [Table1] order by
CHARINDEX(name,'第一个第二个第三个第四个第五个')
/*
name time Class
---------- ----------------------- ----------
第一个 2011-10-24 00:00:00.000 A班
第一个 2011-10-24 00:00:00.000 B班
第二个 2011-10-24 00:00:00.000 A班
第二个 2011-10-24 00:00:00.000 B班
第三个 2011-10-24 00:00:00.000 A班
第三个 2011-10-24 00:00:00.000 B班
第四个 2011-10-23 00:00:00.000 B班
第四个 2011-10-23 00:00:00.000 A班
第五个 2011-10-23 00:00:00.000 B班
第五个 2011-10-23 00:00:00.000 A班
第五个 2011-10-24 00:00:00.000 B班
第五个 2011-10-24 00:00:00.000 A班
(12 行受影响)
create table [Table1](
[name] nvarchar(10),[time] datetime,[Class] nvarchar(10))
INSERT INTO [Table1]([name],[time],[Class])VALUES('第一个','2011-10-24','A班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第一个','2011-10-24','B班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第二个','2011-10-24','A班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第二个','2011-10-24','B班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第三个','2011-10-24','A班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第五个','2011-10-24','A班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第四个','2011-10-23','A班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第五个','2011-10-23','B班')
go
select
name,a.time,b.Class
from
((select distinct name,time from Table1)a cross join (select time,class from Table1)b )
where
a.time=b.time
group by
name,a.time,b.Class
order by
CHARINDEX(name,'第一个第二个第三个第四个第五个')
drop table Table1
/*name time Class
---------- ----------------------- ----------
第一个 2011-10-24 00:00:00.000 A班
第一个 2011-10-24 00:00:00.000 B班
第二个 2011-10-24 00:00:00.000 A班
第二个 2011-10-24 00:00:00.000 B班
第三个 2011-10-24 00:00:00.000 A班
第三个 2011-10-24 00:00:00.000 B班
第四个 2011-10-23 00:00:00.000 A班
第四个 2011-10-23 00:00:00.000 B班
第五个 2011-10-23 00:00:00.000 A班
第五个 2011-10-23 00:00:00.000 B班
第五个 2011-10-24 00:00:00.000 A班
第五个 2011-10-24 00:00:00.000 B班
(12 行受影响)
*/
select a.[name],a.[time],b.[Class]
from (
select distinct [name],[time]
from table1
) a cross join (
select distinct [Class]
from table1
) b
create table [Table1](
[name] nvarchar(10),[time] datetime,[Class] nvarchar(10))
INSERT INTO [Table1]([name],[time],[Class])VALUES('第一个','2011-10-24','A班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第一个','2011-10-24','B班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第二个','2011-10-24','A班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第二个','2011-10-24','B班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第三个','2011-10-24','A班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第五个','2011-10-24','A班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第四个','2011-10-23','A班')
INSERT INTO [Table1]([name],[time],[Class])VALUES('第五个','2011-10-23','B班')
go
INSERT [Table1]
SELECT
a.NAME,a.[time],b.[Class]
FROM
(select [name],[time]
from Table1
GROUP BY [name],[time]
HAVING COUNT(1)=1)a,
(SELECT [Class]='A班' UNION ALL SELECT [Class]='B班')b
WHERE
NOT EXISTS(SELECT 1 FROM Table1 WHERE [name]=a.[name] AND [time]=a.[time] AND [Class]=b.[Class])