/fuel-cassandra

Apache Cassandra package for Fuel.

Primary LanguagePHP

fuel-cassandra

Apache Cassandra package for Fuel. It includes a PHP client library for Apache Cassandra : phpcassa as a submodule.

Cassandra

The Apache Cassandra Project develops a highly scalable second-generation distributed database, bringing together Dynamo's fully distributed design and Bigtable's ColumnFamily-based data model.

Quick Start

Add package in your FuelPHP application/website

Get this package in you app

$ cd MYAPP/
$ git submodule add git://github.com/ooXavier/fuel-cassandra.git fuel/packages/cassandra
$ git submodule init
$ git submodule update
$ cd fuel/packages/cassandra/
$ git submodule init
$ git submodule update
$ cd ../../..

Then simply add cassandra to your config.php always_loaded.packages config option.

'always_load'  => array(
    'packages'  => array(
        // ...
    'cassandra',
    ),
    // ...

Set-up your Apache Cassandra server(s) connection

Copy config file model into your application

$ cp fuel/packages/cassandra/config/cassandra.php fuel/app/config/

Edit the file to set-up the connection to your cassandra server installation. Example :

<?php
return array(
    'path' => 'phpcassa',
    'cassandra' => array(
        'default' => array(
            'keyspace'  => 'CineMQstaging1',
            'servers' => array (
                '127.0.0.1:9160',
            )
        )
    ),
);

Usage

Establishing a connection

// Get a an new instance of configured nodes on a defined keyspace
$cass = Cassandra::instance('default');

Creating a Keyspace

// Creating a simple keyspace with replication factor 1
$cass->

Creating a Column Family

// Creating a column family with a single validated column
$cass->

// Create an index on the name
$cass->

Inserting into a Column Family

// Insert with FuelPHP DB Query
$query = DB::insert('users', array('KEY', 'email'))->values(array('toto', 'toto@perdu.com'));
$cass->

Updating a Column Family

// Update
$cass->

Selecting from a Column Family

// Select all
$cass->

// Select just one user by id
$cass->

// Select just one user by indexed column
$cass->

Deleting from a Column Family

// Delete the swarthy bastard Kevin
$cass->