基础查询

Customer::find()->one();    此方法返回一条数据;

Customer::find()->all();    此方法返回所有数据;

Customer::find()->count();    此方法返回记录的数量;

Customer::find()->average();    此方法返回指定列的平均值;

Customer::find()->min();    此方法返回指定列的最小值 ;

Customer::find()->max();    此方法返回指定列的最大值 ;

Customer::find()->scalar();    此方法返回值的第一行第一列的查询结果;

Customer::find()->column();    此方法返回查询结果中的第一列的值;

Customer::find()->exists();    此方法返回一个值指示是否包含查询结果的数据行;

Customer::find()->batch(10);  每次取10条数据 

Customer::find()->each(10);  每次取10条数据,迭代查询 

//根据sql语句查询:查询name=test的客户
Customer::model()->findAllBySql("select * from customer where name = test");  //根据主键查询:查询主键值为1的数据
Customer::model()->findByPk(1);  //根据条件查询(该方法是根据条件查询一个集合,可以是多个条件,把条件放到数组里面) 
Customer::model()->findAllByAttributes(['username'=>'admin']);  //子查询
$subQuery = (new Query())->select('COUNT(*)')->from('customer');
// SELECT `id`, (SELECT COUNT(*) FROM `customer`) AS `count` FROM `customer`
$query = (new Query())->select(['id', 'count' => $subQuery])->from('customer'); //关联查询:查询客户表(customer)关联订单表(orders),条件是status=1,客户id为1,从查询结果的第5条开始,查询10条数据
$data = (new Query())
    ->select('*')
    ->from('customer')
    ->join('LEFT JOIN','orders','customer.id = orders.customer_id')
    ->where(['status'=>'1','customer.id'=>'1'])
    ->offset(5)
    ->limit(10)
    ->all()

直接查询

  1.  
    //createCommand(执行原生的SQL语句)  
  2.  
    $sql= "SELECT u.account,i.* FROM sys_user as u left join user_info as i on u.id=i.user_id";  
  3.  
    $rows=Yii::$app->db->createCommand($sql)->query();  
  4.  
     
  5.  
    查询返回多行:    
  6.  
    $command = Yii::$app->db->createCommand('SELECT * FROM post');  
  7.  
    $posts = $command->queryAll();
  8.  
     
  9.  
    返回单行
  10.  
    $command = Yii::$app->db->createCommand('SELECT * FROM post WHERE id=1');  
  11.  
    $post = $command->queryOne();
  12.  
      
  13.  
    查询多行单值:  
  14.  
    $command = Yii::$app->db->createCommand('SELECT title FROM post');  
  15.  
    $titles = $command->queryColumn();
  16.  
      
  17.  
    查询标量值/计算值:  
  18.  
    $command = Yii::$app->db->createCommand('SELECT COUNT(*) FROM post');  
  19.  
    $postCount = $command->queryScalar();

关联查询

  1.  
    /**
  2.  
     *客户表Model:CustomerModel 
  3.  
     *订单表Model:OrdersModel
  4.  
     *国家表Model:CountrysModel
  5.  
     *首先要建立表与表之间的关系 
  6.  
     *在CustomerModel中添加与订单的关系
  7.  
     */     
  8.  
    Class CustomerModel extends \yii\db\ActiveRecord
  9.  
    {
  10.  
        ...
  11.  
        //客户和订单是一对多的关系所以用hasMany
  12.  
        //此处OrdersModel在CustomerModel顶部别忘了加对应的命名空间
  13.  
        //id对应的是OrdersModel的id字段,order_id对应CustomerModel的order_id字段
  14.  
        public function getOrders()
  15.  
        {
  16.  
            return $this->hasMany(OrdersModel::className(), ['id'=>'order_id']);
  17.  
        }
  18.  
        
  19.  
        //客户和国家是一对一的关系所以用hasOne
  20.  
        public function getCountry()
  21.  
        {
  22.  
            return $this->hasOne(CountrysModel::className(), ['id'=>'Country_id']);
  23.  
        }
  24.  
        ....
  25.  
    }
  26.  
          
  27.  
    // 查询客户与他们的订单和国家
  28.  
    CustomerModel::find()->with('orders', 'country')->all();
  29.  
     
  30.  
    // 查询客户与他们的订单和订单的发货地址(注:orders 与 address都是关联关系)
  31.  
    CustomerModel::find()->with('orders.address')->all();
  32.  
     
  33.  
    // 查询客户与他们的国家和状态为1的订单
  34.  
    CustomerModel::find()->with([
  35.  
        'orders' => function ($query) {
  36.  
            $query->andWhere('status = 1');
  37.  
            },
  38.  
            'country',
  39.  
    ])->all();

YII 框架查询的更多相关文章

  1. 三级联动(在YII框架中)

    //三级联动 //数据库代码过多就不上传了 //视图 <div class="area">    <table class="table"&g ...

  2. Yii框架 多表查询实例

    Yii框架多表查询实例:总共分为两个步骤(以下的代码我全部都写在model中):1.先在主表model中声明关联表中所需要查询的字段. public $surveyls_description; // ...

  3. 使用 OAuth2-Server-php 在 Yii 框架上搭建 OAuth2 Server

    原文转自 http://www.cnblogs.com/ldms/p/4565547.html Yii 有很多 extension 可以使用,在查看了 Yii 官网上提供的与 OAuth 相关的扩展后 ...

  4. Yii 框架学习--01 框架入门

    Yii 是一个高性能的,适用于开发 WEB2.0 应用的 PHP 框架. Yii目前有两个主要的版本: 2.0 和 1.1.本文以YII 2.0.7为例. 环境需求 Yii2.0 框架有一些系统上的需 ...

  5. php--yii框架中的ajax分页与yii框架自带的分页

    要想使用Yii分页类 第一步:在控制器层加载分页类 use yii\data\Pagination; 第二步: 使用model层查询数据,并用分分页,限制每页的显示条数 $data = Zhao::f ...

  6. yii框架

    Yii Framework是一个基于组件.用于开发大型 Web 应用的高性能 PHP 框架.Yii提供了今日Web 2.0应用开发所需要的几乎一切功能.Yii是最有效率的PHP框架之一.Yii是创始人 ...

  7. YII框架源码分析(百度PHP大牛创作-原版-无广告无水印)

           YII 框架源码分析    百度联盟事业部——黄银锋 目 录 1. 引言 3 1.1.Yii 简介 3 1.2.本文内容与结构 3 2.组件化与模块化 4 2.1.框架加载和运行流程 4 ...

  8. Yii框架tips(转)

    yii的一些小的技巧 http://www.yiichina.com/topic/151 db组件 'schemaCachingDuration'=>3600, 为什么不起做用?需要开缓存 如何 ...

  9. Yii框架tips

    db组件 'schemaCachingDuration'=>3600, 为什么不起做用?需要开缓存 如何在页面下边显示sql的查询时间在log组件的routes中加入 array('class' ...

随机推荐

  1. OSG学习:矩阵变换节点示例

    #include<osgViewer\Viewer> #include<osg\Node> #include<osg\Geode> #include<osg\ ...

  2. phpcms找不到模板、空白模板的解决办法

    有时候会出现这个问题,尤其是在调试模板的过程中,不知道别的朋友的操作习惯.我的习惯是,先保留一份原始的模板.比如: index原版.html. 以便对比之用.但是呢,这样,往往会造成 找不到模板的情况 ...

  3. GetTickCount 和getTickCount

    GetTickCount:正常读取时间函数 getTickCount:不知道是什么鬼东东函数 都包含在windows.h中..运行出的结果天壤之别~~~

  4. Redis集群分布(Windows版)

    Redis系列 作者Mr.Chen,转载请注明博客出处:http://www.cnblogs.com/cjh-notes/ 第一步:下载安装redis windows版的下载地址:https://gi ...

  5. 【bzoj4641】基因改造 特殊匹配条件的KMP

    题目描述 如果两个长度相等的字符串,如果存在一种字符的一一映射,使得第一个字符串的所有字符经过映射后与第二个字符串相同,那么就称它们“匹配”.现在给出两个串,求第一个字符串所有长度等于第二个字符串的长 ...

  6. CSS-posiziton

    1. 想要实现,”返回顶部”永远位于页面的右下角.需要用到position函数.CSS:层叠样式表.用到了分层的功能. position:fixed;  永远固定在一个地方. <!DOCTYPE ...

  7. 深入理解Delete(JavaScript)

    深入理解Delete(JavaScript) Delete  众所周知是删除对象中的属性. 但如果不深入了解delete的真正使用在项目中会出现非常严重的问题 (: Following 是翻译  ka ...

  8. 【刷题】BZOJ 1143 [CTSC2008]祭祀river

    Description 在遥远的东方,有一个神秘的民族,自称Y族.他们世代居住在水面上,奉龙王为神.每逢重大庆典, Y族都会在水面上举办盛大的祭祀活动.我们可以把Y族居住地水系看成一个由岔口和河道组成 ...

  9. [luogu5176] 公约数

    题目描述 求 \[ \sum_{i=1}^n\sum_{j=1}^m\sum_{k=1}^p\gcd(i\cdot j,i\cdot k,j\cdot k)\times \gcd(i,j,k)\tim ...

  10. ocker nginx 配置反向代理和负载均衡

    1. 获取及配置nginx 如果需要全站通过docker部署,那么nginx或许是不可或缺的.通过配置nginx,可以迅速实现负载均衡和反向代理服务.值得一提的是,docker官网恰好也有nginx镜 ...