pdo 整套类的封装,保存修改查询
<?php
/**
*
*/
class Db{
private $host = '';
private $port = '';
private $user = '';
private $pass = '';
private $dbname = '';
private $charset='';
private $tbp = '';
private $db = '';
/**
* 返回 pdo对象
*/
public function getDb(){
return $this->db;
}
/**
* @param $tbp 表名前辍
*/
public function setTbp($tbp=''){
$this->tbp = $tbp;
}
public function __construct($host='localhost',$port='3306',$user='root',$pass='',$dbname='fzdb',$charset='utf8',$tbp='fz_'){
$dsn = "mysql:host=$host;port=$port;dbname=$dbname";
$opt = [1002 =>"set names $charset"];
try {
$this->db = new PDO ( $dsn, 'root', '', $opt );
$this->host = $host;
$this->port = $port;
$this->user = $user;
$this->pass = $pass;
$this->dbname = $dbname;
$this->tbp = $tbp;
$this->charset = $charset;
} catch ( Exception $e ) {
exit ( '数据库服务器连接失败,程序终止' );
}
}
/**
*
* @param unknown $t 表名,不含执行时会自动加上表前辍
* @param unknown $d 要插入的数据是关联数组
*/
public function gomsg($url='',$msg=''){
echo '<script>';
echo "alert('$msg');";
echo "location.href='$url'";
echo '</script>';
}
public function save($t,$d){
$t = $this->tbp.$t;
foreach($d as $key=>$v){
$kk[] = $key;
$vv[] = ':'.$key;
}
$kk = implode(',',$kk);
$vv = implode(',',$vv);
$stmt = $this->db->prepare("insert into $t($kk) values($vv)");
$stmt->execute($d);
$stmt->closeCursor();
}
public function query($t,$f='*',$w='1=1',$o='',$l='limit 10'){
$t = $this->tbp.$t;
$stmt = $this->db->prepare("select $f from $t where $w $o $l");
$stmt->execute();
$rs = $stmt->fetchAll(PDO::FETCH_ASSOC);
$stmt->closeCursor();
return $rs;
}
public function delete($t,$w='1=1'){
$t = $this->tbp.$t;
$stmt = $this->db->prepare("delete from $t where $w");
$stmt->execute();
$stmt->closeCursor();
}
public function getcount($t,$w='1=1'){
$t = $this->tbp.$t;
$stmt = $this->db->prepare("select count(*) from $t where $w");
$stmt->execute();
$stmt->bindColumn(1, $c);
$stmt->fetchAll(PDO::FETCH_NUM);
return $c;
}
public function updatenum($t,$f,$w='1=1'){
$t = $this->tbp.$t;
$stmt = $this->db->prepare("update $t set $f where $w");
$stmt->execute();
$stmt->closeCursor();
}
public function pager($t,$currpage=1,$f='*',$pagesize=3,$w='1=1',$o='',$ty=''){
$recordcount = $this->getcount($t,$w);
$t = $this->tbp.$t;
$stmt = $this->db->prepare("select $f from $t where $w $o limit ?,?");
$pagecount = ceil($recordcount/$pagesize);
$currpage = $currpage<1 ? 1 : $currpage;
$currpage = $currpage>$pagecount ? $pagecount : $currpage;
$start = $currpage*$pagesize - $pagesize;
$stmt->bindParam(1, $start, PDO::PARAM_INT);
$stmt->bindParam(2, $pagesize, PDO::PARAM_INT);
$stmt->execute();
$row[] = $stmt->fetchAll(PDO::FETCH_ASSOC);
$first = 1;
$end = 10;
$pages = '<div class="page">';
if($currpage>=7){
$first = $currpage-5;
$end = $first+$end-1;
}
if($currpage>1){
$prev = $currpage-1;
if($first>1){
$pages.="<a href=?".$ty."p=1>首页</a><a href=?".$ty."p=$prev>上一页</a>";
}else{
$pages.="<a href=?".$ty."p=$prev>上一页</a>";
}
}
for($i=$first;$i<=$end;$i++){
if($i>$pagecount){
break;
}
if($i==$currpage){
$pages.='<a class="checked">'.$i.'</a>';
continue;
}
$pages.="<a href=?".$ty."p=$i>$i</a>";
}
if($currpage<$pagecount){
$next = $currpage+1;
$pages.="<a href=?".$ty."p=$next>下一页</a>";
}
if($end<$pagecount){
$pages.="<a href=?".$ty."p=$pagecount>尾页</a>";
}
$row[] = $pages.'</div>';
$row[] = $pagesize;
$row[] = $pagecount;
$row[] = $recordcount;
$row[] = $currpage;
return $row;
}
public function css1(){
$css = <<<css
<style>
.page{font-size:12px;height:30px;padding:15px 0;clear:both;overflow:hidden;text-align:center;}
.page a{text-decoration:none;line-height:25px;padding:0px 10px;display:inline-block;margin-right:5px;border:solid 1px #c8c7c7;}
.page a:hover,.page a.checked{text-decoration:none;border:solid 1px #0086d6;background:#0091e3;color:#fff;}
.page a:visited,.page a:link{color:#333;}
.page a:active{color:#3B3B3B;}
</style>
css;
echo $css;
}
public function md5($p,$c='webrx'){
$s1 = md5($p.$c);
$s2 = sha1($p.$c);
$sok = substr($s1,0,6).substr($s2,0,6);
$sok .= substr($s1,12,5).substr($s2,22,5);
$sok .= substr($s1,22,5).substr($s2,32,5);
return $sok;
}
public function update($t,$d,$w='1=1'){
$t = $this->tbp.$t;
foreach($d as $key=>$v){
$kk[] = $key.'=:'.$key;
}
$kk = implode(',',$kk);
$stmt = $this->db->prepare("update $t set $kk where $w");
$stmt->execute($d);
$stmt->closeCursor();
}
public function __destruct(){
unset($this->db);
}
}
pdo 整套类的封装,保存修改查询的更多相关文章
- 一个强大的封装好的pdo处理类
php5.5后就不支持mysql扩展了,也就是说这以后都不能使用msyql_conncet之类的函数了.不过没有关系,pdo比mysql有更多优势,写法也很简单,下面贴出一个来自互联网的pdo处理类. ...
- Java—类的封装、继承与多态
一.类和对象 1.类 类是数据以及对数据的一组操作的封装体. 类声明的格式: 类声明 { 成员变量的声明: 成员方法的声明及实现: } 1.1 声明类 [修饰符] class 类<泛型> ...
- Java---对象与类的封装
一.类和对象: package cn.hncu.Myclasslearn; /** * * @author hncu_chx * * Mylove amin */ /**类是一种数据类型,声明一个类就 ...
- PHP 类的封装和使用
类:相似的数据和数据操作的封装 class 成员量:普通的量加上一定的修饰就变成了成员量 public,protected,private 成员方法:普通的函数,加上一定的修饰,放入到类中就变成了成 ...
- 类的封装(property)
封装 封装程序的主要原因:保护隐私:而封装方法的主要原因是:隔离复杂的执行过程 property的特性 将一个类的函数定义成特性以后,对象再去使用的时候obj.name,根本无法察觉自己的name是执 ...
- 关于PHP建立数据库访问类的封装以及操作php单例模式连接数据库封装类
建立数据库访问类的封装 <?php class DBDA { public $host = "localhost"; //服务器地址 public $ui ...
- 模块的封装之C语言类的封装
[微知识]模块的封装(一):C语言类的封装 是的,你没有看错,我们要讨论的是C语言而不是C++语言中类的封装.在展开知识点之前,我首先要 重申两点: 1.面向对象是一种思想,基本与所用的语言是无关的. ...
- 第三篇 :微信公众平台开发实战Java版之请求消息,响应消息以及事件消息类的封装
微信服务器和第三方服务器之间究竟是通过什么方式进行对话的? 下面,我们先看下图: 其实我们可以简单的理解: (1)首先,用户向微信服务器发送消息: (2)微信服务器接收到用户的消息处理之后,通过开发者 ...
- 025医疗项目-模块二:药品目录的导入导出-HSSF导入类的封装
上一篇文章提过,HSSF的用户模式会导致读取海量数据时很慢,所以我们采用的是事件驱动模式.这个模式类似于xml的sax解析.需要实现一个接口,HSSFListener接口. 原理:根据excel底层存 ...
随机推荐
- Kettle使用介绍
本文主要阅读目录如下: 1.Kettle概念 2.下载和部署 3.Kettle环境配置 4.Kettle使用及组件介绍 ETL(Extract-Transform-Load的缩写,即数据抽取.转换.装 ...
- Oracle 使用SqlPlus管理
Oracle 使用SqlPlus 安装,一键安装,很简单.安装过程,一定要记住密码 一.登陆sqlplus 连接本地服务器,可以直接,打开cmd: 可以直接不用登陆,如果登陆需要输入用户名.密码. s ...
- spring事务传播机制与隔离级别、通知类别
Spring在TransactionDefinition接口中规定了7种类型的事务传播行为, 它们规定了事务方法和事务方法发生嵌套调用时事务如何进行传播: 事务传播行为类型 说明 PROPAGATIO ...
- 如何使用openssl生成RSA公钥和私钥对
在ubuntu上要使用openssl的话需要先进行安装,命令如下: sudo apt-get install openssl 安装完成就可以使用openssl了. 首先需要进入openssl的交互 ...
- Mysql无法创建外键的原因
在Mysql中创建外键时,经常会遇到问题而失败,这是因为Mysql中还有很多细节需要我们去留意,我自己总结并查阅资料后列出了以下几种常见原因. 1. 两个字段的类型或者大小不严格匹配.例如,如果一个 ...
- 【DNS】简单聊聊DNS如何工作
随便聊聊 我们知道,网络上传输的数据包是一层一层的包起来的,典型的是mac地址层,ip层,tcp/udp层,应用层数据 这么几个层,那用户在浏览器中打开www.baidu.com数据包如何传到baid ...
- 【MySQL】排序原理与案例分析
前言 排序是数据库中的一个基本功能,MySQL也不例外.用户通过Order by语句即能达到将指定的结果集排序的目的,其实不仅仅是Order by语句,Group by语句,Distinct语句都会隐 ...
- Windows Server 2008配置服务器证书[转载]
备忘 http://wangchunhai.blog.51cto.com/225186/139451
- Java lamda Stream
Intermediate:一个流可以后面跟随零个或多个 intermediate 操作.其目的主要是打开流,做出某种程度的数据映射/过滤,然后返回一个新的流,交给下一个操作使用.这类操作都是惰性化的( ...
- Windows消息机制详解
消息是指什么? 消息系统对于一个win32程序来说十分重要,它是一个程序运行的动力源泉.一个消息,是系统定义的一个32位的值,他唯一的定义了一个事件,向 Windows发出一个通知,告诉应用 ...