- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在问这个问题之前,了解我实际上在做什么很重要。
与我正在实现的功能相比,最好的比较是 Facebook 的搜索功能。当您开始输入时,会出现一个包含各种搜索结果的下拉列表。在顶部,您会找到名字与您的搜索匹配的 friend ,然后是其他匹配的人,然后是页面、事件等....
我的情况类似,但我只想搜索两件事。用户和文档(在下面的代码中命名为涟漪)。
我有这个工作正常。在我讨论我的案例中此功能的逻辑时,请耐心等待:
同时,每次按键都会向下面的脚本发出 ajax 请求,该脚本执行以下操作:
最后,所有返回的结果都会附加到自动完成列表中。
这是执行 sphinx 查找并从数据库中获取数据的 PHP 函数示例。
public function search() { $this->disableLayout(); $request = new Request(); $params = $request->getParams(GET); //Perform sphinx textsearch
include('/usr/local/lib/php/sphinxapi.php');
$sphinx = new \SphinxClient();
$sphinx->setMatchMode(SPH_MATCH_ANY);
$sphinx->SetLimits(0, 4);
$mysqlconn = mysql_connect("127.0.0.1:9306") or die ("Couldn't connect to MySQL.");
$users = $sphinx->Query($params['data']['q'], "users");
$ripples = $sphinx->Query($params['data']['q'], "ripples");
/*
*USERS
*/
//Loop through users and only collect ID's that are not already present
if (!empty($users["matches"])) {
$ids = "";
foreach($users['matches'] as $id => $data) {
if($ids > ""){
$ids .= ",";
}
if(!isset($params['data']['e'][$id])){
$ids .= $id;
}
}
//If there any any remaining ID's collect the data from the database and return as JSON
if(!empty($ids)){
$userdataquery = "select users.userid, users.firstname, users.lastname
from tellycards_user_data users
where userid IN($ids)
";
$query = new Query($userdataquery);
$usersoutput = $query->fetchAll();
}
}
/*
*RIPPLES
*/
//Loop through ripples and collect ID's
if (!empty($ripples["matches"])) {
$rippleids = "";
foreach($ripples['matches'] as $id => $data) {
if($rippleids > ""){
$rippleids .= ",";
}
$rippleids .= $id;
}
//If there any any remaining ID's collect the data from the database and return as JSON
if(!empty($rippleids)){
$rippledataquery = "select ripples.id, ripples.name, ripples.screenshot
from tellycards_ripples ripples
where id IN($rippleids)
";
$query = new Query($rippledataquery);
$ripplesoutput = $query->fetchAll();
}
}
header('Content-type: text/json');
echo json_encode(array(
'users' => (!empty($usersoutput)) ? $usersoutput : null,
'ripples' => (!empty($ripplesoutput)) ? $ripplesoutput : null
));
您可能会问为什么我们要进行初始好友查找而不是对所有内容都使用 sphinx。那么通过执行上面的方法。由于在客户端存储了 friend 数组,因此用户在键入时会得到即时反馈,尽管 sphinx 的速度非常快,但由于 http 请求,不可避免地会出现一些延迟。在实践中,它的效果非常好,顺便说一下,它似乎也是 facebook 使用的方法。
还有很多 javascript 代码可以防止不必要的查找,返回的数据被添加到缓存堆等,以便将来的搜索不需要点击 sphinx/db 等......
现在终于到了我的实际问题....
当前的服务器端功能让我很困扰。现在有两个搜索由 Sphinx 执行,两个搜索由 MySQL 执行。我怎么可能将所有这些整理成一个 sphinx 查询和一个 MySQL 查询?有什么办法吗? (请记住,文档和用户可能共享相同的 PK ID,因为它们位于 MySQL 中的两个完全不同的表中,并且(当前)分布在两个单独的索引中)。或者有什么方法可以组合这两个 MySQL 查询,使它们比有两个单独的选择更有效?
或者……由于查询的简单性,我最好像上面那样将它们分开吗? (都是索引主键查询)
我想我要的是任何建议/建议。
非常欢迎任何评论。
最佳答案
如果没有两个 MySQL 查询,你真的无法逃脱。好吧,您可以通过使用 UNION 将它们合并为一个。或者通过创建一个新的组合“表”( View 或物化 View )——但真的不认为它值得付出努力。两个查询非常好-正如您所说的那样,它们已编入索引。
您可以使用一个 sphinx 索引(以及一个搜索查询)- 通过创建一个新的组合索引。因为你说你的 key 不是唯一的,所以必须创建一个新的合成 key 。
例如...
sql_query = SELECT userid*2 AS id, 1 AS table_id, firstname AS one, lastname as two FROM tellycards_user_data \
UNION \
SELECT (id*2)+1 as id, 2 AS table_id, name AS one, screenshot AS two FROM tellycards_ripples
sql_attr_unit = table_id
这为您提供了一个假键,以及一个用于标识结果来自哪个表的属性。您可以使用它来获取它来自的原始表。 (还有许多其他方法可以做同样的事情)
这允许您运行一个查询,可以获得合并的结果。
...但不相信这是个好主意。因为如果结果不对称,您可能会错过结果。假设一个表有 20 个匹配结果,另一个表有 10 个。假设您显示前 10 个结果,现在由于限制,第二个表的结果很可能隐藏在第一个表的下面(极端示例,实际上,希望它们混合在一起)。两个单独的查询,允许您保证从每个表中获得一些结果。
...毕竟如此。坚持你得到的。没关系。
关于php - 使用 Sphinx/MySQL 一次从两个表中获取数据有更好的方法吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12857931/
我在网上搜索但没有找到任何合适的文章解释如何使用 javascript 使用 WCF 服务,尤其是 WebScriptEndpoint。 任何人都可以对此给出任何指导吗? 谢谢 最佳答案 这是一篇关于
我正在编写一个将运行 Linux 命令的 C 程序,例如: cat/etc/passwd | grep 列表 |剪切-c 1-5 我没有任何结果 *这里 parent 等待第一个 child (chi
所以我正在尝试处理文件上传,然后将该文件作为二进制文件存储到数据库中。在我存储它之后,我尝试在给定的 URL 上提供文件。我似乎找不到适合这里的方法。我需要使用数据库,因为我使用 Google 应用引
我正在尝试制作一个宏,将下面的公式添加到单元格中,然后将其拖到整个列中并在 H 列中复制相同的公式 我想在 F 和 H 列中输入公式的数据 Range("F1").formula = "=IF(ISE
问题类似于this one ,但我想使用 OperatorPrecedenceParser 解析带有函数应用程序的表达式在 FParsec . 这是我的 AST: type Expression =
我想通过使用 sequelize 和 node.js 将这个查询更改为代码取决于在哪里 select COUNT(gender) as genderCount from customers where
我正在使用GNU bash,版本5.0.3(1)-发行版(x86_64-pc-linux-gnu),我想知道为什么简单的赋值语句会出现语法错误: #/bin/bash var1=/tmp
这里,为什么我的代码在 IE 中不起作用。我的代码适用于所有浏览器。没有问题。但是当我在 IE 上运行我的项目时,它发现错误。 而且我的 jquery 类和 insertadjacentHTMl 也不
我正在尝试更改标签的innerHTML。我无权访问该表单,因此无法编辑 HTML。标签具有的唯一标识符是“for”属性。 这是输入和标签的结构:
我有一个页面,我可以在其中返回用户帖子,可以使用一些 jquery 代码对这些帖子进行即时评论,在发布新评论后,我在帖子下插入新评论以及删除 按钮。问题是 Delete 按钮在新插入的元素上不起作用,
我有一个大约有 20 列的“管道分隔”文件。我只想使用 sha1sum 散列第一列,它是一个数字,如帐号,并按原样返回其余列。 使用 awk 或 sed 执行此操作的最佳方法是什么? Accounti
我需要将以下内容插入到我的表中...我的用户表有五列 id、用户名、密码、名称、条目。 (我还没有提交任何东西到条目中,我稍后会使用 php 来做)但由于某种原因我不断收到这个错误:#1054 - U
所以我试图有一个输入字段,我可以在其中输入任何字符,但然后将输入的值小写,删除任何非字母数字字符,留下“。”而不是空格。 例如,如果我输入: 地球的 70% 是水,-!*#$^^ & 30% 土地 输
我正在尝试做一些我认为非常简单的事情,但出于某种原因我没有得到想要的结果?我是 javascript 的新手,但对 java 有经验,所以我相信我没有使用某种正确的规则。 这是一个获取输入值、检查选择
我想使用 angularjs 从 mysql 数据库加载数据。 这就是应用程序的工作原理;用户登录,他们的用户名存储在 cookie 中。该用户名显示在主页上 我想获取这个值并通过 angularjs
我正在使用 autoLayout,我想在 UITableViewCell 上放置一个 UIlabel,它应该始终位于单元格的右侧和右侧的中心。 这就是我想要实现的目标 所以在这里你可以看到我正在谈论的
我需要与 MySql 等效的 elasticsearch 查询。我的 sql 查询: SELECT DISTINCT t.product_id AS id FROM tbl_sup_price t
我正在实现代码以使用 JSON。 func setup() { if let flickrURL = NSURL(string: "https://api.flickr.com/
我尝试使用for循环声明变量,然后测试cols和rols是否相同。如果是,它将运行递归函数。但是,我在 javascript 中执行 do 时遇到问题。有人可以帮忙吗? 现在,在比较 col.1 和
我举了一个我正在处理的问题的简短示例。 HTML代码: 1 2 3 CSS 代码: .BB a:hover{ color: #000; } .BB > li:after {
我是一名优秀的程序员,十分优秀!