- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试用 PHP 创建一个系统,我可以在其中根据他们的订单信息和对这些答案的要求发送自动答案。例如,如果客户的订单中包含 product_id 20,30 和 40。我希望能够为其中一个答案设置一个要求,检查它是否匹配,然后发出相应的答案。
目前有两张表,一张用于消息本身,一张用于与这些消息相关联的要求。
tickets_answers
id name message
1 Test 1 This is the first test message.
2 Test 2 Another test message
tickets_answers_options
id answer_id option_type option_id
1 1 product_id 20
2 1 product_id 30
3 1 product_id 40
4 2 product_id 25
5 2 product_id 30
遍历所有可用答案并查看它们是否匹配不是首选,因为我不知道将来会设置多少答案/要求。这就是为什么我尝试根据第二个表中显示为 option_ids 的已知产品 ID 检索相应的答案。
查询将使用 PHP 构建。我很可能会根据订单本身的信息进行内爆或构建查询。我现在只是尝试整理 SQL 部分。
我尝试了以下查询来检索 answer_id
SELECT answer_id
FROM tickets_answers_options
WHERE option_id IN (SELECT option_id
FROM tickets_answers_options
WHERE option_type = 'product_id'
AND option_id = 20
OR option_id = 30
OR option_id = 40)
GROUP BY answer_id
这导致接近我想要的东西。此查询返回 answer_ids
1
2
在这种情况下,2 会弹出,因为它与子查询中提到的 option_id 之一匹配。
我想要的结果是获得与 option_ids 匹配的单个 answer_id。我发现这可能有点落后于我为这个特定系统设置结构的方式。但将来会有多个 option_types 需要检查。现在,我正在尝试仅检查 product_id,在 PHP 中,我可以为不同的 option_types 设置多个查询,以确保一切匹配。
我希望我在这里发布了足够的相关信息,如果没有,请告诉我,以便我提供更多信息。并感谢您提前花时间阅读本文。
最佳答案
不是很优雅,但你可以为每个产品 ID 构建一个子查询并将它们全部加入:
SELECT a.answer_id
FROM (SELECT t.answer_id
FROM tickets_answers_options t
WHERE t.option_type = 'product_id'
AND t.option_id = 20) as a
JOIN (SELECT t.answer_id
FROM tickets_answers_options t
WHERE t.option_type = 'product_id'
AND t.option_id = 30) as b
ON a.answer_id = b.answer_id
JOIN (SELECT t.answer_id
FROM tickets_answers_options t
WHERE t.option_type = 'product_id'
AND t.option_id = 40) as c
ON a.answer_id = c.answer_id
编辑
上面的选项可以创建相当多的子查询。这是另一个可能具有更好性能且更优雅的选项。
请注意,您始终需要为 HAVING 子句 sorted 提供产品 ID,这样:20,30,40
而不 em> 这样:30,20,40
才能正常工作。
SELECT t.answer_id, GROUP_CONCAT(DISTINCT(t.option_id) ORDER BY t.option_id) AS option_ids_found
FROM tickets_answers_options t
WHERE t.option_type = 'product_id'
AND t.option_id in (20,30,40)
GROUP BY t.answer_id
HAVING option_ids_found = '20,30,40'
关于php - 在多对一的情况下,如何根据多个 ID 从列中选择唯一值?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40471444/
我有一个 ProductDescription ViewController,它从我放置在许多 ViewController 中的 ProductTable UITableView 调用。 对于 St
首先,是的,我使用的是 DistinctRootEntityResultTransformer。 我有以下(Fluent NHibernate)映射: public FirstObjectMap()
我有两个模型:Book 和 Author。每个Author有很多本书,每本书有很多作者,所以我在Author和Book之间建立了ManyToMany关系,如下所示: class Author(mode
我正在尝试映射两个具有一对一关系的类之间的关系。在互联网上查找后,似乎人们更喜欢使用多对一来映射它。 例如,有一个 Order 类和 Bill 类。比尔持有发票的 FK。 这是我为比尔绘制的 map
假设有以下实体类: public class Player { public virtual int ID { get; set; } public virtual string Name { g
我想尝试一下 dynamodb 我能够保存单个对象。现在我想尝试创建一个多对一的关联。 许多任务应附加到单个用户。 @DynamoDBTable(tableName = "User") public
所以,情况如下: 表ComputerInventory,其中包含{computerInventoryID(主键)、TagID(唯一)、名称等} 表reviewStatus,其中包含{reviewSta
我在使用 hibernate 进行多对一映射时遇到问题。我有两个表,表 A 和表 B。我在这些表之间映射了多对一关系。两个表可以一起使用,也可以单独使用。 用 Java 中的类来表示表,例如: cla
我的实体: @Entity public class Film { @Id @GeneratedValue(strategy = IDENTITY) private long film
我必须制作拼贴项目的域层。我们的标准很少,比如我们必须使用 Hibernate,而且数据库也是固定的。 数据库的相关部分看起来几乎像这样: BusEntity(表 1) 总线 ID 公交车具体信息 总
如果有这两个实体: @Entity @Table(name = "CUSTOMER") public class Customer { @Id @GeneratedValue(stra
我正在尝试找出在多对一关系中检索单个最新结果的最有效方法。 示例: 实体 A - 团队(名称)实体 B - 员工(姓名,已创建) 团队>员工 我想在 Employee 上创建一个获取请求,返回每个团队
假设我有一个MySQL表read,记录了一个userid和一个articleid,记录了用户阅读了哪些文章。我现在想列出已阅读文章 1、2 和 3 的用户。 我知道以下是不可能的,但它说明了这个想法:
我的两个实体之间存在多对一关系。现在我希望当没有更多的 child 时将 parent 移除。 我的情况: 类(class)联系人 类(class)组织 一个组织有几个联系人,每个联系人都有一个组织。
我有下表: A 和 B A 有一个复合 PK:id int,类型 string。 B 只有 A 的 PK 之一:id int。 如何使用 B 的 id 和常量 type='typeB' 定义从 A 到
我正在为我的项目使用 Hibernate 3 映射一些实体,并简单地解释说我有这样的东西: Student 实体(tstudent 表) UniversityStudent 实体(tuniversit
我有一个成员表:成员(id, name, gender, head_id) 我想要的是建立以户主(家庭成员)为基础的家庭关系。就像这样:一个成员属于一个家庭(由成员定义) 也许我可以将其拆分为 2 个
示例 父类 @OneToMany(mappedBy = "parent") private List childs; 子类 @ManyToOne(cascade = CascadeType.ALL)
我有以下化学过程数据集,由 5 个连续输入向量组成,产生 1 个输出。每个输入每分钟采样一次,而输出操作系统每 5 采样一次。 虽然我相信输出取决于之前的 5 个输入向量,但我决定为我的设计寻找 LS
我正在将我的应用程序从原则 1 转换为原则 2.4我确实从数据库自动映射,但缺少一些关系: 表:产品产品 ID、标题、价格 表:位置产品id , 产品id , 位置id , 数量 因此每个 Locat
我是一名优秀的程序员,十分优秀!