锘??xml version="1.0" encoding="utf-8" standalone="yes"?>亚洲国产精品碰碰,亚洲国产日韩成人综合天堂,亚洲无线电影官网http://www.tkk7.com/programmer/category/27883.htmlzh-cnFri, 07 Dec 2007 06:21:09 GMTFri, 07 Dec 2007 06:21:09 GMT60How To: Using symfony to add a join between tableshttp://www.tkk7.com/programmer/archive/2007/12/05/165599.htmlwadewadeWed, 05 Dec 2007 09:26:00 GMThttp://www.tkk7.com/programmer/archive/2007/12/05/165599.htmlhttp://www.tkk7.com/programmer/comments/165599.htmlhttp://www.tkk7.com/programmer/archive/2007/12/05/165599.html#Feedback0http://www.tkk7.com/programmer/comments/commentRss/165599.htmlhttp://www.tkk7.com/programmer/services/trackbacks/165599.html1. simple join two tables

purpose:
generate sql like:   

select * from photo p
    left join artist a on p.artist_id = a.artist_id
      where a.genre = 'something' and p.genre = 'something'

code:           

if(!CriteriaUtil::hasJoin($criteria, ArtistPeer::TABLE_NAME)){
    $criteria->addJoin(PhotoPeer::ARTIST_ID, ArtistPeer::ARTIST_ID, Criteria::LEFT_JOIN);
}
$criteria->add(ArtistPeer::GENRE, $genre);    
$criteria->add(PhotoPeer::GENRE, $genre);

2. join two tables, add AND OR between conditions
purpose:
generate sql like:    

select * from photo p
    left join artist a on p.artist_id = a.artist_id
      where (a.genre = 'some' or p.genre='something')
        and a.name = 'something'

code:   

if(!CriteriaUtil::hasJoin($criteria, ArtistPeer::TABLE_NAME)){
   $criteria->addJoin(PhotoPeer::ARTIST_ID, ArtistPeer::ARTIST_ID, Criteria::LEFT_JOIN);
}
$criteria->add(ArtistPeer::GENRE, $genre);
$c = $criteria->getCriterion(ArtistPeer::GENRE);
if($c != null){
   $c->addOr($criteria->getNewCriterion(PhotoPeer::GENRE, $genre));
}
$criteria->add(ArtistPeer::NAME, $name);

 

Note:
It's a good habit to check if we have joined the table already. to check this, you can use the following util class, it get all the joined tables, and check if the table exists in them.

class CriteriaUtil{
    public static function hasJoin($c, $table_name){
        $joins = $c->getJoins();
        if($joins != null){
            foreach($joins as $join){
                if($join->getRightTableName() == $table_name){
                    return true;
                }
                if($join->getLeftTableName() == $table_name){
                    return true;
                }
            }
        }
        return false;
    }
}


wade 2007-12-05 17:26 鍙戣〃璇勮
]]>
How To: Clear cache for symfonyhttp://www.tkk7.com/programmer/archive/2007/11/13/165571.htmlwadewadeTue, 13 Nov 2007 09:23:00 GMThttp://www.tkk7.com/programmer/archive/2007/11/13/165571.htmlhttp://www.tkk7.com/programmer/comments/165571.htmlhttp://www.tkk7.com/programmer/archive/2007/11/13/165571.html#Feedback0http://www.tkk7.com/programmer/comments/commentRss/165571.htmlhttp://www.tkk7.com/programmer/services/trackbacks/165571.htmlOriginal article: http://www.symfony-project.com/book/1_0/18-Performance

Clearing Selective Parts of the Cache

During application development, you have to clear the cache in various situations:

  • When you create a new class: Adding a class to an autoloading directory (one of the project's lib/ folders) is not enough to have symfony find it automatically. You must clear the autoloading configuration cache so that symfony browses again all the directories of the autoload.yml file and references the location of autoloadable classes--including the new ones.
  • When you change the configuration in production: The configuration is parsed only during the first request in production. Further requests use the cached version instead. So a change in the configuration in the production environment (or any environment where SF_DEBUG is turned off) doesn't take effect until you clear the cached version of the file.
  • When you modify a template in an environment where the template cache is enabled: The valid cached templates are always used instead of existing templates in production, so a template change is ignored until the template cache is cleared or outdated.
  • When you update an application with the sync command: This case usually covers the three previous modifications.

The problem with clearing the whole cache is that the next request will take quite long to process, because the configuration cache needs to be regenerated. Besides, the templates that were not modified will be cleared from the cache as well, losing the benefit of previous requests.

That means it's a good idea to clear only the cache files that really need to be regenerated. Use the options of the clear-cache task to define a subset of cache files to clear, as demonstrated in Listing 18-14.

Listing 18-14 - Clearing Only Selective Parts of the Cache

// Clear only the cache of the myapp application
> symfony clear-cache myapp

// Clear only the HTML cache of the myapp application
> symfony clear-cache myapp template

// Clear only the configuration cache of the myapp application
> symfony clear-cache myapp config

You can also remove files by hand in the cache/ directory, or clear template cache files selectively from the action with the $cacheManager->remove() method, as described inChapter 12

 

Note:

1. We can use $cacheManager->remove() to clear cache after we deployed a new version product.

2. write code to generate models from database, and then call $cacheManager->remove() to clear cache.


 


wade 2007-11-13 17:23 鍙戣〃璇勮
]]>
主站蜘蛛池模板: 免费一级毛片在线观看| 福利免费观看午夜体检区| 亚洲区小说区图片区| 美女羞羞喷液视频免费| 国产精品嫩草影院免费| 黄人成a动漫片免费网站| 国产91在线免费| 一级看片免费视频囗交| 亚洲精品少妇30p| 日韩免费无码一区二区三区| 久久久亚洲精品国产| 最近免费最新高清中文字幕韩国| 日产亚洲一区二区三区| 69堂人成无码免费视频果冻传媒| 国产成人精品日本亚洲11| 在线免费观看韩国a视频| 一区二区三区在线免费| 亚洲av无码成h人动漫无遮挡| 三年片在线观看免费大全电影| 亚洲欧洲中文日产| 成人免费在线观看网站| 免费无遮挡无码视频在线观看| 亚洲一区AV无码少妇电影☆| 99精品视频免费在线观看| 亚洲不卡影院午夜在线观看| 四虎影库久免费视频| 日韩a级无码免费视频| 亚洲国产av高清无码| 国产yw855.c免费视频| 国产成人AV免费观看| 亚洲综合综合在线| 国产真人无遮挡作爱免费视频| 一级做受视频免费是看美女| 亚洲精品人成在线观看| 日韩一区二区免费视频| 国内少妇偷人精品视频免费| 亚洲中文字幕久久精品无码2021| 免费在线视频一区| 中国人xxxxx69免费视频| 另类小说亚洲色图| 亚洲福利视频一区二区三区|