仓酷云

标题: PHP网站制作之一个基于PDO的数据库操作类(新) 一个PD... [打印本页]

作者: 莫相离    时间: 2015-2-3 23:37
标题: PHP网站制作之一个基于PDO的数据库操作类(新) 一个PD...
熟悉了PHP和MYSQL开发的要领之后,再回头看你写的那个留言本,你也许会怀疑那真的是你写的吗?当然,如果屋里还有鬼的话,也许是它写的-_-   复制代码 代码以下:
<?php
/*
* 作者:胡睿
* 日期:2011/03/19
* 电邮:hooray0905@foxmail.com
*
* 20110319
* 经常使用数据库操作,如:增删改查,获得单笔记录、多笔记录,前往最新一条拔出纪录id,前往操作纪录行数等
* 20110630
* 全体修正办法,兼并局部参数
* 标准代码,一个办法里只要1个return语句
*/
/*
参数申明
int $debug 是不是开启调试,开启则输入sql语句
int $mode 0 前往数组
1 前往单笔记录
2 前往行数
string $table 数据库表
string $fields 需求查询的数据库字段,答应为空,默许为查找全体
string $sqlwhere 查询前提,答应为空
string $orderby 排序,答应为空,默许为id倒序
*/
function hrSelect($debug, $mode, $table, $fields="*", $sqlwhere="", $orderby="id desc"){
global $pdo;
if($debug){
if($mode == 2){
echo "select count(*) from $table where 1=1 $sqlwhere order by $orderby";
}elseif($mode == 1){
echo "select $fields from $table where 1=1 $sqlwhere";
}else{
echo "select $fields from $table where 1=1 $sqlwhere order by $orderby";
}
exit;
}else{
if($mode == 2){
$rs = $pdo->query("select count(*) from $table where 1=1 $sqlwhere order by $orderby");
$return = $rs->fetchColumn();
}elseif($mode == 1){
$rs = $pdo->query("select $fields from $table where 1=1 $sqlwhere");
$return = $rs->fetch();
}else{
$rs = $pdo->query("select $fields from $table where 1=1 $sqlwhere order by $orderby");
$return = $rs->fetchAll();
}
return $return;
}
}
/*
参数申明
int $debug 是不是开启调试,开启则输入sql语句
int $mode 0 默许insert,无前往信息
1 前往履行条目数
2 前往最初一次拔出纪录的id
string $table 数据库表
string $fields 需求拔出数据库的字段
string $values 需求拔出数据库的信息,必需与$fields逐一对应
*/
function hrInsert($debug, $mode, $table, $fields, $values){
global $pdo;
if($debug){
echo "insert into $table ($fields) values ($values)";
exit;
}else{
if($mode == 2){
$return = $pdo->lastInsertId("insert into $table ($fields) values ($values)");
}elseif($mode == 1){
$return = $pdo->exec("insert into $table ($fields) values ($values)");
}else{
$pdo->query("insert into $table ($fields) values ($values)");
exit;
}
return $return;
}
}
/*
参数申明
int $debug 是不是开启调试,开启则输入sql语句
int $mode 0 默许update,无前往信息
1 前往履行条目数
string $table 数据库表
string $set 需求更新的字段及内容,格局:a='abc',b=2,c='2010-10-10 10:10:10'
string $sqlwhere 修正前提,答应为空
*/
function hrUpdate($debug, $mode, $table, $set, $sqlwhere=""){
global $pdo;
if($debug){
echo "update $table set $set where 1=1 $sqlwhere";
exit;
}else{
if($mode==1){
$return = $pdo->exec("update $table set $set where 1=1 $sqlwhere");
}else{
$pdo->query("update $table set $set where 1=1 $sqlwhere");
exit;
}
return $return;
}
}
/*
参数申明
int $debug 是不是开启调试,开启则输入sql语句
int $mode 0 默许delete,无前往信息
1 前往履行条目数
string $table 数据库表
string $sqlwhere 删除前提,答应为空
*/
function hrDelete($debug, $mode, $table, $sqlwhere=""){
global $pdo;
if($debug){
echo "delete from $table where 1=1 $sqlwhere";
exit;
}else{
if($mode == 1){
$return = $pdo->exec("delete from $table where 1=1 $sqlwhere");
}else{
$pdo->query("delete from $table where 1=1 $sqlwhere");
exit;
}
return $return;
}
}
?>

别的一段代码是基于我这个数据库操作类的事务虚例:
复制代码 代码以下:
/*
注重,数据库操作表类型必需为InnoDB,其他类型不撑持事务
PDO事务机制
$pdo->beginTransaction(); --开启事务
$pdo->commit(); --停止事务
$pdo->rollBack(); --回滚操作

示例,用try/catch包住db操作,当事务内的db操作呈现中止,则履行回滚并抛出异常信息。
*/
try{
$pdo->beginTransaction();
hrInsert(0,1,"class","name,parentid","'god',0"); //可以正常履行
hrInsert(0,0,0,"tb_searchlog","userid,code","4"); //失足
$pdo->commit();
}catch(Exception $e){
$pdo->rollBack();
echo "Failed: " . $e->getMessage();
}

代码下载:点击下载在学习中,我也一直这样要求着自己。
作者: 小魔女    时间: 2015-2-4 03:50
Apache不是非得用80或者8080端口的,我刚开始安得时候就是80端口老占用,就用了个 81端口,结果照常,就是输localhost的时候,应该输入为 localhost:81
作者: 莫相离    时间: 2015-2-9 14:50
Ps:以上纯属原创,如有雷同,纯属巧合
作者: 仓酷云    时间: 2015-2-27 07:42
至于模板嘛,各位高人一直以来就是争论不休,我一只小菜鸟就不加入战团啦,咱们新手还是多学点东西的好。
作者: 山那边是海    时间: 2015-3-1 13:47
因为blog这样的可以让你接触更多要学的知识,可以接触用到类,模板,js ,ajax
作者: 变相怪杰    时间: 2015-3-2 17:10
本文当是我的笔记啦,遇到的问题随时填充
作者: 活着的死人    时间: 2015-3-7 14:00
有时候汉字的空格也能导致页面出错,所以在写代码的时候,要输入空格最好用引文模式。
作者: 飘灵儿    时间: 2015-3-15 07:28
做为1门年轻的语言,php一直很努力。
作者: 再见西城    时间: 2015-3-17 00:06
先学习php和mysql,还有css(html语言很简单)我认为现在的效果比以前的方法好。
作者: 透明    时间: 2015-3-23 07:14
当留言板完成的时候,下步可以把做1个单人的blog程序,做为目标,
作者: 分手快乐    时间: 2015-4-1 07:10
因为blog这样的可以让你接触更多要学的知识,可以接触用到类,模板,js ,ajax
作者: 第二个灵魂    时间: 2015-4-4 05:32
你很难利用原理去编写自己的代码。对于php来说,系统的学习我认为还是很重要的,当你有一定理解后,你可你针对某种效果研究,我想那时你不会只是复制代码的水平了。
作者: 小女巫    时间: 2015-4-9 04:56
首先声明:我是一个菜鸟,是一个初学者。学习了一段php后总是感觉自己没有提高,无奈。经过反思我认为我学习过程中存在很多问题,我改变了学习方法后自我感觉有了明显的进步。
作者: 谁可相欹    时间: 2015-4-10 07:01
为了以后维护的方便最好是代码上都加上注释,“予人方便,自己方便”。此外开发文档什么的最好都弄齐全。我觉得这是程序员必备的素质。虽然会消耗点很多的时间。但是确实是非常有必要的。
作者: 再现理想    时间: 2015-4-14 04:03
个人呢觉得,配wamp 最容易漏的一步就是忘了把$PHP$目录下的libmysql.dll拷贝到windows系统目录的system32目录下,还有重启apache。
作者: 愤怒的大鸟    时间: 2015-4-16 14:01
曾经犯过一个很低级的错误,我在文件命名的时候用了一个横线\\\\\\\'-\\\\\\\' 号,结果找了好几个小时的错误,事实是命名的时候 是不能用横线 \\\\\\\'-\\\\\\\' 的,应该用的是下划线  \\\\\\\'_\\\\\\\' ;
作者: 小妖女    时间: 2015-4-21 17:43
兴趣是最好的老师,百度是最好的词典。
作者: 不帅    时间: 2015-4-22 11:15
先学习php和mysql,还有css(html语言很简单)我认为现在的效果比以前的方法好。
作者: 柔情似水    时间: 2015-4-27 08:54
我要在声明一下:我是个菜鸟!!我对php这门优秀的语言也是知之甚少。但是我要在这里说一下php在网站开发中最常用的几个功能:
作者: 蒙在股里    时间: 2015-5-7 04:24
其实没啥难的,多练习,练习写程序,真正的实践比看100遍都有用。不过要熟悉引擎




欢迎光临 仓酷云 (http://ckuyun.com/) Powered by Discuz! X3.2