我有一个复杂的查询,我已经摔跤了2天,似乎无法让它运行。我有两个查询 - 第一个查询工作正常,但我无法弄清楚第二个 我做错了什么?
CREATE TABLE `recipes` (
`id` int(10) unsigned NOT NULL auto_increment,
`name` varchar(100) NOT NULL default '',
`cat` int(5) NOT NULL default '0',
`instructions` text NOT NULL,
`submitted_by` varchar(100) NOT NULL default '',
`addDate` date NOT NULL default '0000-00-00',
`hits` int(7) NOT NULL default '0',
`metaDesc` text NOT NULL,
`metaKeys` text NOT NULL,
`enComments` enum('yes','no') NOT NULL default 'yes',
`enRating` enum('yes','no') NOT NULL default 'yes',
`enRecipe` enum('yes','no') NOT NULL default 'yes',
`isApproved` enum('yes','no') NOT NULL default 'no',
`comCount` int(7) NOT NULL default '0',
`ratingCount` int(8) NOT NULL default '0',
`ipAddresses` text NOT NULL,
`email` varchar(250) NOT NULL default '',
`rss_date` varchar(35) NOT NULL default '',
PRIMARY KEY (`id`),
FULLTEXT KEY `name` (`name`,`instructions`,`metaDesc`,`metaKeys`),
FULLTEXT KEY `submitted_by` (`submitted_by`)
) ENGINE=MyISAM DEFAULT CHARSET=latin1 AUTO_INCREMENT=37 ;
CREATE TABLE `ingredients` (
`id` int(10) NOT NULL auto_increment,
`recipe` int(8) NOT NULL,
`qty` varchar(128) NOT NULL,
`measurement` varchar(128) NOT NULL,
`ingredient` varchar(128) NOT NULL,
PRIMARY KEY (`id`),
KEY `ingredient` (`ingredient`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 AUTO_INCREMENT=135 ;
我创建了一个查询,将搜索词与成分表中的任何成分相匹配,并生成整个配方。
$q_recipe = mysql_query("SELECT * FROM recipes
WHERE enRecipe = 'yes'
AND isApproved = 'no'
AND MATCH(name,instructions,submitted_by,metaDesc,metaKeys) AGAINST('".$search."') IN BOOLEAN MODE)
OR id IN (SELECT distinct recipe FROM ingredients WHERE ingredient LIKE '%".$search."%')
ORDER BY name LIMIT $limit") or die(mysql_error());
目标是重写上述查询以提供新的搜索功能,该功能将搜索项数组与仅包含数组中所有项的配方相匹配。帮助!
答案 0 :(得分:1)
找到解决方案虽然效率可能不高。
foreach ($search as $item) {
$sql .= "AND id IN (SELECT recipe FROM ingredients WHERE ingredient like '%".$item."%') ";
}
$q_sql = "SELECT * FROM recipes
WHERE enRecipe = 'yes'
AND isApproved = 'no'
".$sql;
答案 1 :(得分:0)
'反对'中的额外括号。将AGAINST('".$search."') IN BOOLEAN MODE)
更改为AGAINST('".$search."' IN BOOLEAN MODE)
。
我还要小心让两个表使用不同的字符集。