设计目标:
  1,该类一实例化,就可以自动连接上mysql数据库;
  2,该类可以单独去设定要使用的连接编码(set names XXX)
  3,该类可以单独去设定要使用的数据库(use XXX);
  4,可以主动关闭连接;

<?php
/*
设计一个类:mysql数据库操作类
设计目标:
1,该类一实例化,就可以自动连接上mysql数据库;
2,该类可以单独去设定要使用的连接编码(set names XXX)
3,该类可以单独去设定要使用的数据库(use XXX);
4,可以主动关闭连接;
*/
class MySqlDB{
// 链接资源
private $link = null; // 构造方法
function __construct($host='localhost', $port=3306, $user='root', $pwd='', $charset='utf8', $dbName='mysql'){
$this->link = @mysql_connect("$host:$port", $user, $pwd); // @:阻止警告输出
mysql_query("set names $charset"); // 设置编码
mysql_query("use $dbName"); // 设置使用的数据库
} // 可设置链接编码
function setCharset($charset){
mysql_query("set names $charset");
} // 可设置使用的数据库
function selectDB($dbName){
mysql_query("use $dbName");
} // 可关闭链接
function closeDB(){
mysql_close($this->link);
}
} # ************************* 测试 *************************
$host = 'localhost';
$port = 3306;
$user = 'root';
$pwd = '123456';
$charset = 'utf8';
$dbname = 'db1'; $db = new MySqlDB($host, $port, $user, $pwd, $charset, $dbname); // 测试是否链接成功
$set = mysql_query("select * from student");
var_dump($set);
echo "<br>"; // 测试修改编码
$db->setCharset('gbk'); //********** 显示数据 **********
echo "<table border='1'>";
echo "<tr>";
// 获得列数
$field_count = mysql_num_fields($set);
for($i=0; $i<$field_count; $i++){
// 获得第 i 列的名称
$field_name = mysql_field_name($set, $i);
echo "<td>". $field_name . "</td>";
}
echo "</tr>";
// 遍历每一行记录
while($rec = mysql_fetch_array($set)){
echo "<tr>"; for($i=0; $i<$field_count; $i++){
// 获取列名
$field_name = mysql_field_name($set, $i);
// 获取该记录,改行的数据
echo "<td>" . $rec[$field_name] . "</td>";
} echo "</tr>";
} echo "</table>"; // ********* end ********** // 测试关闭链接
$db->closeDB();
$set = @mysql_query("select * from student");
var_dump($set);
echo "<br>"; ?>

改进: 使用单例

<?php
/*
设计一个类:mysql数据库操作类
设计目标:
1,该类一实例化,就可以自动连接上mysql数据库;
2,该类可以单独去设定要使用的连接编码(set names XXX)
3,该类可以单独去设定要使用的数据库(use XXX);
4,可以主动关闭连接;
*/ class MySQLDB{
private $link = null; // 用于存储成功链接后的资源 // 属性, 存储链接数据库的基本信息
private $host;
private $port;
private $user;
private $pwd;
private $charset;
private $dbname; // 1)私有化构造方法
private function __construct($config){
// 保存链接的基本信息
$this->host = !empty($config['host']) ? $config['host'] : "localhost";
$this->port = !empty($config['port']) ? $config['port'] : "3306";
$this->user = !empty($config['user']) ? $config['user'] : "root";
$this->pwd = !empty($config['pwd']) ? $config['pwd'] : "";
$this->charset = !empty($config['charset']) ? $config['charset'] : "utf8";
$this->dbname = !empty($config['dbname']) ? $config['dbname'] : "mysql"; // 链接数据库
$this->link = mysql_connect("{$this->host}:{$this->port}", "$this->user", "$this->pwd")
or die("链接失败"); // 设定编码
//mysql_query("set names {$config['charset']}");
$this->setCharset($config['charset']); // 设定要使用的数据库名
//mysql_query("use {$config['dbname']}");
$this->selectDB($config['dbname']);
} // 2)单例, 存储唯一实例
private static $instance = null; // 3)静态方法,获取唯一实例
static function GetInstance($config){
//if(!isset(self::$instance)){ // ==>等价于
if(!(self::$instance instanceof self)){ // 更常用
self::$instance = new self($config); // 创建并保存起来
}
return self::$instance;
} // 4)私有化克隆方法
private function __clone(){} // 可设定要使用的编码
function setCharset($charset){
mysql_query("set names $charset", $this->link);
} // 可设定要使用的数据库
function selectDB($dbname){
mysql_query("use $dbname", $this->link);
} // 可关闭数据库链接
function closeDB(){
mysql_close($this->link);
} // 执行 sql 语句,进行错误处理,并返回结果
private function query($sql){
$result = mysql_query($sql, $this->link);
if($result === false){
// 失败处理
echo "sql语句执行失败,请参考如下信息:";
echo "<br />错误代码: " . mysql_errno();
echo "<br />错误信息: " . mysql_error();
echo "<br />错误语句: " . $sql;
die();
}
return $result;
} // 执行一条 增删改 sql语句,返回真或假
function exec($sql){
$result = $this->query($sql);
return true;
} // 执行一条 sql 语句,返回一行记录
function getOneRow($sql){
$result = $this->query($sql);
$rec = mysql_fetch_assoc($result);
// 提前销毁结果集,否则需要等待页面结束才能自动销毁
mysql_free_result($result);
return $rec;
} // 执行一条 sql 语句,返回多行记录
function getRows($sql){
$result = $this->query($sql);
$arr = array();
while($rec = mysql_fetch_assoc($result)){
$arr[] = $rec; // 二维数组
} mysql_free_result($result);
return $arr;
} // 执行一条 sql 语句,直接返回一个结果
// 类似于: select count(*) as c from user_list
function getOneData($sql){
$result = $this->query($sql);
$rec = mysql_fetch_row($result);
$data = $rec[0];
mysql_free_result($result);
return $data;
}
}
?>

-------------->>>

php : mysql数据库操作类演示的更多相关文章

  1. php MySQL数据库操作类源代码

    php MySQL数据库操作类源代码: <?php class MySQL{ private $host; //服务器地址 private $name; //登录账号 private $pwd; ...

  2. 设计模式 - 单例模式mysql数据库操作类

    待续... index.php 调用方法: <?php header('Content-Type:text/html; charset=utf8'); require 'instance.php ...

  3. MySQL数据库操作类(PHP实现,支持连贯操作)

    <?php /** * Author: suvan * CreateTime: 2018/2/27 * description: 数据库操作类(仅对接MySQL数据库,主要利用MySQLi函数) ...

  4. php pdo mysql数据库操作类

    <?php namespace iphp\core; use iphp\App; /** * 数据库操作基类 基于pdo * @author xuen * 支持链式操作,支持参数绑定 * 说明1 ...

  5. Java数据库操作类演示

    只在mysql上测试过,不知道算不算好使​1. [代码][Java]代码     package org.load.demo; import java.io.IOException;import ja ...

  6. php 封装mysql 数据库操作类

    <?phpheader('content-type:text/html;charset=utf-8');//封装mysql   连接数据库php_mysql//封装mysql   连接数据库ph ...

  7. C# MySQL 数据库操作类

    using System; using System.Configuration; using System.Collections; using System.Data; using MySql.D ...

  8. DELPHI XE MYSQL数据库操作类 MYSQLHELPER

    注: 无需odbc配置 {* * MySQL Helper v1.0 * 2015.6.19 * 说明: * 这是一个操作MySQL的类,该类必须和libmysql.dll,dbxmys.dll两个文 ...

  9. php中用面向对象的思想编写mysql数据库操作类

    最近刚入门完mysql,正好学了一阵子php就想着如何把mysql的表信息用php打印页面上.现在就把代码贴出来,以便小伙伴们参考. 先是建立mysql连接: /*建立连接*/ class datab ...

随机推荐

  1. 【iCore3 双核心板】例程十七:USB_MSC实验——读/写U盘(大容量存储器)

    实验指导书及代码包下载: http://pan.baidu.com/s/1qXt1L0o iCore3 购买链接: https://item.taobao.com/item.htm?id=524229 ...

  2. 解决thrift: ···No such file or directory问题

    感谢Anker分享:error while loading shared libraries: xxx.so.x" 错误的原因和解决办法 今天在装thrift的时候遇到一个这样的问题: ro ...

  3. unity assert server 与 cache server

    Asset server 其实就是unity提供的版本控制工具,不过我们都转到P4V了,上午尝试了一下,如果小团队使用还是不错的,使用过程大致如下,具体的还是要大伙去官网看喽 服务器安装文件下载: h ...

  4. Codevs 1022 覆盖

    时间限制: 1 s 空间限制: 128000 KB 题目等级 : 大师 Master 题目描述 Description 有一个N×M的单位方格中,其中有些方格是水塘,其他方格是陆地.如果要用1×2的矩 ...

  5. Elasticsearch学习笔记(一)

    批量建索引: curl -s -XPOST 'localhost:9200/_bulk' --data-binary @documents.json 查看索引mappingmyindex/_mappi ...

  6. 多线程 - CyclicBarrier

    一个同步辅助类,它允许一组线程互相等待,直到到达某个公共屏障点 (common barrier point).在涉及一组固定大小的线程的程序中,这些线程必须不时地互相等待,此时 CyclicBarri ...

  7. SQL2005 数据库——查看索引

    sqlserver查询表索引 2012-09-19 18:18 by Spring.Guo, 4599 阅读, 0 评论, 收藏, 编辑 SELECT   索引名称=a.name  ,表名=c.nam ...

  8. Saving changes is not permitted in SQL Server

    From Save (Not Permitted) Dialog Box on MSDN : The Save (Not Permitted) dialog box warns you that sa ...

  9. mysqldump database table

    一)在同一个数据库服务器上面进行数据表间的数据导入导出: 1. 如果表tb1和tb2的结构是完全一样的,则使用以下的命令就可以将表tb1中的数据导入到表tb2中: insert into db2.tb ...

  10. windows磁盘分区

    windows 下对磁盘进行分区吗,如何调整大小. N的输入单位为GB,输出单位为MB; (N-1)4+1024N;