<?php
class MySQLDB {
private $host; // 主机地址
private $port; // 端口号
private $user; // 用户名
private $pwd; // 密码
private $dbname; // 数据库名
private $charset; // 字符集
private $link; // 连接对象
private static $instance;
private function __construct($param){
$this->initParam($param);
$this->initConnect();
}
private function __clone(){
}
// 获取单例
public static function getInstance($param= array()){
if(!self::$instance instanceof self){
self::$instance= new self($param);
}
return self::$instance;
}
// 初始化参数
private function initParam($param){
$this->host= $param['host']??'127.0.0.1';
$this->port= $param['port']??'3306';
$this->user= $param['user']??'';
$this->pwd= $param['pwd']??'';
$this->dbname= $param['dbname']??'';
$this->charset= $param['charset']??'utf8';
}
// 连接数据库
private function initConnect(){
$this->link= @mysqli_connect($this->host, $this->user, $this->pwd, $this->dbname, $this->port);
if(mysqli_connect_error()){
echo '数据库连接失败<br>';
echo '错误信息:'.mysqli_connect_error(),'<br>';
echo '错误码:'.mysqli_connect_errno(),'<br>';
exit;
}else{
echo '数据库连接成功!';
}
mysqli_set_charset($this->link, $this->charset);
}
// 数据库的增删改查
private function execute($sql){
if(!$rs= mysqli_query($this->link, $sql)){
echo 'SQL语句执行失败<br>';
echo '错误信息:'.mysqli_error($this->link),'<br>';
echo '错误码:'.mysqli_errno($this->link),'<br>';
echo '错误的SQL语句:'.$sql,'<br>';
exit;
}
return $rs;
}
// 执行增删改语句
public function exec($sql) {
$key=substr($sql,0,6);
if(in_array($key,array('insert','update','delete')))
return $this->execute($sql);
else{
echo '非法访问<br>';
exit;
}
}
//获取自动增长的编号
public function getLastInsertId() {
return mysqli_insert_id($this->link);
}
//执行查询语句
private function query($sql) {
if(substr($sql,0,6)=='select' || substr($sql,0,4)=='show' || substr($sql,0,4)=='desc'){
return $this->execute($sql);
}else{
echo '非法访问<br>';
exit;
}
}
//匹配所有数据
public function fetchAll($sql,$type='assoc') {
$rs=$this->query($sql);
$type=$this->getType($type);
return mysqli_fetch_all($rs,$type);
}
//匹配一维数组
public function fetchRow($sql,$type='assoc') {
$list=$this->fetchAll($sql,$type);
if(!empty($list))
return $list[0];
return array();
}
//匹配一行一列
public function fetchColumn($sql) {
$list=$this->fetchRow($sql,'num');
if(!empty($list))
return $list[0];
return null;
}
//获取匹配类型
private function getType($type) {
switch($type){
case 'num':
return MYSQLI_NUM;
case 'both':
return MYSQLI_BOTH;
default:
return MYSQLI_ASSOC;
}
}
}
$param= array(
'user' => 'root',
'pwd' => '',
'dbname' => 'sel'
);
$db= MySQLDB::getInstance($param);
// 查询所有信息
$listAll= $db->fetchAll('select * from news');
var_dump($listAll);
// 查询一条记录
$listRow= $db->fetchRow('select * from news');
var_dump($listRow);
// 查询一个字段
$listColumn= $db->fetchColumn('select * from news');
var_dump($listColumn);
?>