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与SQL注入攻击[二]
Apr 17 PHP
一个图形显示IP的PHP程序代码
Oct 19 PHP
php实现mysql同步的实现方法
Oct 21 PHP
提高PHP性能的编码技巧以及性能优化详细解析
Aug 24 PHP
PHP输出英文时间日期的安全方法(RFC 1123格式)
Jun 13 PHP
PHP采用get获取url汉字出现乱码的解决方法
Nov 13 PHP
推荐一本PHP程序猿都应该拜读的书
Dec 31 PHP
php简单备份与还原MySql的方法
May 09 PHP
最新最全PHP生成制作验证码代码详解(推荐)
Jun 12 PHP
PHP页面跳转操作实例分析(header方法)
Sep 28 PHP
PHP迭代与递归实现无限级分类
Aug 28 PHP
浅析PHP中的 inet_pton 网络函数
Dec 16 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
PHP输出九九乘法表代码实例
2015/03/27 PHP
PHP 以POST方式提交XML、获取XML,解析XML详解及实例
2016/10/26 PHP
PHP基础之输出缓冲区基本概念、原理分析
2019/06/19 PHP
php设计模式之原型模式分析【星际争霸游戏案例】
2020/03/23 PHP
jQuery之end()和pushStack()使用介绍
2012/02/07 Javascript
js 三级关联菜单效果实例
2013/08/13 Javascript
JS+CSS设置img在DIV中只显示Img垂直居中的部分
2013/10/24 Javascript
使用AngularJS处理单选框和复选框的简单方法
2015/06/19 Javascript
JSONP跨域请求实例详解
2016/07/04 Javascript
JavaScript数组去重的6个方法
2017/01/21 Javascript
jquery 仿锚点跳转到页面指定位置的实例
2017/02/14 Javascript
jQuery第一次运行页面默认触发点击事件的实例
2018/01/10 jQuery
微信小程序之多文件下载的简单封装示例
2018/01/29 Javascript
详解vue几种主动刷新的方法总结
2019/02/19 Javascript
详解Vue中使用插槽(slot)、聚类插槽
2019/04/12 Javascript
微信小程序实现卡片层叠滑动效果
2019/06/21 Javascript
利用JavaScript的Map提升性能的方法详解
2019/08/14 Javascript
JS script脚本中async和defer区别详解
2020/06/24 Javascript
[04:10]2018年度CS GO玩家最喜爱的主播-完美盛典
2018/12/16 DOTA
Python的Twisted框架中使用Deferred对象来管理回调函数
2016/05/25 Python
Python定时任务sched模块用法示例
2018/07/16 Python
pymongo中group by的操作方法教程
2019/03/22 Python
Python爬虫之Selenium鼠标事件的实现
2020/12/04 Python
CSS3 media queries + jQuery实现响应式导航
2016/09/30 HTML / CSS
Html5实现单张、多张图片上传功能
2019/04/28 HTML / CSS
天猫超市:阿里巴巴打造的网上超市
2016/11/02 全球购物
玛蒂尔达简服装:Matilda Jane Clothing
2019/02/13 全球购物
销售自我评价
2013/10/22 职场文书
一份婚庆公司创业计划书
2014/01/11 职场文书
舞蹈教师自荐信
2014/01/27 职场文书
司法局群众路线教育实践活动整改措施思想汇报
2014/10/13 职场文书
2015年安全生产工作总结范文
2015/04/02 职场文书
2015年中职班主任工作总结
2015/05/25 职场文书
纯CSS实现酷炫的霓虹灯效果
2021/04/13 HTML / CSS
详细介绍python操作RabbitMq
2022/04/12 Python
clear 万能清除浮动(clearfix:after)
2023/05/21 HTML / CSS