YII 操作数据库的三种方式

作者:袖梨 2022-06-25

Getting data from a database
Most applications today use databases. Be it a small website or a social network, at least some parts are powered by databases. Yii introduces three ways which allow you to work with databases:
Active Record
Query builder
SQL via DAO

 代码如下 复制代码
<?php
class DbController extends Controller
{
    protected function afterAction($action)
    {
        $time = sprintf('%0.5f', Yii::getLogger()->getExecutionTime());
        $memory = round(memory_get_peak_usage()/(1024*1024),2)."MB";
        echo "Time: $time, memory: $memory";
        parent::afterAction($action);
    }
 
    public function actionAr()
    {
        $actors = Actor::model()->findAll(array('with' => 'films',
                'order' => 't.first_name, t.last_name, films.title'));
        echo '
  1. ';

  2.        
foreach($actors as $actor)
        {
            echo '';
            echo $actor->first_name.' '.$actor->last_name;
            echo '
  1. ';

  2.             foreach($actor->films as $film)

  3.             {

  4.                 echo '
  5. ';
                    echo $film->title;
                    echo '
  6. ';

  7.             }

  8.             echo '
';
            echo '';
        }
        echo '';
    }
 
    public function actionQueryBuilder()
    {
        $rows = Yii::app()->db->createCommand()
                ->from('actor')
                ->join('film_actor', 'actor.actor_id=film_actor.actor_id')
                ->leftJoin('film', 'film.film_id=film_actor.film_id')
                ->order('actor.first_name, actor.last_name, film.title')
                ->queryAll();
        $this->renderRows($rows);
    }
 
    public function actionSql()
    {
        $sql = "SELECT * FROM actor a
             JOIN film_actor fa ON fa.actor_id = a.actor_id
             JOIN film f ON fa.film_id = f.film_id
             ORDER BY a.first_name, a.last_name, f.title";
        $rows = Yii::app()->db->createCommand($sql)->queryAll();
        $this->renderRows($rows);
    }
 
    public function renderRows($rows)
    {
        $lastActorName = null;
        echo '
  1. ';

  2.         foreach($rows as $row)

  3.         {

  4.             $actorName = $row['first_name'].' '.$row['last_name'];

  5.             if($actorName!=$lastActorName){

  6.                 if($lastActorName!==null){

  7.                     echo '
';
                    echo '';
                }
                $lastActorName = $actorName;
                echo '';
                echo $actorName;
                echo '
  1. ';

  2.             }

  3.             echo '
  4. ';
                echo $row['title'];
                echo '
  5. ';

  6.         }

  7.         echo '
';
    }
}

相关文章

精彩推荐