文章来源:http://www.cnblogs.com/hello-tl/p/7592547.html

<?php
/**
* __construct($Mysql_config) 构造函数 $Mysql_config['server']服务器-$Mysql_config['user']用户名-$Mysql_config['pwd']密码-$Mysql_config['name']数据库名字-$Mysql_config['character']字符集
* Mysql_alter_drop($table,$name) 删除一个字段 $table表明 $name字段名
* Mysql_alter_add($table,$name,$type) 添加一个字段 $table表明 $name字段名 $type字段类型
* Mysql_instert($data="",$name="") 添加一条数据 $data数组格式的数据简直跟数据库字段一致 $name表明
* Mysql_insert_id() 取得上一步 INSERT 操作产生的 ID
* Mysql_delete($name="",$where="") 删除数据 $name表明 $where条件
* Mysql_update($name="",$data="",$where="") 修改一条语句 $name 表明 $data数组格式的数据简直跟数据库字段一致 $where条件
* Mysql_query($sql="") 执行一条sql语句 $sql 语句
* Mysql_array($array="") 返回一个二维数组 $array 上一条查询的返回值
* Mysql_json_encode($数组,$fromCode="gb2312",$toCode="utf-8") 数组转换json
* Mysql_rows() 返回相应的条数
* Mysql_rows_result() 释放资源
* function __destruct() 析构函数 自动关闭书库
*/
class TL_Mysql{
  private $conn;
  private $result;
  /*构造函数*/
  public function __construct($Mysql_config){
    if(is_array($Mysql_config)){
      $this->conn = mysql_connect(!empty($Mysql_config['server'])?$Mysql_config['server']:'localhost',!empty($Mysql_config['user'])?$Mysql_config['user']:'root',$Mysql_config['pwd']);
      mysql_select_db($Mysql_config['name']);
      mysql_query(!empty($Mysql_config['character'])?$Mysql_config['character']:'utf8_general_ci');
    }
  }
/**
* 删除一个字段
* @param [type] $table [description] 表明
* @param [type] $name [description] 字段名
*/
public function Mysql_alter_drop($table,$name){
$sql = "alter table ".$table." drop column ".$name."";
$this->Mysql_query($sql);
return $sql;
}
/**
* 添加一个字段
* @param [type] $table [description] 表明
* @param [type] $name [description] 字段名
* @param [type] $type [description] 类型/位数
*/
public function Mysql_alter_add($table,$name,$type){
$sql = "alter table ".$table." add ".$name." ".$type." ";
$this->Mysql_query($sql);
return $sql;
}
/**
* 添加一条数据
* @param [type] $data [description] 数据
* @param [type] $name [description] 数据库名字
* @return [type] [description]
*/
public function Mysql_instert($data="",$name=""){
    if(is_array($data) && !empty($name)){
      $key = "";
      $value = "";
      foreach ($data as $keys => $values){
        $key = $key . "`" . $keys . "`,";
        $value = $value . "'" . $values. "',";
      }
      $key = substr($key,0,-1);
      $value = substr($value,0,-1);
      $sql = "INSERT INTO ".$name." (".$key.") VALUES (".$value.")";
      $this->Mysql_query($sql);
      return $sql;
    }else{
      $sql = "Mysql_instert(不是一个数组,表名称)";
      return $sql;
    }
  }
/*取得上一步 INSERT 操作产生的 ID*/
public function Mysql_insert_id() {
return mysql_insert_id();
}
/**
* 删除数据
* @param [type] $name [description] 表名称
* @param [type] $where [description] 条件
*/
  public function Mysql_delete($name="",$where=""){
    if(!empty($name) && !empty($where)){
      $sql = "delete from ".$name." where ".$where;
      $this->Mysql_query($sql);
      return $sql;
    }else{
      $sql = "Mysql_delete(表名称,数据库条件)";
      return $sql;
    }
  }
/**
* 修改一条语句
* @param [type] $name [description] 表名称
* @param [type] $data [description] 数据
* @param [type] $where [description] 条件
*/
public function Mysql_update($name="",$data="",$where=""){
    if(is_array($data)){
      $datas = "";
      foreach ($data as $keys => $values){
        $datas = $datas . $keys . "='" . $values ."',";
      }
      $sql = "update ".$name." set ".substr($datas,0,-1)." where ".$where;
      $this->Mysql_query($sql);
      return $sql;
    }else{
      $sql = "Mysql_update(表名称,数据,条件)";
      return $sql;
    }
  }
/**
* 执行一条sql语句
* @param [type] $sql [description] sql语句
* @return [type] [description]
*/
public function Mysql_query($sql=""){
    if(!empty($sql)){
      $result=mysql_query($sql);
      return $this->result = $result;
    }else{
      $result = "Mysql_query(mysql语句)";
      return $result;
    }
}
/**
* 返回一个二维数组
* @param [type] $array [description] 执行过的sql语句
*/
public function Mysql_array($array=""){
    if(!empty($array)){
      $result=array();
      while($row = mysql_fetch_array($array,MYSQL_ASSOC)){
        $result[] = $row;
      }
      return $result;
    }else{
      $_array = array('Mysql_array(执行过的sql语句)');
      return $_array;
    }
}
/**
* [encodeConvert description] 转换json
* @param [type] $str [description] 数组
* @param [type] $fromCode [description] gb2312
* @param [type] $toCode [description] utf-8
* @return [type] [description]
*/
function Mysql_json_encode($str,$fromCode,$toCode){
if(strtoupper($toCode) == strtoupper($fromCode)) return $str;
if(is_string($str)){
if(function_exists('mb_convert_encoding')){
return mb_convert_encoding($str,$toCode,$fromCode);
}
else{
return iconv($fromCode,$toCode,$str);
}
}
elseif(is_array($str)){
foreach($str as $k=>$v){
$str[$k] = $this->Mysql_json_encode($v,$fromCode,$toCode);
}
return $str;
}
return $str;
}
/**
* 返回受相应的条数
*/
public function Mysql_rows(){
return mysql_affected_rows();
}
//释放资源
public function Mysql_rows_result(){
return mysql_free_result($this->result);
}
//析构函数,自动关闭数据库,垃圾回收机制
public function __destruct() {
if (!empty($this->result)) {
$this->Mysql_rows_result();
}
return mysql_close($this->conn);
}
}
$Mysql_config = array(
  'server' => 'localhost',//规定要连接的服务器。
  'user' => 'root',//用户名。默认值是服务器进程所有者的用户名。
  'pwd' => '9803164',//密码。默认值是空密码。
  'name' => 'test',//数据库名字
  'character' => 'utf8_general_ci',//字符集
);
$Mysql = new Mysql($Mysql_config);

文章来源:http://www.cnblogs.com/hello-tl/p/7592547.html

PHP:Mysql 基础类的更多相关文章

  1. 基础类封装-pymysql库操作mysql封装

    import pymysql from lib.logger import logger from warnings import filterwarnings filterwarnings(&quo ...

  2. 关于MySql的DBHelper类以及数据分页

    前端: <%@ Register Assembly="AspNetPager" Namespace="Wuqi.Webdiyer" TagPrefix=& ...

  3. php session_set_save_handler 函数的用法(mysql)(转)

    <?php /*============================文件说明======================================== @filename:     s ...

  4. C# 与MySQL

    1. MySQL.Data.dll       http://files.cnblogs.com/files/lwngreat/MySql.Data.rar 2.在工程中添加引用 3. 使用  Mys ...

  5. ADO.NET FOR MySQL帮助类

    using System; using System.Collections; using System.Collections.Specialized; using System.Data; usi ...

  6. C#简单构架之EF进行读写分离+多数据库(Mysql/SqlService)

    最近因为项目需要,研究了下EF的读写分离,所以做了一个demo进行测试,下面是项目的结构 表现层view 主要提供Web.WebApi等表现层的解决方案 公共层public 主要提供项目公共类库,数据 ...

  7. MySQL如何记录binlog

    --MySQL如何记录binlog   -------------------------------2014/07/08     binlog文件的内容 log event       MySQL的 ...

  8. C#操作SqlServer MySql Oracle通用帮助类Db_Helper_DG(默认支持数据库读写分离、查询结果实体映射ORM)

    [前言] 作为一款成熟的面向对象高级编程语言,C#在ADO.Net的支持上已然是做的很成熟,我们可以方便地调用ADO.Net操作各类关系型数据库,在使用了多年的Sql_Helper_DG后,由于项目需 ...

  9. VS连接数据库的通用方法(SQL/MySql)

    在vs里面连接数据库的方法有很多,这里是通用的方法和基本操作 SQL /// <summary> /// 数据访问抽象基础类 /// Copyright (C) Maticsoft /// ...

随机推荐

  1. bzoj3265: 志愿者招募加强版(线性规划+单纯形法)

    传送门 鉴于志愿者招募那题我是用网络流写的所以这里还是写一下单纯形好了-- 就是要我们求这么个线性规划(\(d_{ij}\)表示第\(i\)种志愿者在第\(j\)天能不能服务,\(x_i\)表示第\( ...

  2. SPOJ GSS3 线段树系列1

    SPOJ GSS系列真是有毒啊! 立志刷完,把线段树搞完! 来自lydrainbowcat线段树上的一道例题.(所以解法参考了lyd老师) 题意翻译 n 个数, q 次操作 操作0 x y把 Ax 修 ...

  3. play framework

    Compilation errorThe file {module:docviewer}/app/controllers/PlayDocumentation.java could not be com ...

  4. 查找MySQL和 SQL sever data

    MySql SQL server

  5. 尺取法 POJ 3601 Subsequence

    题目传送门 /* 题意:求连续子序列的和不小于s的长度的最小值 尺取法:对数组保存一组下标(起点,终点),使用两端点得到答案 1. 记录前i项的总和,求[i, p)长度的最小值,用二分找到sum[p] ...

  6. Navicat无法连接Oracle数据库问题处理一例

    需要通过Navicat连接Oracle数据库进行数据迁移,发现无法连接,报如下错误信息: 按照百度中的说明配置了正确的oci. 此时又报如下错误: 问题解决: 经测试发现与软件的版本有关系,本机的Or ...

  7. C#内存映射文件学习[转]

    原文链接 内存映射文件是由一个文件到进程地址空间的映射. C#提供了允许应用程序把文件映射到一个进程的函(MemoryMappedFile.CreateOrOpen).内存映射文件与虚拟内存有些类似, ...

  8. 数组声明的几种方式以及length属性

    声明一: int[] arr=new int[10]; for(int i=0;i<arr.length;i++){ arr[i]=i; } 声明二: int[] arr2={1,2,3}; 声 ...

  9. UML 用例图(转载)

    UML是系统架构设计师考试的一个重要考点,需要考生掌握.但是有些考生,在学习的过程中会有这样的疑问,在敏捷开发时代,UML还有没有必要去学习? UML还是有用的,主要用在设计和分析阶段,但是UML不适 ...

  10. Css 基本的规则写法

    样式表的写法: css的语法由一些标志构成,就是一个基本的样式表由选择器,属性和属性值构成.Css有标准的写法规则标准的css写法: h1 { Font-family:黑体;} h1:表示选择符Fon ...