一亩三分地论坛

 找回密码
 获取更多干货,去instant注册!

扫码关注一亩三分地公众号
查看: 632|回复: 3
收起左侧

[数组] Databases: DB5 SQL

[复制链接] |试试Instant~ |关注本帖
神罗天征 发表于 2015-3-28 17:36:40 | 显示全部楼层 |阅读模式

注册一亩三分地论坛,查看更多干货!

您需要 登录 才可以下载或查看,没有帐号?获取更多干货,去instant注册!

x
Q4
Remove all ratings where the movie's year is before 1970 or after 2000, and the rating is fewer than 4 stars

最近在斯坦福公开课平台学习Databases,但是这道题实在是不会了,始终得不到正确答案,请大神帮忙解答,跪谢

delete
from rating
where rating.mID in (select movie.mID
from movie join rating using(mID)
where movie.year <1970 or movie.year>2000 and stars<4)
这是我的代码

评分

1

查看全部评分

2015fallcser 发表于 2015-3-28 18:22:52 | 显示全部楼层
AND has greater priority than OR.
回复 支持 反对

使用道具 举报

 楼主| 神罗天征 发表于 2015-3-28 19:47:43 | 显示全部楼层
2015fallcser 发表于 2015-3-28 18:22
AND has greater priority than OR.

但是添加了括号,最终出来的结果还是错的
回复 支持 反对

使用道具 举报

mything 发表于 2015-3-29 21:33:11 | 显示全部楼层
本帖最后由 mything 于 2015-3-29 21:35 编辑

你的解法问题是删除了所有这个mID的rating,不管是大于4还是小于4,sub query只决定了要有至少一个rating是小于4的,但在主query里就只得到了mID信息,不知道具体是哪个rating了,而SQLite又不支持多个attributes的in判断,所以要把stars的判断放在主query里做。我开始还有一个更brute force的解法,把所有判断放在sub query里,用exists来过滤。
回复 支持 反对

使用道具 举报

本版积分规则

请点这里访问我们的新网站:一亩三分地Instant.

Instant搜索更强大,不扣积分,内容组织的更好更整洁!目前仍在beta版本,努力完善中!反馈请点这里

关闭

一亩三分地推荐上一条 /5 下一条

手机版|小黑屋|一亩三分地论坛声明 ( 沪ICP备11015994号 )

custom counter

GMT+8, 2016-12-10 13:21

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

快速回复 返回顶部 返回列表