1

phpcassaのbatch_mutate()関数の例を教えてください。

この関数の操作方法を理解できず、十分な情報が見つかりませんでした。

また、カウンターでの使い方も知りたいです。

前もって感謝します。

4

2 に答える 2

3

「複数のキーからデータを削除」:

function batch_remove($key=null, $columns=null, $super_column=null, $write_consistency_level=null) {

    $timestamp = CassandraUtil::get_time();
    $deletion = new cassandra_Deletion();
    $deletion->timestamp = $timestamp;

    if ($super_column !== null) $deletion->super_column = $this->pack_name($super_column, true);
    else $deletion->super_column = null;

    if ($columns !== null) {
        $predicate = $this->create_slice_predicate($columns, '', '', false, self::DEFAULT_COLUMN_COUNT);
        $deletion->predicate = $predicate;
    }

    $mutation = new cassandra_Mutation();
    $mutation->deletion = $deletion;

    if (is_array($key) && count($key) >= 1) {

        $mut_map = array();
        foreach($key as $v) {
            $packed_key[$v] = $this->pack_key($v);
            $mut_map[$v] = array($this->column_family => array($mutation));
        }

        return $this->pool->call("batch_mutate", $mut_map, $this->wcl($write_consistency_level));

    } else return false;

}

//delete name1, name2, name3 from key1, key2 in a single call
$column_family->batch_remove(array(key1, key2), array(name1, name2, name3));
于 2012-02-02T10:58:51.540 に答える
2
  1. カウンターの batch_mutate は、PHPCassa ではまだ利用できません: https://github.com/thobbs/phpcassa/issues/31
  2. チュートリアルに従って実行中の batch_mutate: http://thobbs.github.com/phpcassa/tutorial.html

「データの挿入」:

 $row1 = array('name1' => 'val1', 'name2' => 'val2');
 $row2 = array('foo' => 'bar');
 $column_family->batch_insert(array('row1' => $row1, 'row2' => $row2);
于 2012-01-12T08:24:22.857 に答える