Zend Framework数据库操作技巧总结


Posted in PHP onFebruary 18, 2017

本文实例总结了Zend Framework数据库操作。分享给大家供大家参考,具体如下:

Zend_Db数据库知识

例子:

Model文件:

$this->fetchAll("is_jian=1","id DESC",0,2)->toArray();
//根据is_jian=1,按id倒序排列取前2条记录当第一个参数为null时,则直接按id倒序排列ASC为正序。

路由文件:

$video=new Video();//实例化数据库类
$this->view->get2Video =$video->get2Video();//取到2条首页推荐的数据

index.phtml文件:

<?php foreach ($this->get2Video as $video): ?>
<?=$video['id']; ?>
<?=$video['name']; ?>
<? endforeach; ?>

添加引号防止数据库攻击

quote用法

$value = $db->quote('St John"s Wort');
// $value 现在变成了 '"St John\"s Wort"' (注意两边的引号)
// 为数组加引号
$value = $db->quote(array('a', 'b', 'c'));
// $value 现在变成了 '"a", "b", "c"' (","分隔的字符串)

quoteInto用法

echo $where = $db->quoteInto('id = ?', 1);
// $where 现在为 'id = "1"' (注意两边的引号)
// 在where语句中为数组加上引号
$where = $db->quoteInto('id IN(?)', array(1, 2, 3));
// $where 现在为 'id IN("1", "2", "3")' (一个逗号分隔的字符串)

(1)数据查询总结

直接进行查询.    ( 使用完整的sql语句)

//function quoteInto($text, $value, $type = null, $count = null)
$db = $this->getAdapter();
$sql = $db->quoteInto('SELECT * FROM `m_video` WHERE `is_guo` =?', '1');
$result = $db->query($sql);
// 使用PDOStatement对象$result将所有结果数据放到一个数组中
$videoArray = $result->fetchAll();

fetchAll用法

fetchAll($where = null, $order = null, $count = null, $offset = null)

取回结果集中所有字段的值,作为连续数组返回,如果参数不设置就写成null

可以取回结果集的指定条数

$videoArray=$this->fetchAll("is_jian=1 and is_guo=1","id DESC",0,2)->toArray();

fetchAssoc用法

fetchAssoc($sql, $bind = array())

取回结果集中所有字段的值,作为关联数组返回, 第一个字段作为码

$db = $this->getAdapter();
$videoArray=$db->fetchAssoc("SELECT * FROM m_video WHERE `is_jian` = :title",array('title' => '1'));

fetchCol用法

fetchCol($sql, $bind = array())

取回所有结果行的第一个字段名

$db = $this->getAdapter();
$videoArray=$db->fetchCol("SELECT name FROM m_video WHERE `is_jian` = :title",array('title' => '1'));

fetchOne用法

fetchOne($sql, $bind = array())

只取回第一个字段值

$db = $this->getAdapter();
echo $videoArray=$db->fetchOne("SELECT count(*) FROM m_video WHERE `is_jian` = :title",array('title' => '1'));

fetchPairs用法

fetchPairs($sql, $bind = array())

取回一个相关数组,第一个字段值为码(id),第二个字段为值(name)

返回:Array( [1] => 十二生肖奇缘    [2] => 桃花运),1,2:为id字段。

$db = $this->getAdapter();
$videoArray=$db->fetchPairs("SELECT id, name FROM m_video WHERE is_jian = :title",array('title' => '1'));

fetchRow用法

fetchRow($where = null, $order = null)

只取回结果集的第一行

$videoArray=$this->fetchRow("is_jian=1 and is_guo=1", 'id DESC')->toArray();

query用法

//function query($sql, $bind = array())
$db = $this->getAdapter();
$result = $db->query('SELECT * FROM `m_video`');
//$result = $db->query('SELECT * FROM `m_video` WHERE `name` = ? AND id = ?',array('十二生肖奇缘', '1'));
//$result->setFetchMode(Zend_Db::FETCH_OBJ);//FETCH_OBJ为默认值,FETCH_NUM,FETCH_BOTH
//while ($row = $result->fetch()) {
//  echo $row['name'];
//}
//$rows = $result->fetch();
//$rows = $result->fetchAll();
//$obj = $result->fetchObject();//echo $obj->name;
// echo $Column = $result->fetchColumn(0);//得到结果集的第一个字段,比如0为id号,用于只取一个字段的情况
print_r($rows);

select用法

$db = $this->getAdapter();
$select = $db->select();
$select->from('m_video', array('id','name','clicks'))
->where('is_guo = :is_guo and name = :name')
->order('name')// 按什么排序列,参加为数组(多个字段)或字符串(一个字段)
->group()//分组
->having()//分组查询数据的条件
->distinct()// 无参数,去掉重复的值。有时候与groupby返回的结果一样
->limit(10);
// 读取结果使用绑定的参数
$params = array('is_guo' => '1','name'=>'十二生肖奇缘');
//$sql = $select->__toString();//得到查询语句,可供调试
$result = $db->fetchAll($select,$params);
执行select的查询
$stmt = $db->query($select);
$result = $stmt->fetchAll();

或用

$stmt = $select->query();
$result = $stmt->fetchAll();

如果直接用

$db->fetchAll($select)

结果一样

多表联合查询用法

$db = $this->getAdapter();
$select = $db->select();
$select->from('m_video', array('id','name','pic','actor','type_id','up_time'))
->where('is_guo = :is_guo and is_jian = :is_jian')
->order('up_time')
->limit(2);
$params = array('is_guo' => '1','is_jian'=>'1');
$select->join('m_type', 'm_video.type_id = m_type.t_id', 'type_name');//多表联合查询
$videoArray = $db->fetchAll($select,$params);

find()方法,可以使用主键值在表中检索数据.

// SELECT * FROM round_table WHERE id = "1"
$row = $table->find(1);
// SELECT * FROM round_table WHERE id IN("1", "2", 3")
$rowset = $table->find(array(1, 2, 3));

(2)数据删除总结

第一种方法:可以删任意表

//quoteInto($text, $value, $type = null, $count = null)
$table = 'm_video';// 设定需要删除数据的表
$db = $this->getAdapter();
$where = $db->quoteInto('name = ?', 'ccc');// 删除数据的where条件语句
echo $rows_affected = $db->delete($table, $where);// 删除数据并得到影响的行数

第二种方法:只能删除本表中的

//delete用法
// delete($where)
$where = "name = 'bbb'";
echo $this->delete($where);// 删除数据并得到影响的行数

(3)数据更新总结

第一种方法:可以更新任意表

// 以"列名"=>"数据"的格式构造更新数组,更新数据行
$table = 'm_video';// 更新的数据表
$db = $this->getAdapter();
$set = array (
'name' => '蝶影重重',
'clicks' => '888',
);
$where = $db->quoteInto('id = ?', '10');// where语句
// 更新表数据,返回更新的行数
echo $rows_affected = $db->update($table, $set, $where);

第二种方法:只能更新本表中的

$set = array (
'name' => '蝶影重重22',
'clicks' => '8880',
);
$db = $this->getAdapter();
$where = $db->quoteInto('id = ?', '10');// where语句
$rows_affected = $this->update($set, $where);// 更新表数据,返回更新的行数

(4)数据插入总结

第一种方法:可以在任意表中插入数据

$table = 'm_gao';// 插入数据的数据表
$db = $this->getAdapter();
// 以"列名"=>"数据"的格式格式构造插入数组,插入数据行
$row = array (
'title'   => '大家好。111',
'content' => '影视网要改成用zend framework开发啊',
'time' => '2009-05-04 17:23:36',
);
// 插入数据行并返回插入的行数
$rows_affected = $db->insert($table, $row);
// 最后插入的数据id
echo $last_insert_id = $db->lastInsertId();
$row=array(
'name'=>'curdate()',
'address' => new Zend_Db_Expr ('curdate()')
)

这样子字段name会插入一个curdate()的字符串,而address插入一个时间值(curdate()的结果2009-05-09)

第二种方法:只能适合本表中的还没有总结出来

(5)事务处理

$table = 'm_gao';// 插入数据的数据表
$db = $this->getAdapter();
$db->beginTransaction();//Zend_Db_Adapter会回到自动commit模式下,直到你再次调用 beginTransaction()方法
// 以"列名"=>"数据"的格式格式构造插入数组,插入数据行
$row = array (
'id'=>null,
'title'   => '大家好。111',
'content' => '影视网要改成用zend framework开发啊',
'time' => '2009-05-04 17:23:36',
);
try {
// 插入数据行并返回插入的行数
$rows_affected = $db->insert($table, $row);
// 最后插入的数据id
$last_insert_id = $db->lastInsertId();
$db->commit();// 事务提交
}catch (Exception $e){
$db->rollBack();
echo '捕获异常:'.$e->getMessage();//打出异常信息
}
echo $last_insert_id;

(6)其他

$db = $this->getAdapter();
$tables = $db->listTables(); //列出当前数据库中的所有表
$fields = $db->describeTable('m_video');//列出一个表的字段情况

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

PHP 相关文章推荐
php htmlspecialchars加强版
Feb 16 PHP
用php或asp创建网页桌面快捷方式的代码
Mar 23 PHP
CI(CodeIgniter)框架配置
Jun 10 PHP
php实现的用户查询类实例
Jun 18 PHP
在Linux系统下一键重新安装WordPress的脚本示例
Jun 30 PHP
PHP检测用户是否关闭浏览器的方法
Feb 14 PHP
常用PHP封装分页工具类
Jan 14 PHP
PHP中Laravel 关联查询返回错误id的解决方法
Apr 01 PHP
PHP实现的DES加密解密封装类完整实例
Apr 29 PHP
laravel 解决强制跳转 https的问题
Oct 22 PHP
利用PHP内置SERVER开启web服务(本地开发使用)
Jan 22 PHP
PHP如何通过带尾指针的链表实现'队列'
Oct 22 PHP
php基于ob_start(ob_gzhandler)实现网页压缩功能的方法
Feb 18 #PHP
PHP开发APP端微信支付功能
Feb 17 #PHP
php+webSoket实现聊天室示例代码(附源码)
Feb 17 #PHP
PHP中检索字符串的方法分析【strstr与substr_count方法】
Feb 17 #PHP
PHP常用的三种设计模式
Feb 17 #PHP
轻松实现php文件上传功能
Feb 17 #PHP
php自定义函数br2nl实现将html中br换行符转换为文本输入中换行符的方法【与函数nl2br功能相反】
Feb 17 #PHP
You might like
一步一步学习PHP(2)――PHP类型
2010/02/15 PHP
让PHP开发者事半功倍的十大技巧小结
2010/04/20 PHP
php过滤所有恶意字符(批量过滤post,get敏感数据)
2014/03/18 PHP
PHP面向对象程序设计模拟一般面向对象语言中的方法重载(overload)示例
2019/06/13 PHP
根据当前时间在jsp页面上显示上午或下午
2014/08/18 Javascript
JS实现统计复选框选中个数并提示确定与取消的方法
2015/07/01 Javascript
JavaScript位移运算符(无符号) &gt;&gt;&gt; 三个大于号 的使用方法详解
2016/03/31 Javascript
Node.js 文件夹目录结构创建实例代码
2016/07/08 Javascript
使用bootstrap插件实现模态框效果
2017/05/10 Javascript
AngularJS中的promise用法分析
2017/05/19 Javascript
JS实现的随机排序功能算法示例
2017/06/09 Javascript
解决webpack打包速度慢的解决办法汇总
2017/07/06 Javascript
jQuery制作全屏宽度固定高度轮播图(实例讲解)
2017/07/08 jQuery
AjaxFileUpload.js实现异步上传文件功能
2019/04/19 Javascript
Vue基本使用之对象提供的属性功能
2019/04/30 Javascript
vuex的使用和简易实现
2021/01/07 Vue.js
Python3中使用PyMongo的方法详解
2017/07/28 Python
Python数据分析之如何利用pandas查询数据示例代码
2017/09/01 Python
tensorflow实现简单的卷积网络
2018/05/24 Python
python 平衡二叉树实现代码示例
2018/07/07 Python
启动Atom并运行python文件的步骤
2018/11/09 Python
Python使用paramiko操作linux的方法讲解
2019/02/25 Python
python 实现GUI(图形用户界面)编程详解
2019/07/17 Python
python list多级排序知识点总结
2019/10/23 Python
解决numpy矩阵相减出现的负值自动转正值的问题
2020/06/03 Python
django haystack实现全文检索的示例代码
2020/06/24 Python
如何用Python绘制3D柱形图
2020/09/16 Python
Html5 实现微信分享及自定义内容的流程
2019/08/20 HTML / CSS
SQL Server的固定数据库角色都有哪些?对应的服务器权限有哪些?
2013/05/18 面试题
小学母亲节活动方案
2014/03/14 职场文书
片区教研活动总结
2014/07/02 职场文书
2014年社区个人工作总结
2014/12/02 职场文书
大三学生英语考试作弊检讨书
2015/01/01 职场文书
创业计划书之婴幼儿游泳馆
2019/09/11 职场文书
如何使用JavaScript策略模式校验表单
2021/04/29 Javascript
【海涛解说】pis亲自推荐,其实你从来不会玩NW
2022/04/01 DOTA