PHP基于单例模式实现的mysql类_PHP
php
单例模式
本文实例讲述了PHP基于单例模式实现的mysql类。分享给大家供大家参考,具体如下:
<?php defined('ACC')||exit('Access Denied'); // 封装mysql操作类,包括连接功能,及查询功能. class mysql extends absdb{ protected static $ins = null; protected $host; // 主机名 protected $user; // 用户名 protected $passwd; // 密码 protected $db; // 数据库名 protected $port; // 端口 protected $conn = null; // 在内部操作,获得一个对象 public static function getIns() { if(self::$ins === null) { self::$ins = new self(); } $conf = conf::getIns(); self::$ins->host = $conf->host; self::$ins->user = $conf->user; self::$ins->passwd = $conf->pwd; self::$ins->db = $conf->db; self::$ins->port = $conf->port; self::$ins->connect(); self::$ins->select_db(); self::$ins->setChar(); return self::$ins; } // 不让外部做new操作, protected function __construct() { } // 连接数据库 public function connect() { $this->conn = @mysql_connect($this->host,$this->user,$this->passwd,$this->port); if(!$this->conn) { $error = new Exception('数据库连不上',9); throw $error; } } // 发送sql查询 public function query($sql) { $rs = mysql_query($sql,$this->conn); if(!$rs) { log::write($sql); } return $rs; } // 封装一个getAll方法 // 参数:$sql // 返回: array,false public function getAll($sql) { $rs = $this->query($sql); if(!$rs) { return false; } $list = array(); while($row = mysql_fetch_assoc($rs)) { $list[] = $row; } return $list; } // 封装一个getRow方法 // 参数:$sql // 返回: array,false public function getRow($sql) { $rs = $this->query($sql); if(!$rs) { return false; } return mysql_fetch_assoc($rs); } // 封装一个getOne方法, // 参数: $sql // 返回: int,str(单一的值) public function getOne($sql) { $rs = $this->query($sql); if(!$rs) { return false; } $tmp = mysql_fetch_row($rs); return $tmp[0]; } // 封装一个afftect_rows()方法 // 参数:无 // 返回 int 受影响行数 public function affected_rows() { return mysql_affected_rows($this->conn); } // 返回最新生成的auto_increment列的值 public function last_id() { return mysql_insert_id($this->conn); } // 选库函数 public function select_db() { $sql = 'use ' . $this->db; return $this->query($sql); } // 设置字符集的函数 public function setChar() { $sql = 'set names utf8'; return $this->query($sql); } // 自动生成insert语句,update语句并执行 public function autoExecute($data,$table,$act='insert',$where='') { if($act == 'insert') { $sql = 'insert into ' . $table . ' ('; $sql .= implode(',',(array_keys($data))); $sql .= ') values (\''; $sql .= implode("','",array_values($data)); $sql .= "')"; } else if($act == 'update') { if(!trim($where)) { return false; } $sql = 'update ' . $table . ' set '; foreach($data as $k=>$v) { $sql .= $k; $sql .= '='; $sql .= "'".$v."',"; } $sql = substr($sql,0,-1); $sql .= ' where '; $sql .= $where; } else { return false; } //return $sql; return $this->query($sql); } }
登录后复制
更多关于PHP数据库操作相关内容感兴趣的读者可查看本站专题:《php+mysql数据库操作入门教程》、《PHP基于pdo操作数据库技巧总结》及《php常见数据库操作技巧汇总》
希望本文所述对大家PHP程序设计有所帮助。
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章
仓库:如何复兴队友
1 个月前
By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶体解释及其做什么(黄色晶体)
2 周前
By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
1 个月前
By 尊渡假赌尊渡假赌尊渡假赌
击败分裂小说需要多长时间?
4 周前
By DDD
R.E.P.O.保存文件位置:在哪里以及如何保护它?
4 周前
By DDD

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

PHP 8.4 带来了多项新功能、安全性改进和性能改进,同时弃用和删除了大量功能。 本指南介绍了如何在 Ubuntu、Debian 或其衍生版本上安装 PHP 8.4 或升级到 PHP 8.4

CakePHP 是 PHP 的开源框架。它的目的是使应用程序的开发、部署和维护变得更加容易。 CakePHP 基于类似 MVC 的架构,功能强大且易于掌握。模型、视图和控制器 gu

Visual Studio Code,也称为 VS Code,是一个免费的源代码编辑器 - 或集成开发环境 (IDE) - 可用于所有主要操作系统。 VS Code 拥有针对多种编程语言的大量扩展,可以轻松编写
