mysql – 使用AND从term_taxnomy表中选择
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了mysql – 使用AND从term_taxnomy表中选择,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2505字,纯文字阅读大概需要4分钟。
内容图文
![mysql – 使用AND从term_taxnomy表中选择](/upload/InfoBanner/zyjiaocheng/902/0d5368fa35b84771b11c8cc2e460dac4.jpg)
我遇到了一种情况,我必须在支票上显示帖子并取消选中条款.
已分配条款的帖子.我有条件’区’和’美食’现在我必须选择有’XYZ’区和烹饪’ABC’的帖子.
我试过的查询: –
SELECT p.ID, p.post_title
FROM wp_posts p
LEFT JOIN `wp_term_relationships` t
ON p.ID = t.object_id
LEFT JOIN `wp_term_taxonomy` tt
ON t.term_taxonomy_id = tt.term_taxonomy_id
WHERE tt.term_id IN (".$area.")
OR tt.term_id IN (".$cuis.")
GROUP BY t.object_id
HAVING COUNT( t.term_taxonomy_id ) = 2
LIMIT 0,7
wp_term_taxonomy的结构如下所示: –
问题是单表和单列,并在值之间应用AND运算符.
wp_term_relationship
object_id | wp_term_taxonomy_id | term_order
==============================================
134 | 36 | 0
______________________________________________
135 | 36 | 0
wp_posts
ID | post_title |
==================================
1 | Hello world! |
__________________________________
2 | Test |
wp_term_taxnomy
term_taxonomy_id term_id taxonomy description parent count
=============================================================================
1 1 category ------ 0 2
解决方法:
假设我们有3个表:
| test1 | | test1_to_test2 | | test2 |
|-------+ +----------------| +-------|
| id |-----| test1_id | +----| id |
| test2_id |----+
正是你所拥有的结构.
内容:
test1
+----+-------+
| id | value |
+----+-------+
| 1 | val1 |
| 2 | val2 |
+----+-------+
test1_to_test2
|----------+----------|
| test1_id | test2_id |
|----------+----------|
| 1 | 1 |
| 1 | 2 |
| 2 | 1 |
|----------+----------|
test2
|----+
| id |
|----+
| 1 |
| 2 |
|----+
我们需要从test1表中选择值,test1_to_test2中的行包含(test2_id = 1)AND(test2_id = 2).所以,我们想要这个:
+----+-------+
| id | value |
+----+-------+
| 1 | val1 |
+----+-------+
为此,我们将任务分为两个子任务:
1.从test1_to_test2中选择test1_id,它包含两行:
SELECT
test1_id
FROM
test1_to_test2
WHERE
test1_to_test2.test2_id IN (1,2)
GROUP BY
test1_id
HAVING
COUNT(test1_id) = 2
2.使用子查询和IN运算符(它是我们需要的SQL)从test1中选择适当的行:
SELECT
test1.id,
test1.`value`
FROM
test1
WHERE
test1.id IN
(
SELECT
test1_id
FROM
test1_to_test2
WHERE
test1_to_test2.test2_id IN (1,2)
GROUP BY
test1_id
HAVING
COUNT(test1_id) = 2
)
我们得到了我们所需要的:
+----+-------+
| id | value |
+----+-------+
| 1 | val1 |
+----+-------+
对您的表使用相同的方法,您将获得具有“XYZ”区域和烹饪“ABC”的帖子.
内容总结
以上是互联网集市为您收集整理的mysql – 使用AND从term_taxnomy表中选择全部内容,希望文章能够帮你解决mysql – 使用AND从term_taxnomy表中选择所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。