仓酷云

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 830|回复: 19
打印 上一主题 下一主题

[学习教程] PHP网站制作之一个基于PDO的数据库操作类(新) 一个PD...

[复制链接]
莫相离 该用户已被删除
跳转到指定楼层
#
发表于 2015-2-3 23:37:07 | 只看该作者 回帖奖励 |正序浏览 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
熟悉了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();
}

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

本版积分规则

QQ|Archiver|手机版|仓酷云 鄂ICP备14007578号-2

GMT+8, 2024-11-11 07:02

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表