我有这样的数据库:
例如,用户使用来请求所有posts
数据posts.post_id = 1
。现在,我想从其他表中获取其他数据:
posts
有post_id = 1
postmeta
与post_id = 1
users
中的某些字段取决于posts.user_id
位置post_id = 1
files
与以下项有关联的所有字段post_id = 1
terms
中的某些字段与post_id = 1
在PHP中,我可以简单地运行5个查询来获取此信息,但是我猜这不是最好的方法,因为MySQL能够更快地执行此操作。
更新详细信息:
-- select from posts
SELECT
posts.post_id,
posts.post_title,
posts.post_name,
posts.post_content,
posts.post_status,
posts.post_type,
posts.post_modified_gmt,
posts.post_date_gmt,
posts.post_mime_type,
posts.user_id
FROM
posts
WHERE
posts.post_id = 1
--select from postmeta
SELECT
postmeta.postmeta_value,
postmeta.postmeta_key,
postmeta.postmeta_id
FROM
postmeta
WHERE
postmeta.post_id = 1
SELECT
files.file_size,
files.file_type,
files.file_name,
files.file_id
FROM
files
INNER JOIN file_relationships ON files.file_id = files.file_id
WHERE
file_relationships.post_id = 1
--select from terms
SELECT
terms.term_id,
terms.term_name,
terms.term_slug,
terms.term_taxonomy,
terms.term_description,
terms.term_group,
terms.term_parent,
terms.term_count
FROM
term_relationships
INNER JOIN terms ON term_relationships.term_id = terms.term_id
WHERE
term_relationships.post_id = 1
--select from users , users.user_id depend on posts.user_id
SELECT
users.user_id,
users.user_name,
users.user_email,
users.user_nicename,
users.user_password,
users.user_displayname,
users.user_role,
users.user_bio
FROM
users
WHERE
users.user_id = 1
这是查询,我运行以获取有关PHP,数据库和数据的信息
有没有一种方法可以仅使用MySQL?
单个查询并不总是比多个查询更好。在这种情况下,我建议仅合并您的1对1关系,但对多对1关系保留单独的查询,因为如果单个帖子包含3个术语和2个文件,将多对1关系都连接起来,则会产生6行。
选择帖子,用户和帖子元数据
select * from posts p
join postmeta pm on pm.post_id = p.post_id
join users u on u.user_id = p.user_id
where p.post_id = 1
选择文件
select f.* from files f
join file_relationships fr on fr.file_id = f.file_id
join posts p on p.post_id = fr.post_id
where p.post_id = 1
选择条款
select t.* from terms t
join term_relationships tr on tr.term_id = t.term_id
join posts p on p.post_id = tr.post_id
where p.post_id = 1
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句