Как я могу создать систему тегов, используя php и mysql?
Интересно, как я могу создать систему тегов в php и с базой данных mysql, я сначала хотел создать в таблице строку, в которой хранятся статьи, именованные теги и перечислить теги, разделенные запятыми, но я не уверен, как я могу создать запрос, который ищет соответствующие теги, я не хочу запрашивать каждую статью каждый раз, когда кто-то нажимает на тег. кто-нибудь может помочь?
2 ответа
Решение
Вы описываете отношения "многие ко многим" между статьями и тегами. Вы хотели бы использовать промежуточную соединительную таблицу для разрешения этих отношений.
Теперь, чтобы найти все статьи, которые соответствуют выбранному тегу:
SELECT a.article_title
FROM Tag t
INNER JOIN Article_Tag_Xref atx
ON t.tag_id = atx.tag_id
INNER JOIN Article a
ON atx.article_id = a.article_id
WHERE t.tag_name = 'SelectedTagName'
tbl_articles имеет articleID и т. д.
У tbl_tags есть tagID и т. д.
tbl_taggedarticles имеет taggedArticleID, articleID, tagID
SELECT articleID FROM tbl_taggedarticles WHERE tagID = "searchedID"