我试图弄清楚如何查询我的MYSQL数据库-不幸的是我根本不擅长MYSQL ...
我有两个表:
帖子:
---------------------
| id | name | type |
---------------------
| 1 | mike | type1 |
| 2 | john | type2 |
| 3 | bill | type1 |
---------------------
后元:
-------------------------------
| id | post_id | key | value |
-------------------------------
| 1 | 1 | key1 | val1 |
| 2 | 1 | key2 | val2 |
| 3 | 3 | key3 | val3 |
-------------------------------
我想要的是一些逻辑,例如:
When posts.type == type 1
select m.id, m.key, m.value from postmeta m
where post_id === posts.id
最好是,如果我有这样的$ result => $ row:
array (
id => post.id,
name => post.name,
options => array (
key => value
...
)
)
这是我现在的查询。它接近了,但是还没有解决问题的方法:
$sql = "SELECT p.id, p.post_title, p.post_content, p.post_type, m.meta_key, m.post_id, m.meta_id, m.meta_value
FROM posts p
JOIN postmeta m ON m.post_id = p.id
WHERE type='type1'
GROUP BY p.id";
我想念什么?
谢谢你的帮助!
塞布
您可以使用内部联接和条件进行选择
select m.id, m.key, m.value
from postmeta m
inner join posts as p on( p.id = m.id and p.type = 1)
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句