[tp3.2.1]查询(2)
<?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)的更多相关文章
- tp3.2 复合查询or
tp3.2 复合查询or $where['goods_name'] = array("like","%$q%");$where['goods_sn'] = ar ...
- Tp3.2 复合查询
我们常常有这样的需求,比如搜索. 搜索出,标题,子标题,内容中包含某某关键字. 这就要and,or结合使用了. $where = ['is_show'=>1,'status'=>1]; / ...
- tp3 联表查询
联表查询D("column") ->field("{$DbPrefix}column.pid,{$DbPrefix}news.*") ->where ...
- [tp3.2.1]sql查询语句(一)
基本查询方式 字符串条件查询, 索引数组条件查询 对象条件查询 SQL语句大小写是一样的,但是,执行的时候有一个小写到大写的转换,所以最好写大写 $condition=new ...
- tp3中子查询 逻辑条件是or
直接用写sql最快 $map['_string'] = 'status=1 AND score>10'; //子查询条件字段不同 $condition['platform'] = 'swap'; ...
- tp3.2博客详情页面查询上一篇下一篇
- Thinkphp 连接数据库、查询、添加
一.连接数据库配置及Model数据模型层 1. Thinkphp\conf\convertion.php中找到数据库设置部分,复制到自己的配置文件中,并添加好有关数据库的内容 JiaoWu\Home\ ...
- TP3.2.3 接入银联支付
TP3.2.3 接入银联支付 项目接入银联支付的过程, 在此记录下,希望能帮助开发盆友平坑. 银联SKD链接:https://open.unionpay.com/ajweb/product/newPr ...
- 6月16 ThinkPHP连接数据库及Model数据模型层--------查询及数据添加
连接数据库配置及Model数据模型层 convertion.php config.php 1.在config.php做数据库连接配置 2.修改配置 /* 数据库设置 */ 'DB_TYPE' => ...
随机推荐
- golang github.com/go-sql-driver/mysql 遇到的数据库,设置库设计不合理的解决方法
golang github.com/go-sql-driver/mysql 遇到的数据库,设置库设计不合理的解决方法,查询中报了以下这个错 Scan error on column index 2: ...
- MongoDB数据库的简介及安装
一.MongoDB数据库简介 简介 MongoDB是一个高性能,开源,无模式的,基于分布式文件存储的文档型数据库,由C++语言编写,其名称来源取自“humongous”,是一种开源的文档数据库──No ...
- 李洪强漫谈iOS开发[C语言-048]-打印平方表
打印平方表
- 一个资深iOS开发者对于React Native的看法
一个资深iOS开发者对于React Native的看法 当我第一次尝试ReactNative的时候,我觉得这只是网页开发者涉足原生移动应用领域的歪门邪道. 我认为一个js开发者可以使用javasc ...
- 用脚本来简化iOS美术同学的工作
用脚本来简化iOS美术同学的工作 问题 我们知道,在 iOS 开发中,为了使我们的 app 能够同时支持 iPhone 的 Retina 屏幕和普通屏幕,美术同学需要对 UI 设计稿中的每个元素进行 ...
- Apache Jmeter发送post请求
下面用Jmeter发送一个post请求, 对应的js代码如下: $("#register_a").click(function() { var name = $("#un ...
- Hibernate中一对一关联映射/组件映射
Hibernate映射:一对一关联 1.按照外键映射 2.按照主键映射 组件映射 下面以员工账号表和员工档案表(员工账号和档案表之间是一对一的关系)为例,介绍这两种映射关系,并使用这两种 映射方式分别 ...
- FZU1894 单调队列
S - 1019 Time Limit:1500MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u Submit Sta ...
- 关于使用QQ、新浪微博、腾讯微博等第三方登录网站的开发过程(二)
(二).新浪微博登录 1. 首先在新浪微博开放平台注册成为开发者.[http://open.weibo.com/connect] 具体自己填写一些相关信息就OK! 2. 注册成功之后,点击[微连接], ...
- MySQL 5.7贴心参数之binlog_row_image
相信大家都了解mysql binlog的格式,那就是有三种,分别是STATEMENT,MiXED,ROW.各有优劣,具体的请大家自行查阅资料.在MySQL 5.7版本以前,虽然ROW格式有各种各样的好 ...