rickysu / cacheable-behavior-bundle
Provide a propel1 smart cache behavior bundle for symfony 2
v1.0.2
2013-04-08 03:09 UTC
Requires
- php: >=5.3.3
- rickysu/tagcache: >=1.0.0
- symfony/event-dispatcher: >=2.1.0
Suggests
- propel/propel1: 1.6.*
This package is auto-updated.
Last update: 2024-11-14 18:39:46 UTC
README
Introduction
This is a symfony2 bundle for propel1 and provides a smart relation cache.
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.
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
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.
//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.
LICENSE
MIT