[转]ThinkPHP的CURD易忽视点小结

转自: http://www.oschina.net/code/snippet_2285640_44437、

1、使用对象的方法插入数据 D用法。
$Form = D(‘Form‘);
$data[‘title‘] = ‘ThinkPHP‘;
$data[‘content‘] = ‘表单内容‘;
$Form->add($data);

其实thinkphp还支持对象的方式直接向数据库插入数据,如下:
$Form = D(‘Form‘);
$Form->title = ‘ThinkPHP‘;
$Form->content = ‘表单内容‘;
$Form->add();

2、不指定条件对数据更新。
$Form = M("Form"); // 要修改的数据对象属性赋值
$data[‘id‘] = 5;
$data[‘title‘] = ‘ThinkPHP‘;
$data[‘content‘] = ‘ThinkPHP3.1版本发布‘;
$Form->save($data); // 根据条件保存修改的数据

save方法会自动识别数据对象中的主键字段,并作为更新条件。当然,你也可以显式的传入更新条件,也就是我们最常用的方法:
$Form = M("Form");
// 要修改的数据对象属性赋值
$data[‘title‘] = ‘ThinkPHP‘;
$data[‘content‘] = ‘ThinkPHP3.1版本发布‘;
$Form->where(‘id=5‘)->save($data); // 根据条件保存修改的数据

其实还有对象的方式,就像上面提到的,插入数据,用对象的方式一样:
$Form = M("Form");
// 要修改的数据对象属性赋值
$Form->title = ‘thinkphp‘;
$Form->content = ‘ThinkPHP3.1版本发布‘;
$Form->where(‘id=5‘)->save(); // 根据条件保存修改的数据

并且,可以将主键字段包含在要保存的数据里,这样就可以不需要写where了
$Form = M("Form");
// 要修改的数据对象属性赋值
$Form->id = 5;
$Form->title = ‘thinkphp‘;
$Form->content = ‘ThinkPHP3.1版本发布‘;
$Form->save(); // 根据数据对象中的主键保存修改的数据

3、单个字段值的修改。

有些时候,我们只需要修改某个字段的值,就可以使用setField方法,而不需要每次都调用save方法。
$Form = M("Form"); // 更改title值
$Form->where(‘id=5‘)->setField(‘title‘,‘ThinkPHP‘);

6、强大的增减字段值运算。

thinkphp中,可以对某个字段的数据直接执行增减操作。

对于统计字段,系统还提供了更加方便的setInc和setDec方法。
$User = M("User"); // 实例化User对象
$User->where(‘id=5‘)->setInc(‘score‘,3); // 用户的积分加3
$User->where(‘id=5‘)->setInc(‘score‘); // 用户的积分加1
$User->where(‘id=5‘)->setDec(‘score‘,5); // 用户的积分减5
$User->where(‘id=5‘)->setDec(‘score‘); // 用户的积分减1

7、不使用where来执行删除。

$User->delete(‘1,2,5‘); // 删除主键为1,2和5的用户数据。

这种用法可以用在类似于签到时候,用户积分自动增加的例子上。

8、打印sql语句
echo $User->getLastSql();或者echo $User->_sql();

循环输出
volist 还有别名 iterate

模版赋值:
$User = D(‘User‘)
$list = $User->findAll()
$this->assign(‘list‘,$list)

模版定义:
<iterate name="list" id="vo">
{$vo.name}
</iterate>

注意 name 和 id 表示的含义
// 输出 list 的第 5~15 条记录
<iterate name="list" id="vo" offset="5" length=‘10‘>
{$vo.name}
</iterate>

// 输出偶数记录
<iterate name="list" id="vo" mod="2" >
<eq name="mod" value="1">
{$vo.name}
</eq>
</iterate>

// 输出 key
<iterate name="list" id="vo" key="k" >
{$k}.{$vo.name}
</iterate>

//子循环输出
<volist name="list" id="vo">
<iterate name="vo[‘sub‘]" id="sub">
{$sub.name}
</iterate>
</volist>

Switch 标签
<switch name="name">
<case value="1">value1</case>
<case value="2">value2</case>
<default />default
</switch>
其 中 name 属性可以使用函数以及系统变量,例如:
<switch name="Think.get.userId|abs">
<case value="1">admin</case>
<default />default
</switch>
也 可以对 case 的 value 属性使用变量,例如:
<switch name="userId">
<case value="$adminId">admin</case>
<case value="$memberId">member</case>
<default />default
</switch>

比较标签
<eq name="name" value="value">value</eq> // name 变量的值等于 value 就输出
<neq name="name" value="value">value</neq> // name 变量的值不等于 value 就输出
<gt name="name" value="5">value</gt> // name 变量的值大于 5 就输出
<egt name="name" value="5">value</egt> // name 变量的值大于等于 5 就输出
<lt name="name" value="5">value</lt> // name 变量的值小于 5 就输出
<elt name="name" value="5">value</elt> // name 变量的值小于等于 5 就输出

//其实上面的所有标签都是 compare 标签的别名
// 其中 type 属性的值就是上面列出的判断标签名称
<compare name="name" value="5" type="eq">value</compare> // name 变量的值等于 5 就输出

If标签
<if condition="$name eq 1 "> value1
<elseif condition="$name eq 2" />value2
<else /> value3
</if>

C操作
操作(动态)配置: 主要用于Action方法里面
获取:
C(‘配置参数‘)
设置:
C(‘配置参数 ‘,新值)

A操作
快速创建Action对象:
$action = A(‘User‘);
等效于
$action = new UserAction();

D操作
快速创建模型数据对象:
$model = D(‘User‘);
等效于
$model = new UserModel();

S操作
快速操作缓存方法
获取:
S(‘name‘)
设置:
S(‘name‘,‘value‘);
删 除:
S(‘name‘,NULL);

F操作
快速文件数据保存方法
使用方法与S操作一样

L操作
快速操作语言变量
获取:
L(‘语言变量‘);
设置:
L(‘语言变量‘,‘值‘);
如: L(‘USER_INFO‘,‘用户信息‘); //设置名称为USER_INFO的语言变量
批量赋值:
$arr[‘语言变量1‘] = ‘值1‘;
$arr[‘语言变量2‘] = ‘值2‘;
L($arr);

ThinkPHP系统常量

THINK_PATH // ThinkPHP 系统目录
APP_PATH // 当前项目目录
APP_NAME // 当前项目名称
MODULE_NAME //当前模块名称
ACTION_NAME // 当前操作名称
TMPL_PATH // 项目模版目录
LIB_PATH // 项目类库目录
CACHE_PATH // 项目模版缓存目录

CONFIG_PATH //项目配置文件目录
LOG_PATH // 项目日志文件目录
LANG_PATH // 项目语言文件目录
TEMP_PATH //项目临时文件目录
PLUGIN_PATH // 项目插件文件目录
VENDOR_PATH // 第三方类库目录
DATA_PATH // 项目数据文件目录
IS_APACHE // 是否属于 Apache
IS_IIS //是否属于 IIS
IS_WIN //是否属于Windows 环境
IS_LINUX //是否属于 Linux 环境
IS_FREEBSD //是否属于 FreeBsd 环境
NOW_TIME // 当前时间戳
MEMORY_LIMIT_ON // 是否有内存使用限制

MEMORY_LIMIT_ON // 是否有内存使用限制
OUTPUT_GZIP_ON // 是否开启输出压缩
MAGIC_QUOTES_GPC // MAGIC_QUOTES_GPC
THINK_VERSION //ThinkPHP 版本号
LANG_SET // 浏览器语言
TEMPLATE_NAME //当前模版名称
TEMPLATE_PATH //当前模版路径
__ROOT__ // 网站根目录地址
__APP__ // 当前项目(入口文件)地址
__URL__ // 当前模块地址
__ACTION__ // 当前操作地址
__SELF__ // 当前 URL 地址
TMPL_FILE_NAME //当前操作的默认模版名(含路径)
WEB_PUBLIC_URL //网站公共目录
APP_PUBLIC_URL //项目公共模版目录

预定义常量
WEB_LOG_ERROR=0 // 错误日志类型
WEB_LOG_DEBUG=1 // 调试日志类型
SQL_LOG_DEBUG=2 // SQL 日志类型
SYSTEM_LOG=0 // 系统方式记录日志
MAIL_LOG=1 // 邮件方式记录日志
TCP_LOG=2 // TCP 方式记录日志
FILE_LOG=3 // 文件方式记录日志
DATA_TYPE_OBJ=1 // 对象方式返回
DATA_TYPE_ARRAY=0 // 数组方式返回
URL_COMMON=0 // 普通模式 URL
URL_PATHINFO=1 // PATHINFO URL
URL_REWRITE=2 // REWRITE URL
HAS_ONE=1 // HAS_ONE 关联定义
BELONGS_TO=2 // BELONGS_TO 关联定义
HAS_MANY=3 // HAS_MANY 关联定义
MANY_TO_MANY=4 // MANY_TO_MANY 关联定义
EXISTS_VAILIDATE = 0 // 表单存在字段则验证
MUST_VALIDATE = 1 // 必须验证
VALUE_VAILIDATE = 2 // 表单值不为空则验证

I方法
    echo I(‘get.id‘); // 相当于 $_GET[‘id‘]
    echo I(‘get.name‘); // 相当于 $_GET[‘name‘]
    echo I(‘get.name‘,‘‘,‘htmlspecialchars‘); // 采用htmlspecialchars方法对$_GET[‘name‘] 进行过滤,如果不存在则返回空字符串
时间: 2024-10-09 18:14:45

[转]ThinkPHP的CURD易忽视点小结的相关文章

ThinkPHP的易忽视点小结

1.使用对象的方法插入数据 D用法. $Form = D('Form'); $data['title'] = 'ThinkPHP'; $data['content'] = '表单内容'; $Form->add($data); 其实thinkphp还支持对象的方式直接向数据库插入数据,如下: $Form = D('Form'); $Form->title = 'ThinkPHP'; $Form->content = '表单内容'; $Form->add(); 2.不指定条件对数据更新

ThinkPHP的CURD操作

CURD:create(创建).update(更新).read(读取).delete(删除) 1.数据对象创建(create):  a.TP提供了create方法迅速的创建数据对象,可一自动的根据表单数据创建对象,支持数组,对象,甚至可以把一个数据对象创建给一个新的数据对象,如:    $User=M('User');    $User->name='ThinkPHP';    $User->email='[email protected]';    $Member=M('Member'); 

ThinkPHP 的CURD 基本操作

说起CURD,懂点SQL的人都知道,就是增删改查,做业务系统的时候,往往离不开这CURD,最近也是刚刚接触ThinkPHP,ThinkPHP的灵活性是比原生PHP好用的多,下面我就简单的介绍一下我的学习心得. 学习ThinkPHP对MySQL的操作,首先你要有MySQL,然后又PHP的运行环境. wamp可以帮你解决配置的麻烦,关于wamp资料很多,百度就可以了. 下面就简单介绍一下ThinkPHP的增删改查的过程. 一.创建数据库,命名为t_user. 代码为: DROP TABLE IF E

【三十四】thinkphp之curd操作

1.数据创建(create) 接受提交过来的数据,比如表单提交的 POST(默认)数据.接受到数据后,还可以对数据进行有效的验证.完成.生成等工作 // 这里 create()方法就是数据创建,数据的结果就是提交的 POST 数据的键值对. // 特别注意的是:提交过来的字段和数据表字段是对应的,否则无法解析 //根据表单提交的POST数据,创建数据 var_dump($user->create()); 通过$_post接收数据 //通过数组手工获取数据,覆盖提交的 $data['name']=

OpenCV里IplImage和char *的相互转换,以及极易忽视的细节

OpenCV中IplImage和单字节char*的相互转换 从 IplImage到 char* : data = image->imageData //对齐的图像数据 或者data = image->imageDataOrigin //未对齐的原始图像数据 从 char* 到 IplImage: image =cvCreateImageHeader(cvSize(width,height), depth, channels); cvSetData(image, data, step); ste

集合一些易忽视的地方

1.请讲下Java里面的容器 集合Collection有两种: List:元素是有序的,元素可以重复,因为该集合体有索引 ArrayList: 底层数据结构是数组,查询快,增删慢. 线程不安全,效率高.    当元素放满了后,以原长度的50%+1的长度加长集合容器的长度. Vector: 底层数据结构是数组,查询快,增删慢. 线程安全,效率低.    当元素放满了后,以原长度100%的长度加长集合容器的长度. LinkedList: 底层数据结构是链表,查询慢,增删快. 线程不安全,效率高. V

总结ThinkPHP使用技巧经验分享(四)

ThinkPHP的CURD易忽视点小结1.不定义方法,直接渲染模板. 对于没有任何实际逻辑的操作方法,我们只需要直接定义对应的模板文件就行了,比如表单页面,这个页面一般不会有变量向模板中输出,所以,我们没有必要再去写一个对应的空方法然后$this->display()了.2.简介create方法. 假设我们实例化的模型为$model,那么ThinkPHP可以直接通过$model->add()的方式向数据库中添加数据,那么如果我们在$model->add()之前调用$model->c

ThinkPHP CURD方法盘点:field方法

ThinkPHP的CURD操作中有很多非常实用的方法,从这篇开始,我们会为大家一一介绍. 首先为大家介绍下field方法的用法.field属于模型的连贯操作方法之一,主要目的是标识要返回或者操作的字段,可以用于查询和写入操作. 1.用于查询 在查询操作中field方法是使用最频繁的. $Model->field('id,title,content')->select(); 这里使用field方法指定了查询的结果集中包含id,title,content三个字段的值.执行的SQL相当于: SELE

thinkphp 更新数据时如果未修改数据,返回结果判断错误

thinkphp的CURD中,使用save方法时会出现一个奇怪的问题,即如果数据没有更新(与原数据相同),返回值判断为false.其实很久之前就发现了这个问题,一度以为是官方代码的问题,但是一直拖延到最近才想到要去解决这个问题.不得不说:"明日复明日,明日何其多.事事待明日,万事皆蹉跎.",与君共勉! 在官网上搜索了这个问题之后,发现官方已经解决了这个问题,原本的判断: $result = $Model->where('id=1')->save($data); if($re