dsjhejw3232 2016-10-10 03:49
浏览 12
已采纳

PHP全文搜索的工作原理与否,布尔模式

I would like to ask more info about PHP ?BOOLEAN? fulltext search.

$searchquery=mysqli_query($dbconnect,"select *, MATCH(s.title,s.url, s.keyword, s.`desc`) AGAINST('$q' IN BOOLEAN MODE )  AS score from site s where MATCH(s.title, s.keyword, s.url, s.`desc`) AGAINST('$q' IN BOOLEAN MODE ).

Sample keywords, some China and Arabic and normal Europe

(Arabic works)السيارات
中国的房子 (not working)
Tädiauto (works) Tädid (doesn't work)
all without äõü'ss etc works(english) ()
Someone can explain me this

at the end I set my tables to utf8_general_ci, nothing changed. I use $keywords=htmlspecialchars($keywords, ENT_QUOTES, "UTF-8");

It makes me feel that not all words are searchable words with full text search?


anyways because like (%keyword%) works there is no issue with the database, or is the match() against() a Mysql separate search program that needs something, this seems to be so random search engine. Nobody seems to know this, how Google does it, need to investigate this.

  • 写回答

1条回答 默认 最新

  • duandui2803 2016-10-24 10:45
    关注

    While I was searching a lot, never seen this suggestion, PHP:

    mysqli_set_charset($dbconnect, 'utf8'); mysqli_query($dbconnect, "SET NAMES 'utf8';"); mysqli_query($dbconnect, "SET CHARACTER SET 'utf8';"); mysqli_query($dbconnect, "SET COLLATION_CONNECTION = 'utf8_unicode_ci';");

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 Attention is all you need 的代码运行
  • ¥15 一个服务器已经有一个系统了如果用usb再装一个系统,原来的系统会被覆盖掉吗
  • ¥15 使用esm_msa1_t12_100M_UR50S蛋白质语言模型进行零样本预测时,终端显示出了sequence handled的进度条,但是并不出结果就自动终止回到命令提示行了是怎么回事:
  • ¥15 前置放大电路与功率放大电路相连放大倍数出现问题
  • ¥30 关于<main>标签页面跳转的问题
  • ¥80 部署运行web自动化项目
  • ¥15 腾讯云如何建立同一个项目中物模型之间的联系
  • ¥30 VMware 云桌面水印如何添加
  • ¥15 用ns3仿真出5G核心网网元
  • ¥15 matlab答疑 关于海上风电的爬坡事件检测