Thinkphp 整理备忘 杂记
1:输出变量函数 (手册目录:控制器-输出变量)
I('变量类型.变量名',['默认值'],['过滤方法'],['额外数据源'])
例:$title = I('post.title','','strip_tags');
2:判断是否是POST方式提交 (手册目录:控制器-请求类型)
(手册目录:附录-常亮参考)
IS_POST 是系统常亮,判断当前是否POST请求
例如: if (IS_POST){ ………… }
3: 分页
$User = M('User'); // 实例化User对象
$count = $User->where('status=1')->count();// 查询满足要求的总记录数
$Page = new \Think\Page($count,25);// 实例化分页类 传入总记录数和每页显示的记录数(25)
$show = $Page->show();// 分页显示输出
// 进行分页数据查询 注意limit方法的参数要使用Page类的属性
$list = $User->where('status=1')->order('create_time')->limit($Page->firstRow.','.$Page->listRows)->select();
$this->assign('list',$list);// 赋值数据集
$this->assign('page',$show);// 赋值分页输出
$this->display(); // 输出模板
4:Thinkphp使用多个_string
下面这一种情况,出现两个_string,第一个string会把第二个给覆盖掉
$map["a"]=1;
$map["_string"]="条件1 or 条件2";
$map["_string"]="条件3";
解决办法:
$map["a"]=1;
$map["_string"]=" ( 条件1 or 条件2 ) ";
$map["_string"] . =" and 条件3";
生成的sql语句为:where a=1 AND ( (条件1 OR 条件2) and 条件3 )
5:大小写引起的错误
1- 读取配置 C('参数名称'),‘参数名称’的定义和调用时,最好都统一大写。
6:加载公共模块的service
$service = new \Common\Service\xxxxx();
7:CURD返回值
http://www.baiwar.com/post/thinkphp-database-operations-in-the-return-value.html
http://doc.thinkphp.cn/manual/curd.html
①、save()方法:
返回值是影响的记录数,如果返回false则表示更新出错,因此一定要用恒等来判断是否更新失败。
$result=$model->save();
if ($result === FALSE) {
echo '修改失败';
} elseif($result === ) {
echo '未作任何修改';
} else {
echo '修改成功';
}
②、Count 、Max、Min 、Avg 、Sum返回值
如果查询出错,返回值为false
查询成功,则返回对应的值。(如0、1、2)
③、find方法:
如果查询出错返回:false,
查询结果为空返回:NULL
查询成功则返回一个关联数组(键值是字段名或者别名)。
④、add()方法:
如果数据非法或者查询错误则返回false
如果是自增主键 则返回主键值,否则返回1
8:使用GROUP BY的时候如何统计记录条数 COUNT(*) DISTINCT
M(“bus”)->where($where_ybj)->group('ordert')->count("DISTINCT orderid");
9:日志
$log = print_r($useramount_admin_info, true);
Log::record($log, 'DEBUG');
10:多表查询( 连接查询)
方法一:使用table()方法
$tables = "b_bus bus,b_waidiao_businfo wd"; $wdbl_map['bus.license'] = array('like',"%$select_license%");
$wdbl_map["wd.type"] = 1;
$wdbl_map["wd.status"] = 1;
$wdbl_map["_string"] = "wd.busid = bus.id"; $waidoao_disposable_bus_info_list = M()->table($tables)->where($wdbl_map)->field('bus .*')->group('wd.busid')->order("wd.id desc")->select();
方法二:使用join() 方法
11、TP5:扩展配置目录
extra
config('status.ps')
12:如何在一个模块Action中直接执行另一个模块的Action
A方法:用于在内部实例化控制器,调用格式:
A('[项目://][分组/]模块','控制器层名称')
A('Home/Common');
13:A方法、R方法、D方法、M方法的区别
A方法只是对象的实例化,而R方法是可以同时实例化对象里面的方法的。
Thinkphp 3.2.3 A()和R()方法都是对控制器类的实例化,R()方法比A()写法更简便,R()方法能直接返回类中方法返回的信息。R()方法里面封装了A()方法。
// A方法
$test_m=A("Home/Goods");
echo $test_m->test(); // R方法
echo R("Home/Goods/test");
我们在Model的数据模型里面,必然需要下面的两种方法,一个是D方法,一个是M方法,前者是实例化数据模型类,而后者则是实例化数据模型的父类。
14:Thinkphp中的 I 函数(Thinkphp3.2.3版本) I方法
I 函数的作用是获取系统变量,必要时还可以对变量值进行过滤及强制转化,I 函数的语法格式:
I('变量类型.变量名/修饰符',['默认值'],['过滤方法或正则'],['额外数据源'])
在PHP中获取变量值的方法有很多,比如:$_GET['变量名'],$_POST['变量名'],$_SESSION['变量名'],$_COOKIE['变量名'],$_SERVER['变量名'] 都可以获取相应的变量值,但在thinkphp中为了安全的原因建议统一使用 I 函数来获取变量值。例如:获取 URL 地址栏中参数 id 的值,在php中我们用 $_GET['id'] 来获取,在thinkphp中我们可以用 I('get.id') 来获取。同样的, $_POST['id'] 就用 I('post.id') 取代。
15:Thinkphp中的U函数(Thinkphp3.2.3版本)
U函数的作用是根据当前的URL设置生成对应的URL地址,使用U函数可以确保项目在移植过程中不受环境的影响。
U方法的定义规则如下(方括号内参数根据实际应用决定):
U('地址表达式',['参数'],['伪静态后缀'],['显示域名'])
16:getField用法总结
$User = M("User"); // 实例化User对象
// 获取ID为3的用户的昵称
$nickname = $User->where('id=3')->getField('nickname');
② 获取某个字段列
$User = M("User"); // 实例化User对象
// 获取status为1的用户的昵称列表
$nickname = $User->where('status=1')->getField('nickname',true);
第二个参数传入了true,返回的nickname则是一个数组,包含了所有满足条件的昵称列表。
如果需要限制返回结果数量,可以使用:
$nickname = $User->where('status=1')->getField('nickname',);
③ 获取2个字段列表
$User = M("User"); // 实例化User对象
// 获取status为1的用户的昵称列表
$nickname = $User->where('status=1')->getField('id,nickname');
④:更多用法:http://www.thinkphp.cn/info/174.html
thinkphp5获取控制器名、模型名、方法名的代码
$request= \think\Request::instance();
dump($request->controller()); //获取控制器名
dump($request->module()); //获取模型名
dump($request->action()); //获取方法名
500、表达式中运算符条件的查询
SQL运算符 | 例子 | 实际查询条件 | |
---|---|---|---|
eq | = | $map['id'] = array('eq',100); | 等效于:$map['id'] = 100; |
neq | != | $map['id'] = array('neq',100); | id != 100 |
gt | > | $map['id'] = array('gt',100); | id > 100 |
egt | >= | $map['id'] = array('egt',100); | id >= 100 |
lt | < | $map['id'] = array('lt',100); | id < 100 |
elt | <= | $map['id'] = array('elt',100); | id <= 100 |
like | like | $map<'username'> = array('like','Admin%'); | username like 'Admin%' |
between | between and | $map['id'] = array('between','1,8'); | id BETWEEN 1 AND 8 |
not between | not between and | $map['id'] = array('not between','1,8'); | id NOT BETWEEN 1 AND 8 |
in | in | $map['id'] = array('in','1,5,8'); | id in(1,5,8) |
not in | not in | $map['id'] = array('not in','1,5,8'); | id not in(1,5,8) |
and(默认) | and | $map['id'] = array(array('gt',1),array('lt',10)); | (id > 1) AND (id < 10) |
or | or | $map['id'] = array(array('gt',3),array('lt',10), 'or'); | (id > 3) OR (id < 10) |
xor(异或) | xor | 两个输入中只有一个是true时,结果为true,否则为false,例子略。 | 1 xor 1 = 0 |
exp | 综合表达式 |
$map['id'] = array('exp','in(1,3,8)'); $map['sum'] = array('exp','`sum`+'.$shuliang); |
$map['id'] = array('in','1,3,8'); |
Thinkphp 整理备忘 杂记的更多相关文章
- [转].NET进阶系列之一:C#正则表达式整理备忘
本文转自:http://www.cnblogs.com/KissKnife/archive/2008/03/23/1118423.html 有一段时间,正则表达式学习很火热很潮流,当时在CSDN一天就 ...
- .NET进阶系列之一:C#正则表达式整理备忘
有一段时间,正则表达式学习很火热很潮流,当时在CSDN一天就能看到 好几个正则表达式的帖子,那段时间借助论坛以及Wrox Press出版的<C#字符串和正则表达式参考手册>学习了一些基础的 ...
- 整理备忘一波liunx命令(持续更新)
# 分区挂载 查看当前目录下的文件大小 du --max-depth= -h # 文件操作 # 编辑操作 #liunx 字体设置 苹果方字体下载安装 # 网洛端口 netstat命令各个参数说明如下: ...
- Redis集群搭建详细过程整理备忘
三.安装配置 1.环境 使用2台centos服务器,每台机器上部署3个实例,集群为三个主节点与三个从节点: 192.168.5.144:6380 192.168.5.144:6381 192.168. ...
- Mysql又一次整理笔记--woods备忘
==============================SQL备忘 CRUD 查询 多表 事件等=============================== ------------------ ...
- [转] HTML5终极备忘大全(图片版+文字版)---张鑫旭
by zhangxinxu from http://www.zhangxinxu.com本文地址:http://www.zhangxinxu.com/wordpress/?p=1544 一.前言兼图片 ...
- [CSS3备忘] transform animation 等
一些CSS不经常用就会忘记,好吧,现在整理再学习一下,也留做备忘,方便以后查看... perspective的理解: 1.数值越小,用户与3D空间Z平面距离越近,视觉效果更令人印象深刻(比如看电影,越 ...
- OpenCV备忘
都是转来的内容的,算是整理一下 OpenCV备忘 深度和通道的理解 CV_8UC1 是指一个8位无符号整型单通道矩阵, CV_32FC2是指一个32位浮点型双通道矩阵 CV_8UC1 CV_8SC1 ...
- C#常用代码片段备忘
以下是从visual studio中整理出来的常用代码片段,以作备忘 快捷键: eh 用途: 类中事件实现函数模板 private void MyMethod(object sender, Event ...
随机推荐
- JS 初学正则表达式
正则表达式 匹配中文,英文字母和数字及_的写法!同时控制长度 匹配中文:[\u4e00-\u9fa5] 英文字母:[a-zA-Z] 数字:[0-9] 匹配中文,英文字母和数字及_: ^[\u4e00- ...
- php图片下载
直接用url会在浏览器中打开图片, 想直接弹出保存框,可以用下面方法 下面的$dir指的是图片在服务器的绝对地址 function iDownload(){ $name=$_GET['name']; ...
- HTTPS基本原理
HTTPS基本原理 Xcode7上,默认采用的传输协议就是HTTPS,大家都知道HTTPS = HTTP + SSL,利用HTTPS协议传输的数据是加密的,更加安全.在此对概念性知识不再介绍.直接介绍 ...
- SQLite数据库的基本操作
SQLite,是一款轻型的数据库,是遵守ACID的关系型数据库管理系统,它包含在一个相对小的C库中.它是D.RichardHipp建立的公有领域项目.它的设计目标是嵌入式的,而且目前已经在很多嵌入式产 ...
- 【BZOJ-1086】王室联邦 分块 + 块状树
1086: [SCOI2005]王室联邦 Time Limit: 10 Sec Memory Limit: 162 MBSec Special JudgeSubmit: 1094 Solved: ...
- 【BZOJ-4423】Bytehattan 并查集 + 平面图转对偶图
4423: [AMPPZ2013]Bytehattan Time Limit: 3 Sec Memory Limit: 128 MBSubmit: 144 Solved: 103[Submit][ ...
- SQLite Learning、SQL Query Optimization In Multiple Rule
catalog . SQLite简介 . Sqlite安装 . SQLite Programing . SQLite statements 1. SQLite简介 SQLite是一款轻型的数据库,是遵 ...
- Java replace & replaceAll
Java字符串中需要对一些字符进行替换,用到最多的是replace和replaceAll两个方法.这两个方法在使用的时候需要注意: replace: public String replace (Ch ...
- bitmap的图像像素遍历方法
public class FastBitmap { BitmapData bitmapData; public FastBitmap(Bitmap bitmap) { ,,bitmap.Width,b ...
- 验证时出错。HRESULT = '8000000A'
往往出现在 做了安装项目后有警告: 解决办法: 这本来是在VS2005下创建的一下项目,后来改用VS2010的开发环境,.NET Framework的版本还是使用2.0, 但每次生成之后都会在解决方案 ...