使用HandlerSockets时,我可以指定要从查询中接收哪些字段吗?
这是我的示例表
CREATE TABLE pushed_media
(
user_id BINARY(12) NOT NULL,
story_id BINARY(12) NOT NULL,
sent_date TIMESTAMP DEFAULT CURRENT_TIMESTAMP NOT NULL,
PRIMARY KEY ( user_id, story_id )
);
查询它的PHP代码在
下面$hs = new HandlerSocket($host, $port);
if (!($hs->openIndex(1, $dbname, $table, HandlerSocket::PRIMARY, 'user_id,story_id,sent_date')))
{
echo $hs->getError(), PHP_EOL;
die();
}
$user_id = pack('H*', substr(md5('ruslan'), 0, 24));
$story_id = pack('H*', substr(md5('story1'), 0, 24));
$retval = $hs->executeSingle(1, '=', array($user_id, $story_id), 1, 0);
我需要的只是sent_date
,因为我已经知道其他两个值。是否有可能不再通过网络传输它们?
答案 0 :(得分:5)
您只需在openIndex方法的field
参数中指定,即可指定要从查询中接收的字段。
正如您可以阅读here,此代码:
<?php
$hs->openIndex(1, 'db', 'table', 'PRIMARY', 'k,v');
$ret = $hs->executeSingle(1, '>=', array('K1'));
var_dump($ret);
?>
等效于以下SQL语句:
SELECT k,v FROM table WHERE k >= 'K1' LIMIT 1
回到您的示例,如果您只想阅读sent_date
字段值:
$hs = new HandlerSocket($host, $port);
if (!$hs->openIndex(1, $dbname, $table, myHandlerSocket::PRIMARY, 'sent_date')) {
die($hs->getError());
}
$user_id = pack('H*', substr(md5('ruslan'), 0, 24));
$story_id = pack('H*', substr(md5('story1'), 0, 24));
$retval = $hs->executeSingle(1, '=', array($user_id, $story_id), 1, 0);
die("<pre>".print_r($retval,true)."</pre>");
结果输出应该是这样的:
Array
(
[0] => 0
[1] => 1
[2] => 2013-02-01 22:18:39
)
HandlerSocket protocol documentation州:
一旦发出'open_index'请求,HandlerSocket插件就会打开 指定的索引并保持打开状态,直到客户端连接为止 关闭。每个开放索引由&lt; indexid&gt;标识。如果&lt; indexid&gt;是 已经打开,旧的开放指数已经关闭。 您可以打开相同的内容 &lt; dbname&gt;的组合&LT;表名&GT; &LT; INDEXNAME&GT;多次, 可能具有不同的&lt; columns&gt;。为了提高效率,请保持&lt; indexid&gt; 尽可能小。
答案 1 :(得分:0)
executeMulti
怎么样?
$retval = $hs->executeMulti(array(
array(1, '=', array($user_id), 1, 0),
array(2, '=', array($story_id), 1, 0),
));