ThinkPHP数据操作方法总结


Posted in PHP onSeptember 28, 2015

本文实例总结了ThinkPHP数据操作方法。分享给大家供大家参考。具体如下:

一、ThinkPHP Insert 添加数据

ThinkPHP 内置的 add 方法用于向数据表添加数据,相当于 SQL 中的 INSERT INTO 行为。

添加数据 add 方法是 CURD(Create,Update,Read,Delete / 创建,修改,读取,删除)中的 Create 的实现,ThinkPHP 支持以普通数组方式和面向对象方式将数据写入数据表。

现在以《PHP MySQL 数据库教程》中操作 user 表数据的例子(具体参见:PHP+MySQL之Insert Into数据插入用法分析)为例,来演示如何在 ThinkPHP 中实现对数据表的数据添加操作。

例子:

在 IndexAction 控制器(Lib/Action/IndexAction.class.php)里,添加 insert() 操作:

public function insert()
{
header("Content-Type:text/html; charset=utf-8");
 $Dao = M("User"); // 实例化模型类 // 构建写入的数据数组
 $data["username"] = "小王";
 $data["password"] = md5("123456");
 $data["email"] = 12345@163.com;
$data["regdate"] = time(); // 写入数据
if($lastInsId = $Dao->add($data))
{
echo "插入数据 id 为:$lastInsId";
 }
else {
 $this->error('数据写入错误!');
}
}

访问执行该操作:http://127.0.0.1/html/Myapp/index.php/Index/insert

语法解读

M("User") 用于高效实例化一个数据模型(M 是 new Model 的简写,称为快捷方法),参数为要操作的表名。

接下来构建要保存数据的数组 $data 。

最后是用 add() 方法将数据写入库表,由于使用的是 M快捷方法,需要将 $data 数组传入 add() 方法。

add() 方法如果添加数据记录成功,返回的是新数据记录主键,可直接得到。
该例子实际运行的 SQL 为:

INSERT INTO user
(username,password,email,regdate)
 VALUES
('小王','e10adc3949ba59abbe56e057f20f883e','12345@163.com',1283612673)

提示:运行该例子,请确认在配置文件里正确配置了数据库的相关账号密码等信息,具体参见《ThinkPHP公共配置文件与各自项目中配置文件组合的方法》
 
对象方式添加数据

上面的方式是以构造数据数组的方式,然后将数据以参数形式传入 add 方法写入数据表。ThinkPHP 也支持以对象的方式将数据写入数据表,将上面的代码更改为:

public function insert()
{
header("Content-Type:text/html; charset=utf-8");
 $Dao = M("User"); // 实例化模型类 // 数据对象赋值
$Dao->username = "小王";
 $Dao->password = md5("123456");
 $Dao->email = 12345@163.com;
 $Dao->regdate = time(); // 写入数据
if($lastInsId = $Dao->add()){ echo "插入数据 id 为:$lastInsId";
}
 else {
$this->error('数据写入错误!');
 }
}

对象方式除了数据以数据对象方式赋值外,在调用 add 方法写入数据的时候不需要传递参数。

二、ThinkPHP 更新数据 save方法

save()

ThinkPHP 中使用 save() 方法来更新数据库,并且也支持连贯操作的使用。
例子:

public function update(){
header("Content-Type:text/html; charset=utf-8");
$Dao = M("User"); // 需要更新的数据
 $data['email'] = 'Jack@163.com';
// 更新的条件 $condition['username'] = 'Jack';
 $result = $Dao->where($condition)->save($data);
//或者:$resul t= $Dao->where($condition)->data($data)->save();
if($result !== false){ echo '数据更新成功!';
}
else{
echo '数据更新失败!';
 }
}

上面例子执行的 SQL 语句为:

UPDATE user SET email='Jack@163.com' WHERE username='Jack'

提示

为了保证数据库的安全,避免出错更新整个数据表,如果没有任何更新条件,数据对象本身也不包含主键字段的话,save方法不会更新任何数据库的记录。

因此要使用 save() 方法更新数据,必须指定更新条件或者更新的数据中包含主键字段。

使用主键的例子:

public function update(){
 header("Content-Type:text/html; charset=utf-8");
 $Dao = M("User"); // 需要更新的数据
 $data['email'] = 'Jack@163.com'; $data['uid'] = 2;
 $result = $Dao->save($data);
if($result !== false)
{
echo '数据更新成功!';
 }else{
echo '数据更新失败!';
 }
}

如果需要更新的数据里面包含主键,那么 ThinkPHP 会自动把主键的值作为条件来更新。

上面的例子跟下面的效果相同:

// 需要更新的数据 $data['email'] = 'Jack@163.com';
// 更新的条件 $condition['uid'] = 2; $result = $Dao->where($condition)->save($data);
如果是表单数据,还可以使用 create() 方法创建数据对象来更新数据:

public function update(){
header("Content-Type:text/html; charset=utf-8");
 $Dao = D("User");
 if($vo = $Dao->create())
{ $result = $Dao->save();
if($result !== false)
{ echo '数据更新成功!';
}else{
echo '数据更新失败!';
 } }
else{
$this->error($Form->getError());
 }
}

如果更新的数据需要做逻辑处理,可以在操作类以对象的方式处理或者在模型内处理,具体可参考《ThinkPHP 表单数据智能写入 create 方法》。

注意:以create() 方法创建数据对象来更新数据,表单中必须包含一个以主键为名称的隐藏域,才能完成保存操作。

三、ThinkPHP 查询数据 select(findAll)方法

ThinkPHP 查询数据主要提供以下几类查询:
select:普通查询,同 findAll() 方法
find:取得符合查询条件的一条记录
getBy动态查询:根据某个字段取得符合查询条件的一条记录
getField:获取某个字段的值或多个字段的索引数组
区间查询:取得符合查询条件的区间记录
统计查询:取得符合查询条件的统计数据
定位查询:取得符合查询条件的一条或多条记录
原生SQL查询:支持以原生 SQL 进行查询或执行操作

select()

select() 是 ThinkPHP 中最常用的普通查询方法,得到的是一个二维数组。findAll() 为 select() 方法的别名,并建议使用 select()。

读取操作

下面的例子将 user 表的所有数据读取出来并显示:

public function read()
{
$Dao = M("User"); // 查询数据
$list = $Dao->select();
//dump($list);
// 用 dump() 可以在调试阶段查看数据是否已读取
// 模板变量赋值 $this->assign("list", $list);
// 输出模板 $this->display();
}

假设上面的例子对应的 class 文件为 Lib/Action/IndexAction.class.php ,那么对应的模板文件为 Tpl/default/Index/read.html。

数据显示模板

模板文件用于显示刚才读取的 User 表的数据。在学习阶段,要不想使用模板,也可以直接使用 foreach 语法在 read() 操作内直接显示读取的数据。下面是模板相应的代码片段,我们将读取的数据在一个表格中显示出来:

<table border="1">
 <tr>
<th width="10%">ID</th>
 <th width="30%">用户名</th>
 <th width="30%">电子邮件</th>
<th>注册时间</th>
 </tr>
<volist name="list" id="vo">
<tr>
<td align="center">{$vo['uid']}</td>
 <td>{$vo['username']}</td>
<td>{$vo['email']}</td>
 <td>{$vo['regdate']|date='Y-m-d H:i',###}</td>
 </tr>
</volist>
</table>

要了解更多关于 ThinkPHP模板的知识,请参阅:《ThinkPHP 模板》。

field() 查询指定字段

select() 方法默认是查询所有字段的数据,如果要查询某个或某些字段,就需要使用 filed() 方法。

filed() 是属于 ThinkPHP 连贯操作中的一个方法,如在上面的例子中,只查询用户名和电子邮件地址,则查询方法对应更改为:

$list = $Dao->field('username,email')->select();

使用查询条件

使用 ThinkPHP 连贯操作可以很方便的对数据查询使用查询条件。下面是一些简单的查询条件的例子。

where() 条件

…… // 构造查询条件 $condition['username'] = 'Admin'; // 查询数据 $list = $Dao->where($condition)->select(); ……
上述查询的就是 username='Admin' 这个条件的数据。关于 ThinkPHP where 条件更详细资料,请参阅《ThinkPHP Where 条件》。

ORDER BY 排序

在查询中使用 ORDER BY 对数据进行排序:
…… // 查询数据 $list = $Dao->order('uid DESC')->select(); ……
这个例子就是数据按照 ORDER BY uid DESC 进行查询,而 order() 方法中的参数意义跟 SQL 语句中的意义完全一致。

LIMIT 限制

在查询中使用 LIMIT 限定数据返回的记录数:
…… // 查询数据 $list = $Dao->limit('4,5')->select(); ……
这个例子就是将第 5-10 条记录取出,limit() 方法内的参数意义跟 SQL 语句中的 LIMIT 完全一致。

连贯操作

ThinkPHP 中允许将数据对象中的各个方法写在一起操作,如:
$list = $Dao->order('uid DESC')->limit('4,5')->select();
这就是连贯操作,关于连贯操作更详细的介绍,参见《ThinkPHP 连贯操作》。
 
四、ThinkPHP 删除数据记录 delete 方法

ThinkPHP 中使用 delete() 方法来删除数据库中的数据记录,并且也支持连贯操作的使用。delete() 方法执行成功返回操作影响(删除)的记录数。

例子:

public function del(){
 header("Content-Type:text/html; charset=utf-8");
$Dao = M("User"); // 删除 uid=5 的数据记录
 $result = $Dao->where('uid = 5')->delete();
 if($result !== false){
echo '删除 ',$result,' 条数据。';
}else{
 echo '删除数据失败!';
}
}

上面例子执行的 SQL 为:

DELETE FROM user WHERE uid = 5

delete() 方法可以用于删除单个或者多个数据,主要取决于 where() 删除条件。另外也可以配合连贯操作中的其他方法如 order()、limit() 等构造出更符合需要的删除条件:

$Dao = M("User");
$result = $Dao->where('status=0')->order('regdate ASC')->limit('5')->delete();

上面例子根据用户注册时间降序排列,删除 5 条 status=0 的用户记录。

希望本文所述对大家基于ThinkPHP框架的php程序设计有所帮助。

PHP 相关文章推荐
十天学会php之第七天
Oct 09 PHP
完美解决dedecms中的[html][/html]和[code][/code]问题
Mar 20 PHP
一个图形显示IP的PHP程序代码
Oct 19 PHP
ThinkPHP快速入门实例教程之数据分页
Jul 01 PHP
使用GD库生成带阴影文字的图片
Mar 27 PHP
全面解析PHP验证码的实现原理 附php验证码小案例
Aug 17 PHP
php 静态属性和静态方法区别详解
Apr 09 PHP
php显示页码分页类的封装
Jun 08 PHP
Laravel框架实现model层的增删改查(CURD)操作示例
May 12 PHP
解决laravel5中auth用户登录其他页面获取不到登录信息的问题
Oct 08 PHP
PHP连接SQL server数据库测试脚本运行实例
Aug 24 PHP
Laravel中GraphQL接口请求频率实战记录
Sep 01 PHP
ThinkPHP表单数据智能写入create方法实例分析
Sep 27 #PHP
PHP+MySQL之Insert Into数据插入用法分析
Sep 27 #PHP
ThinkPHP中数据操作案例分析
Sep 27 #PHP
PHP中两个float(浮点数)比较实例分析
Sep 27 #PHP
用php代码限制国内IP访问我们网站
Sep 26 #PHP
十大使用PHP框架的理由
Sep 26 #PHP
PHP弹出对话框技巧详细解读
Sep 26 #PHP
You might like
AM/FM收音机的安装与调试
2021/03/02 无线电
php的SimpleXML方法读写XML接口文件实例解析
2014/06/16 PHP
javascript 获取图片颜色
2009/04/05 Javascript
一个简单的jQuery插件制作 学习过程及实例
2010/04/25 Javascript
js怎么终止程序return不行换jfslk
2013/05/30 Javascript
实现51Map地图接口(示例代码)
2013/11/22 Javascript
IE与FireFox的JavaScript兼容问题解决办法
2013/12/31 Javascript
Javascript实现的简单右键菜单类
2015/09/23 Javascript
基于JavaScript代码实现随机漂浮图片广告
2016/01/05 Javascript
JavaScript实现仿淘宝商品购买数量的增减效果
2016/01/22 Javascript
深入理解JavaScript中的并行处理
2016/09/22 Javascript
Angular路由简单学习
2016/12/26 Javascript
jQuery+PHP+Mysql实现抽奖程序
2020/04/12 jQuery
javascript字体颜色控件的开发 JS实现字体控制
2017/11/27 Javascript
webpack 从指定入口文件中提取公共文件的方法
2018/11/13 Javascript
javascript删除数组元素的七个方法示例
2019/09/09 Javascript
vue-quill-editor 自定义工具栏和自定义图片上传路径操作
2020/08/03 Javascript
vue-cli脚手架的.babelrc文件用法说明
2020/09/11 Javascript
Vue 实现一个简单的鼠标拖拽滚动效果插件
2020/12/10 Vue.js
[02:24]DOTA2痛苦女王 英雄基础教程
2013/11/26 DOTA
[01:10:49]Secret vs VGJ.S 2018国际邀请赛淘汰赛BO3 第二场 8.24
2018/08/25 DOTA
[01:04:08]完美世界DOTA2联赛PWL S3 INK ICE vs GXR 第一场 12.16
2020/12/18 DOTA
HTML中使用python屏蔽一些基本功能的方法
2017/07/07 Python
python操作excel的方法(xlsxwriter包的使用)
2018/06/11 Python
Jupyter Notebook的连接密码 token查询方式
2020/04/21 Python
python代码如何注释
2020/06/01 Python
林清轩官方网站:山茶花润肤油开创者
2016/10/26 全球购物
The Beach People美国:澳洲海滨奢华品牌
2018/07/05 全球购物
党的群众路线教育实践活动公开承诺书
2014/03/28 职场文书
大学生学雷锋活动总结
2014/06/26 职场文书
2014小学语文教师个人工作总结
2014/12/03 职场文书
初中生思想道德自我评价
2015/03/09 职场文书
2015小学教师年度工作总结
2015/05/12 职场文书
大学优秀学生主要事迹材料
2015/11/04 职场文书
​(迎国庆)作文之我爱我的祖国
2019/09/19 职场文书
20180830晚上第一届KSL半决赛 雨神vs解冻(二龙 三炮解说)
2022/04/01 星际争霸