求一sql语句!!高手帮帮忙

mydreamf 2008-03-12 05:49:01
有两个表
表1、配置预约的表,表2、已经预约的表
表1的字段。id,预约项目,预约名额,时间
表2的字段。ID,预约的人,预约的项目
表1、假设数据
id,预约项目,预约名额,时间
1,洗剪吹,2,12:00
2,染头发,3,12:00

在申请预约的时候,有一个页面根据时间显示出,当前可以预约的项目,
假设 洗剪吹已预约2人,染头发已预约2人。那么只剩下一个名额是染头发得。那么我在选择预约项目的时候,只能选择染头发。洗剪吹就不能选了。
假设 洗剪吹已预约1人,染头发已预约2人。那么就可以选择洗剪吹和剪头发两个项目

求一sql可以筛选出,预约名额未满的项目
...全文
245 31 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
31 条回复
切换为时间正序
请发表友善的回复…
发表回复
mydreamf 2008-03-14
  • 打赏
  • 举报
回复
[Quote=引用 30 楼 yangpeiyu 的回复:]
楼主。你根本都是乱来。给分都乱给。
再说给你点评一下上面那兄弟my22xo 这个人的SQL效率都会很大的问题。not in 当你数据多就能休现出来。
小题大做。没话说。。
[/Quote]

1、首先my22xo,即时帮我解决了问题。
2、我也明白not in的效率问题。我的数据并不多,撑死也没有100条,所有用not in.
3、你提供的方法我的实际情况解决不了,因为我知道a.预约名额,并不知道b.的已预约名额,这个算法。是根据my22xo的提示,我自己试出来。
yangpeiyu 其实分数没啥。主要是否解决了问题。
您的建议,我下次注意。
望你海涵
骑蚊子旅游 2008-03-13
  • 打赏
  • 举报
回复
[Quote=引用 21 楼 mydreamf 的回复:]
my22xo 和yangpeiyu
不知道是不是我的问题,如果在预约表里面某个项目没有被预约那么,查出来的结果,都是不对的。
[/Quote]


兄弟,把语句改成这个:

select 预约项目表.itemname from 预约项目表 inner join 预约表 on 1=1 where 预约项目表.itemNum not in (select count(预约表.ID) from 预约表 where 预约表.itemid=预约项目表.id group by 预约表.itemID) group by 预约项目表.itemname

mydreamf 2008-03-13
  • 打赏
  • 举报
回复
郁闷阿,脑袋打结了。。。
mydreamf 2008-03-13
  • 打赏
  • 举报
回复
my22xo 和yangpeiyu
不知道是不是我的问题,如果在预约表里面某个项目没有被预约那么,查出来的结果,都是不对的。
mydreamf 2008-03-13
  • 打赏
  • 举报
回复
哈哈,我来拉!感谢my22xo 和yangpeiyu。
我根据你们的算法来弄弄看,回来给你们分。
yangpeiyu 2008-03-13
  • 打赏
  • 举报
回复
楼主。你根本都是乱来。给分都乱给。
再说给你点评一下上面那兄弟my22xo 这个人的SQL效率都会很大的问题。not in 当你数据多就能休现出来。
小题大做。没话说。。
mydreamf 2008-03-13
  • 打赏
  • 举报
回复
加入筛选条件后,程序完美执行!
感谢my22xo的赐教!马上结贴
骑蚊子旅游 2008-03-13
  • 打赏
  • 举报
回复
我倒,呵呵。

得加分才行,哈哈


select 预约项目表.id,预约项目表.itemname from 预约项目表 inner join 预约表 on 1=1 where 预约项目表.itemNum not in (select count(预约表.ID) from 预约表 where 预约表.itemid=预约项目表.id group by 预约表.itemID) group by 预约项目表.itemname,预约项目表.id order by 预约项目表.id
mydreamf 2008-03-13
  • 打赏
  • 举报
回复
嗯,我详细看看。
我按照你的思路,写出来了。发现一个问题
由于在主语句使用了group by group by 预约项目表.itemname
所以我无法得到。当前洗剪吹的项目的id,我只知道了。还剩下的预约项目的名字,然而在预约表的情况下,我需要存入对应的id
骑蚊子旅游 2008-03-13
  • 打赏
  • 举报
回复
预约表.itemid=预约项目表.id 的作用是这样的,由于预约项目表.itemnum不是唯一的,用select count(预约表.ID) from 预约表 group by 预约表.itemid 查询出来的值比如可能是6,3,2,1 而主语句itemnum就会产生和结果为6的itemid关联,还会和结果为3的itemid关联,查出的结果就不准确。由于两个表在主语句中已经inner join进行了联接,所以加个限制条件“预约表.itemid=预约项目表.id”就可防止数据重复。

这个不好表达,把结果都列出,举个实例吧
(预约项目表)select id,itemname,itemnum from 预约项目表 (把这个假设称为A查询)
1 洗剪吹 6
2 染头发 3
3 拉头发 2
4 测试1 2
5 测试2 3
6 测试3 9

select itemid,count(预约表.ID) from 预约表 group by 预约表.itemID (把这个假设称为B查询)
1 5
2 3
3 1
4 2

我们可以看到A查询洗剪吹是6个名额,在B查询中对应的项目ID(洗剪吹的ID是1,B查询中的ITEMID=1的已登记名额为5,则剩余1个名额),有1个空余名额,但由于使用关键字not in,所以在B查询中的每一个结果都符合洗剪吹的空余名额(全部小于洗剪吹的6个名额),这样结果就肯定不正确了,同时满足染头发这个项目的在B查询中有3和4,都小于染头发的总名额,光这两个项目统计出来就有6个,所以在主语中用了inner join 语句,这时候在子查询中加个限制条件,即A查询中的ID和B查询中的itemid对应的统计出来(比如洗剪吹的ID1与B查询中的ID1对应起来,不对应的不选择出来),这样才是正确的对应关系。不知道这样讲解你是否明白?明白了的话望楼主加点分,呵呵。谢谢
mydreamf 2008-03-13
  • 打赏
  • 举报
回复
稀里糊涂,既然写出来了。给自己一把掌先
mydreamf 2008-03-13
  • 打赏
  • 举报
回复
my22xo
select count(预约表.ID) from 预约表 where 预约表.itemid=预约项目表.id group by 预约表.itemID
这句话的意思是?
为什么是where 预约表.itemid=预约项目表.id
这个不可能相等把,就是为了不想等吗?
fcxxfcxx 2008-03-12
  • 打赏
  • 举报
回复
up
ccaakkee 2008-03-12
  • 打赏
  • 举报
回复
mark
骑蚊子旅游 2008-03-12
  • 打赏
  • 举报
回复
我刚特意测试了一下

把下面的SQL代码直接放到查询分析器里面执行,就可以显示出结果了。

呵,结分:)


create table 预约项目表
(
id int identity(1,1),
itemName varchar(20) default '',
itemNum int default 0,
itemDateTime datetime default getdate()
)


create table 预约表
(
id int identity(1,1),
itemID int default 0,
personName varchar(20) default '',
)

insert into 预约项目表(itemName,itemNum) values('洗剪吹',6)
insert into 预约项目表(itemName,itemNum) values('染头发',3)
insert into 预约项目表(itemName,itemNum) values('拉头发',2)

insert into 预约表(itemID,personName) values(1,'张三')
insert into 预约表(itemID,personName) values(1,'张四')
insert into 预约表(itemID,personName) values(1,'张四')
insert into 预约表(itemID,personName) values(1,'张五')
insert into 预约表(itemID,personName) values(1,'张五')
insert into 预约表(itemID,personName) values(2,'李一')
insert into 预约表(itemID,personName) values(2,'李二')
insert into 预约表(itemID,personName) values(3,'王老一')
insert into 预约表(itemID,personName) values(3,'王老二')



select * from 预约项目表
select * from 预约表
select count(预约表.ID) from 预约表 group by 预约表.itemID

select 预约项目表.itemname from 预约项目表 where 预约项目表.itemNum not in (select count(预约表.ID) from 预约表 group by 预约表.itemID)

骑蚊子旅游 2008-03-12
  • 打赏
  • 举报
回复
试试我的SQL,按不同的项目ID(建议用ID,因为用名字的话有时候若改了项目名字会导致查询结果不正确)分组统计出一共有多少人已经预约,然后看一下项目的预约名额,若统计的结果和预约名额相等,说明预约名额已经满了,所以用了not in,表示预约未满的名额的项目全部查找出来了。

mydreamf 2008-03-12
  • 打赏
  • 举报
回复
ok,下班了。。明天回来结贴!
骑蚊子旅游 2008-03-12
  • 打赏
  • 举报
回复
建议表2的字段加一个字段项目ID,以便和表1的ID值关联

select 表1.预约项目 from 表1 where 表1.预约名额 not in (select count(表2.ID) from 表2 group by 表2.项目ID)


如果要做时间判断的话,表2里面也要加上别人预约的时间字段,然后在上面的语句里面把时间条件放进去就可以了。

yangpeiyu 2008-03-12
  • 打赏
  • 举报
回复
嗯。可以的。你照改就可以的啦。记得给分哦。哈。
mydreamf 2008-03-12
  • 打赏
  • 举报
回复
我试试看,这样好像差不多。。。
加载更多回复(10)

62,243

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧