- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在制作一个应用程序,用户可以在其中完成任务。这些任务具有关联Requirements
。 用户
有一个关联资格
两者通过共享的QualificationCategory
连接
任务
有许多要求,用户
有许多资格
。
需求的结构如下:
Requirement
- ID
- qualification_category_id
- task_type_id
- points_required
资格的结构如下:
Qualification:
- ID
- qualification_category_id
- user_id
- points
问题是这样的:
对于一个用户,我需要找到他被允许完成的所有任务。因此,我想从数据库中选择 task_type.requirements
与 user.qualifications
因此,对于每个任务,检查要求是否与基于 Qualification_category 的任何用户资格相匹配,并且对于每个要求,检查相应的用户资格分数是否高于或等于所需分数。
模型
class Requirement < ApplicationRecord
belongs_to :qualification_category
belongs_to :task_type, inverse_of: :requirements
end
class Task < ApplicationRecord
belongs_to :task_type
belongs_to :data_sourceable, polymorphic: true, optional: true
belongs_to :user_id, optional: true
belongs_to :solution, class_name: 'Hypothesis', optional: true
belongs_to :payment_period, optional: true
has_many :worker_groups, through: :task_type
has_many :requirements, through: :task_type
end
class User < ApplicationRecord
# Include default devise modules. Others available are:
# :confirmable, :lockable, :timeoutable and :omniauthable
devise :database_authenticatable, :timeoutable, :confirmable, :lastseenable,
:recoverable, :rememberable, :trackable, :validatable, :registerable
has_and_belongs_to_many :roles
has_and_belongs_to_many :worker_groups
has_many :payment_periods
has_many :qualifications, inverse_of: :user
has_many :qualification_categories, through: :qualifications
end
class Qualification < ApplicationRecord
belongs_to :qualification_category
belongs_to :user, inverse_of: :qualifications
end
如何编写 MySQL 查询或 ARel 语句来完成此操作。该应用程序将容纳数百万个任务,因此在 ruby 中这样做是不可取的。
数据库 fiddle :https://www.db-fiddle.com/f/2jBx1gQhzqn1hYS5xD82n/0
最佳答案
返回全部task
特定的user
符合(基于匹配单个资格)MySQL 查询,如下所示:
SELECT t.id
FROM task t
JOIN task_type tt
ON tt.id = t.task_type_id
JOIN requirement r
ON r.task_type_id = tt.id
JOIN qualification q
ON q.qualification_category_id = r.qualification_category_id
AND q.points >= r.points_required
JOIN user u
ON u.id = q.user_id
WHERE u.id = ?
这可能会返回“重复项”;因此我们可以添加一个 GROUP BY 子句,或者将连接操作更改为 EXISTS 谓词。
<小时/>为了仅匹配用户资格满足所有要求的任务,我们需要一些不同的东西:
SELECT t.id
FROM task t
JOIN task_type tt
ON tt.id = t.task_type_id
WHERE EXISTS
( SELECT 1
FROM requirement r
JOIN qualification q
ON q.qualification_category_id = r.qualification_category_id
AND q.points >= r.points_required
WHERE r.task_type_id = tt.id
AND q.user_id = ? -- specific user
)
AND NOT EXISTS
( SELECT 1
FROM requirement r
LEFT
JOIN qualification q
ON q.qualification_category_id = r.qualification_category_id
AND q.user_id = ? -- specific user
WHERE r.task_type_id = tt.id
AND ( q.user_id IS NULL OR q.points < r.points_required )
)
EXISTS
bit 检查用户是否至少拥有一项满足要求的资格。
NOT EXISTS
位检查是否有任何 requirement
对于用户没有匹配的任务类别 qualification
.
再多考虑一下,我认为 EXISTS
部分可以省略,我们只需要检查 NOT EXISTS
...有没有requirement
qualification
不满足该条件.
SELECT t.id
FROM task t
JOIN task_type tt
ON tt.id = t.task_type_id
WHERE NOT EXISTS
( SELECT 1
FROM requirement r
LEFT
JOIN qualification q
ON q.qualification_category_id = r.qualification_category_id
AND q.user_id = ? -- specific user
WHERE r.task_type_id = tt.id
AND ( q.user_id IS NULL OR q.points < r.points_required )
)
(假设qualification.points
和requirement.points_required
非空,因此不等式比较将计算为TRUE。如果我们有可能出现NULL值,我们需要适本地处理这些值。)
关于mysql - 如何根据关联的全匹配查找记录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47396808/
Apache服务器全局配置之服务器标识配置篇 服务器标识相关指令: ServerName ServerAdmin ServerSignature ServerTokens UseCanonical
//校验是否全由数字组成 ? 1
具体内容如下: 1 os.system 例如 ipython中运行如下命令,返回运行状态status os.system('cat /etc/passwdqc.conf') min=disab
基本操作 查看数据库 ? 1
Xcode使用教程详细讲解是本文要介绍的内容,Xcode是一个款强大的IDE开发环境,就像你在写Windows程序时需要VS2005一样 需要要Xcode为你写Mac程序提供环境。因此,如果你要成为
就如今天遇到随即函数rand();脑海中想到用它做点啥好呢,最后想起了验证码,数字验证码,字母验证码,中文验证码,可是自己不会呀,咋办呢,上网搜,看别人的代码,开不懂,看视频,听老师讲,将其中所遇到
pcre-7.8.tar.gz 正则表达式下载地址:ftp://ftp.csx.cam.ac.uk/pub/software/programming/pcre/
IDEA常用设置(提高开发效率) 本人也是IDEA编译器的忠实用户了,但是有时出于各种原因,比如更换设备等等,IDEA总是需要重新安装配置。这就让我比较苦恼,因为总是记不全自己之前都修改了
? 1 2
1、 操作环境搭建 系统:Windows7 旗舰版 64位 PHP环境:wampserver2.2e-php5.4.3-httpd2.2.22-mysql5.5.24 32
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 去年关闭。 Improve th
我已经为我在 Adobe Fireworks Cs5 中构建的页面生成了 css,我想知道如何为我的标题和其他 div 设置完整宽度。我将显示标题部分的 css 代码。 @charset "utf
您好,我希望表单宽度为 100%。我希望文本框几乎延伸整个页面的宽度,并在文本框的右侧直接放置小的“GO”按钮,所有按钮都在同一行(或 block )上。 现在我的文本框只有其中文本的宽度(“在此处输
我没有设法将全宽页脚粘贴到网页底部。当页脚上方的主要内容低于一定高度时,页脚下方有一个空白区域。我尝试使用各种解决方案,例如以下 css 代码: html,body { margin:0; padd
我想要一个全宽的表格。当我给 position:fixed; 它变成全宽但可滚动不起作用。 简而言之,我需要一个与浏览器主体没有任何边距的表格。 body { font-family: "Helv
我注意到很多大型网站(如 Google 和 Facebook)在查看页面源代码时 99% 的源代码都是 JavaScript。 有人知道这种方法相对于常规 HTML+JavaScript 页面的优势吗
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 8 年前。 Improve this q
由于某种原因,我网站上的图片不再是全宽的。 据我所见,所有内容都设置为 100% 宽度。 http://cargocollective.com/btatest 我是不是什么地方都没有? 最佳答案 我认
我正在创建一个菜单并尝试使用 CSS 制作全宽菜单。但是,我不确定菜单项将如何出现在菜单中。 这是问题的截图: 问题出在我得到的“GAP”中。 如果我有固定数量的元素,我知道我可以使用这个逻辑: ul
这个问题在这里已经有了答案: Puzzle: Find largest rectangle (maximal rectangle problem) (6 个答案) 关闭 9 年前。 给定一个二元矩阵
我是一名优秀的程序员,十分优秀!