2017 © Pedro Peláez
 

library cacheable-behavior-bundle

Provide a propel1 smart cache behavior bundle for symfony 2

image

rickysu/cacheable-behavior-bundle

Provide a propel1 smart cache behavior bundle for symfony 2

  • Monday, April 8, 2013
  • by rickysu
  • Repository
  • 1 Watchers
  • 4 Stars
  • 33 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 0 Forks
  • 0 Open issues
  • 4 Versions
  • 0 % Grown

The README.md

Propel Cacheable Behavior Bundle

Build Status, (*1)

Introduction

This is a symfony2 bundle for propel1 and provides a smart relation cache., (*2)

Features

  • primary key and unique index query cache.
  • one to one relation cache.
  • one to many relation cache.
  • many to many relation cache.
  • auto detect single or composite key.

Requirements

  • PHP 5.3.3 above
  • rickysu/tagcache 0.1 above

Installation

editing the composer.json file in the root project., (*3)

Editing the composer.json under require: {} section add

"rickysu/cacheable-behavior-bundle": "0.1.*",

Install Bundle With Composer :

php composer.phar install

How to Use

setup config

app/config.yml, (*4)

propel:
    path:       "%kernel.root_dir%/../vendor/propel"
    phing_path: "%kernel.root_dir%/../vendor/phing"
    logging:    %kernel.debug%
    dbal:
        driver:               %database_driver%
        user:                 %database_user%
        password:             %database_password%
        dsn:                  %database_driver%:host=%database_host%;dbname=%database_name%;charset=UTF8
    behaviors:
        cacheable:           RickySu\CacheableBehaviorBundle\Behavior\CacheableBehavior

add cacheable behavior in your schema.xml

retrieve data with primary key or unique index

<?xml version="1.0" encoding="UTF-8"?>
<database name="myorm" defaultIdMethod="native" namespace="ORM\StoreBundle\Model">
    <table name="member">
        <behavior name="cacheable" />
        <column name="id" type="bigint" primaryKey="true" autoIncrement="true" required="true"/>
        <column name="username" type="varchar" size="45" />
        <column name="email" type="varchar" size="80" />
        <unique>
            <unique-column name="username" />
            <unique-column name="email" />
        </unique>
    </table>
// filter by id =1 and build cache
$Member=MemberPeer::retrieveByPk(1);
$Member=MemberQuery::create()->findPk(1);

//filter by username , email and build cache
$Member=MemberPeer::retrieveByUsernameEmail('username','somebody@foo.com');
$Member=MemberQuery::create()
  ->filterByUsername('username')
  ->filterByEmail('somebody@foo.com')
  ->findOne();

//delete cache when save or delete
$Member->save();
$Member->delete();

retrieve data with one to one relation

<?xml version="1.0" encoding="UTF-8"?>
<database name="myorm" defaultIdMethod="native" namespace="ORM\StoreBundle\Model">
    <table name="member">
        <behavior name="cacheable" />
        <column name="id" type="bigint" primaryKey="true" autoIncrement="true" required="true"/>
        <column name="username" type="varchar" size="45" />
        <column name="email" type="varchar" size="80" />
    </table>
    <table name="member_info">
        <behavior name="cacheable" />
        <column name="member_id" type="bigint" primaryKey="true" required="true"/>
        <column name="realname" type="varchar" size="45" />
        <foreign-key foreignTable="member" onDelete="cascade" onUpdate="cascade">
            <reference local="member_id" foreign="id" />
        </foreign-key>
    </table>

retrieve data with one to many relation

<?xml version="1.0" encoding="UTF-8"?>
<database name="myorm" defaultIdMethod="native" namespace="ORM\StoreBundle\Model">
    <table name="category">
        <behavior name="cacheable" />
        <column name="id" type="bigint" primaryKey="true" autoIncrement="true" required="true"/>
        <column name="name" type="varchar" size="45" />
    </table>
    <table name="article">
        <behavior name="cacheable" />
        <column name="id" type="bigint" primaryKey="true" required="true"/>
        <column name="category_id" type="bigint" />
        <column name="title" type="varchar" size="128" />
        <column name="content" type="longvarchar" />
        <foreign-key foreignTable="category" onDelete="cascade" onUpdate="cascade">
            <reference local="category_id" foreign="id" />
        </foreign-key>
    </table>

retrieve data with one to many relation

<?xml version="1.0" encoding="UTF-8"?>
<database name="myorm" defaultIdMethod="native" namespace="ORM\StoreBundle\Model">
    <table name="member">
        <behavior name="cacheable" />
        <column name="id" type="bigint" primaryKey="true" autoIncrement="true" required="true"/>
        <column name="username" type="varchar" size="45" />
    </table>
    <table name="group">
        <behavior name="cacheable" />
        <column name="id" type="bigint" primaryKey="true" required="true"/>
        <column name="groupname" type="varchar" size="45" />
    </table>
    <table name="member_group" isCrossRef="true">
        <behavior name="cacheable" />
        <column name="member_id" type="bigint" primaryKey="true" required="true"/>
        <column name="group_id" type="bigint" primaryKey="true" required="true"/>
        <foreign-key foreignTable="member" onDelete="cascade" onUpdate="cascade">
            <reference local="member_id" foreign="data_id" />
        </foreign-key>
        <foreign-key foreignTable="group" onDelete="cascade" onUpdate="cascade">
            <reference local="group_id" foreign="id" />
        </foreign-key>
    </table>

TODO

clear cache when change relation mapping., (*5)

//set $Article belonds to $Category1
$Article->setCategory($Category1);
$Article->save();

//set $Article belonds to $Category2
$Article->setCategory($Category2);
$Article->save();

//we need to clear $Category1 and $Category2 reference cache.

Note

If your want use this behavior without symfony2 , please folow this demo., (*6)

LICENSE

MIT, (*7)

The Versions

08/04 2013

dev-master

9999999-dev https://github.com/RickySu/cacheable-behavior-bundle

Provide a propel1 smart cache behavior bundle for symfony 2

  Sources   Download

MIT

The Requires

 

by Ricky Su

cache propel rickysu

08/04 2013

v1.0.2

1.0.2.0 https://github.com/RickySu/cacheable-behavior-bundle

Provide a propel1 smart cache behavior bundle for symfony 2

  Sources   Download

MIT

The Requires

 

by Ricky Su

cache propel rickysu

07/12 2012

v1.0.1

1.0.1.0 https://github.com/RickySu/cacheable-behavior-bundle

Provide a propel1 smart cache behavior bundle for symfony 2

  Sources   Download

MIT

The Requires

 

by Ricky Su

cache propel rickysu

26/11 2012

v1.0.0

1.0.0.0 https://github.com/RickySu/cacheable-behavior-bundle

Provide a propel1 smart cache behavior bundle for symfony 2

  Sources   Download

MIT

The Requires

 

by Ricky Su

cache propel rickysu