让我们想象一下,我有视频,每个视频可以有几个标签(每个视频最多有10个标签)。
我计划了我的SQL模式,它看起来如下:
videos:id,title,path,tag_rels:id,tag_id,item_id (将指向videos.id),tags:id,tag;好吧,对我来说很好。
然后,我写了SELECT,它应该得到视频,加上,标签。
SELECT `videos`.`id`, `videos`.`title`, `videos`.`path`, `tags`.`tag`
FROM `videos`
JOIN `tag_rels`
ON `tag_rels`.`item_id` = `videos`.`id`
JOIN `tags`
ON `tags`.`id` = `tag_rels`.`tag_id`它没有经过测试,因为它都是在思想层面上的。
最大的问题是是INSERT查询(我猜是查询)。
据我所知:
videos中插入视频。这将返回主键(videos.id),对吗?tags.tag) ),那么执行一个插入查询并插入它。目标是获取该标记的主键,tag_rels中插入带有视频的pk和标记的pk的条目;因此,每个视频都有一个查询,对的每个标记进行2或3个查询。
这意味着,如果视频有10个标签(最糟糕的情况)没有保存在数据库中,它将花费我1+ 10 *3.嗯..。31查询?!
一定有更好的办法!非常感谢!
我不希望数据库中有重复的条目,我希望在used_in到tags列中使用标签进行视频计数。将来..。
发布于 2011-11-08 16:50:35
对于存储过程来说,这种情况类似。让商店生产的视频数据,和标签的列表。然后在内部执行查询#1至#4。它将更快,因为您不必来回移动数据。
这是你需要的东西。这只是一个起点,所以不要期望它能够编译更少的正确运行,而且您需要所有的10个标记(我认为mysql不能接受数组,但可能有人会更清楚)。
CREATE PROCEDURE insertvideo (IN videotitle CHAR(20),IN videopath CHAR(20), IN tag1 CHAR(20),IN tag2 CHAR(20), IN tag3 CHAR(20) )
BEGIN
DECLARE myid INT;
DECLARE tagid INT;
INSERT INTO videos (title, path) VALUES ( videotitle,videopath);
SELECT id INTO myid FROM videos WHERE title=videotitle AND path=videopath;
SET tagid=NULL;
SELECT id INTO tagid FROM tags WHERE tag=tag1;
IF tagid IS NULL THEN
INSERT INTO tags (tag) VALUES (tag1);
SELECT id INTO tagid FROM tags WHERE tag=tag1;
END IF;
INSERT INTO tag_rels (tag_id, item_id) VALUES (tagid,myid);
SET tagid=NULL;
SELECT id INTO tagid FROM tags WHERE tag=tag2;
IF tagid IS NULL THEN
INSERT INTO tags (tag) VALUES (tag1);
SELECT id INTO tagid FROM tags WHERE tag=tag2;
END IF;
INSERT INTO tag_rels (tag_id, item_id) VALUES (tagid,myid);
SET tagid=NULL;
SELECT id INTO tagid FROM tags WHERE tag=tag3;
IF tagid IS NULL THEN
INSERT INTO tags (tag) VALUES (tag1);
SELECT id INTO tagid FROM tags WHERE tag=tag3;
END IF;
INSERT INTO tag_rels (tag_id, item_id) VALUES (tagid,myid);
END 发布于 2011-11-08 17:00:40
我认为你的计算是错误的。无论标签编号如何,您都需要执行3次查询。
INSERT INTO Video ...INSERT INTO tags(tag)SELECT * FROM
(SELECT 'tag_1' as tag UNION SELECT 'tag_2' ...)a WHERE NOT EXISTS (SELECT 1 FROM tags b WHERE b.tag = a.tag)
3.假设您有一个唯一的索引on (tag_id,item_id),INSERT IGNORE INTO tag_rels( tag_id, item_id) SELECT tag_id, new_video_id FROM tags WHERE tags.tag IN ([new tag_list]) (new_video_id -是在向视频中插入记录后得到的Video.id )
https://stackoverflow.com/questions/8053941
复制相似问题