首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >匹配(field1,field2)与匹配(Field1)或匹配(Field2)之间的差异

匹配(field1,field2)与匹配(Field1)或匹配(Field2)之间的差异
EN

Stack Overflow用户
提问于 2014-05-22 17:13:52
回答 1查看 37关注 0票数 0

以下两种查询的结果是否有差异?

代码语言:javascript
复制
SELECT *
FROM table1, table2
WHERE
    ( MATCH(table1.row1) AGAINST('searchstring' IN BOOLEAN MODE) )
    OR
    ( MATCH(table2.row2) AGAINST('searchstring' IN BOOLEAN MODE) )


SELECT *
FROM table1, table2
WHERE
    ( MATCH(table1.row1, table2.row2) AGAINST('searchstring' IN BOOLEAN MODE) )

我更喜欢第一种方法,因为这使我更容易实现每个领域的排名标准。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-05-22 19:56:08

是的,第二个查询是一个错误。

MATCH()函数的参数必须是定义了一个全文索引的所有列。

但是不能在多个表上定义索引。因此,像MATCH(table1.row1, table2.row2)这样的表达式不能工作,因为它引用来自两个不同表的列。

如果只引用同一表中的列,则可以在一个MATCH()函数中放置多个列。事实上,如果在多个列上定义了全文索引,则这是强制性的。注意,上面我说过,函数的参数必须是全文索引的所有列。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/23813263

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档