<?php
namespace Home\Controller;
use Think\Controller;
use Think\Model;
class QueryController extends Controller{
    //快捷查询 - 是一种多字段查询的简化写法,
    //多个字段之间用‘|’隔开表示OR
    //用‘&’隔开表示AND
    
    public function Query1(){
        echo '<meta http-equiv="Content-type" content="text/html;charset=UTF-8"/>';
        //不同字段  的 相同查询        
        $usr=M('User');
        //$map['user|email']='樱桃小丸子';
        $map['user&email']='樱桃小丸子';
        echo "<pre>";
        var_dump($usr->where($map)->select());
    }
    
    public function Query2(){
        echo '<meta http-equiv="Content-type" content="text/html;charset=UTF-8"/>';
        //不同字段  的 不同查询        
    
        $usr=M('User');
        $map['id&user']=array(1,'柯南','_multi'=>TRUE);
        //设置'_multi'为true,是为了让id对应1,让user对应“柯南”,否则
        //会出现id对应了1,还要对应“柯南”的情况,而且,这设置要放在数组最后
    
        echo "<pre>";
        var_dump($usr->where($map)->select());
    }
    
    public function Query3(){
        echo '<meta http-equiv="Content-type" content="text/html;charset=UTF-8"/>';
        // 结合表达式的 快捷查询    
    
        $usr=M('User');
        
        //$map['id&user']=array(1,'柯南','_multi'=>TRUE);
        //设置'_multi'为true,是为了让id对应1,让user对应“柯南”,否则
        //会出现id对应了1,还要对应“柯南”的情况,而且,这设置要放在数组最后
    
        $map['id&user']=array(array('gt',1),'樱桃小丸子','_multi'=>true);
    
        echo "<pre>";
        var_dump($usr->where($map)->select());
    }
    public function Query4(){
        echo '<meta http-equiv="Content-type" content="text/html;charset=UTF-8"/>';
        
        //区间查询
        //比如 id>1 and id<3
        //或者 id>1 or id<3
        
        $user=M("User");
        $map['id']=array(array('gt',1),array('lt',3));//注意没有等于
        
        echo "<pre>";
        var_dump($user->where($map)->select());
        
        $map['id']=array(array('lt',1),array('gt',3),'or');
        echo "<pre>";
        var_dump($user->where($map)->select());
    }
    
    //组合查询  -  基于索引数组查询方式的扩展性查询,
    //            可以添加字符串查询(_string)、复合查询(_complex)、请求字符串查询(_query)
    //由于采用的是索引数组,重复的会被覆盖
    public function Query5(){
        echo '<meta http-equiv="Content-type" content="text/html;charset=UTF-8"/>';
        
        $user=M('User');
        
        $map['id']=array('eq',1);
        $map['_string']='user="柯南" AND email="kenan0210@sian.com"';
        // $map['_logic']='OR';
        
        echo "<pre>";
        var_dump($user->where($map)->select());
    }
    
    public function Query6(){
        echo '<meta http-equiv="Content-type" content="text/html;charset=UTF-8"/>';
        
        $user=M('User');
        
        $map['id']=array('gt',1);
        //请求字符串 查询 - 这是URL方式,不需要加引号
        $map['_query']='user=樱桃小丸子&email=labixiaoxin001@google.com&_logic=OR';
        //推荐使用,因为字段名有``护起来
        
        echo "<pre>";
        var_dump($user->where($map)->select());
    }
    
    public function Query7(){
        echo '<meta http-equiv="Content-type" content="text/html;charset=UTF-8"/>';
        
        $user=M('User');
        
        $where['user']=array('like','%小%');
        $where['id']=1;
        $where['_logic']='OR';
        $map['_complex']=$where;
        $map['id']=3;
        $map['_logic']='OR';
        
        echo "<pre>";
        var_dump($user->where($map)->select());
    }
    
    //统计  查询
    public function TjQuery(){
        $user=M('User');
        var_dump($user->count());//统计记录总数
        var_dump($user->count('email'));//统计字段email总数,遇到null跳过
        echo "<br />";
        var_dump($user->max('id'));
        var_dump($user->min('id'));
        var_dump($user->avg('id'));
        var_dump($user->sum('id'));
    }    
    
    // 动态查询
    // 借助 PHP5 语言特性,ThinkPHP实现动态查询
    public function Query_getby(){
        //getBy动态查询 //注意找到多个时,只返回一个
        $user=M('User');
        var_dump($user->getByEmail('kswyl_da@gmail.com'));
        var_dump($user->getByUser('旗木卡卡西'));
        var_dump($user->getByUser(array('LIKE','%小%')));
    }    
    
    //getFieldBy查询
    public function Query_getfieldby(){
        $user=M('User');
        //var_dump($user->getFieldByUser('旗木卡卡西','id'));
        var_dump($user->getFieldByUser('旗木卡卡西',array('id','email')));
        //注意,即使想这样想返回多个字段的结果,也会只返回一个(id的 值)
    }
    
    //SQL原生查询
    
    public function Query_read(){
        //ThinkPHP支持原生SQL query读取
        $user=M('User');
        echo "<pre>";
        var_dump($user->query('SELECT * FROM think_user'));
        
    }
    
    //execute写入
    public  function Execute_write(){
        $user=M('User');
        var_dump($user->execute('UPDATE think_user SET user="蜡笔大新" WHERE id=1'));
    }
    
    
} ?>

[tp3.2.1]查询(2)的更多相关文章

  1. tp3.2 复合查询or

    tp3.2 复合查询or $where['goods_name'] = array("like","%$q%");$where['goods_sn'] = ar ...

  2. Tp3.2 复合查询

    我们常常有这样的需求,比如搜索. 搜索出,标题,子标题,内容中包含某某关键字. 这就要and,or结合使用了. $where = ['is_show'=>1,'status'=>1]; / ...

  3. tp3 联表查询

    联表查询D("column") ->field("{$DbPrefix}column.pid,{$DbPrefix}news.*") ->where ...

  4. [tp3.2.1]sql查询语句(一)

    基本查询方式    字符串条件查询,    索引数组条件查询    对象条件查询    SQL语句大小写是一样的,但是,执行的时候有一个小写到大写的转换,所以最好写大写 $condition=new ...

  5. tp3中子查询 逻辑条件是or

    直接用写sql最快 $map['_string'] = 'status=1 AND score>10'; //子查询条件字段不同 $condition['platform'] = 'swap'; ...

  6. tp3.2博客详情页面查询上一篇下一篇

  7. Thinkphp 连接数据库、查询、添加

    一.连接数据库配置及Model数据模型层 1. Thinkphp\conf\convertion.php中找到数据库设置部分,复制到自己的配置文件中,并添加好有关数据库的内容 JiaoWu\Home\ ...

  8. TP3.2.3 接入银联支付

    TP3.2.3 接入银联支付 项目接入银联支付的过程, 在此记录下,希望能帮助开发盆友平坑. 银联SKD链接:https://open.unionpay.com/ajweb/product/newPr ...

  9. 6月16 ThinkPHP连接数据库及Model数据模型层--------查询及数据添加

    连接数据库配置及Model数据模型层 convertion.php config.php 1.在config.php做数据库连接配置 2.修改配置 /* 数据库设置 */ 'DB_TYPE' => ...

随机推荐

  1. LVS DR脚本 解析

    vip.sh #!/bin/bash 192.168.2.240 broadcast 192.168.2.240 netmask 255.255.255.255 up route add -host ...

  2. winform窗体最大化、最小化、还原

    //最大化 private void button_maxsize_Click(object sender, EventArgs e)        {            this.WindowS ...

  3. Base64编码简介

      基本概念   Base64这个术语最初是在“MIME内容传输编码规范”中提出的.Base64不是一种加密算法,虽然编码后的字符串看起来有点加密的赶脚.它实际上是一种“二进制到文本”的编码方法,它能 ...

  4. 除法 Division

    除法 题目链接:http://acm.hust.edu.cn/vjudge/contest/view.action?cid=84562#problem/A 题意: 输入正整数n按从小到大的顺序输出所有 ...

  5. web前端开发CSS命名规范参考

    做为一个web前端工程师,每天接触HTML.css就像吃饭一样,但是作为一名合作.优秀的web前端工程师,对DIV+CSS命名还是有一定的规范的,本文整理了一份web前端开发中DIV+CSS各种命名规 ...

  6. SQL Server 数据库新建用户

    1.在[安全性]中的[登录名]右键创建登陆用户 2. 输入相关信息 3. 然后去相应的数据库下[安全性]中右键添加用户 4.选择刚刚创建的用户名 5. 选择[默认架构]为 owner 6. 对[拥有的 ...

  7. nyoj-204

    描述国王有一个魔镜,可以把任何接触镜面的东西变成原来的两倍——只是,因为是镜子嘛,增加的那部分是反的. 比如一条项链,我们用AB来表示,不同的字母表示不同颜色的珍珠.如果把B端接触镜面的话,魔镜会把这 ...

  8. 西部数据出现“WD SES Device USB Device”怎么办,而且说明书全是英文。

    您好.wd ses device driver这个驱动程序可以在baidu中输入关键词找到,什么驱动之家.驱动人生之类的专业驱动网站也都是有的. western digital的移动硬盘驱动程序安装步 ...

  9. 新一波makefile

    # CROSS_COMPILE = arm-linux-CC = $(CROSS_COMPILE)gccINC=-I../ -I.LIB=-lpthread -lcryptoCC_FLAG= -std ...

  10. 【iCore3 双核心板_FPGA】实验二十三:使用JTAG UART终端打印信息

    实验指导书及代码包下载: http://pan.baidu.com/s/1c83OPC iCore3 购买链接: https://item.taobao.com/item.htm?id=5242294 ...