PHP:Mysql 基础类
文章来源: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 基础类的更多相关文章
- 基础类封装-pymysql库操作mysql封装
import pymysql from lib.logger import logger from warnings import filterwarnings filterwarnings(&quo ...
- 关于MySql的DBHelper类以及数据分页
前端: <%@ Register Assembly="AspNetPager" Namespace="Wuqi.Webdiyer" TagPrefix=& ...
- php session_set_save_handler 函数的用法(mysql)(转)
<?php /*============================文件说明======================================== @filename: s ...
- C# 与MySQL
1. MySQL.Data.dll http://files.cnblogs.com/files/lwngreat/MySql.Data.rar 2.在工程中添加引用 3. 使用 Mys ...
- ADO.NET FOR MySQL帮助类
using System; using System.Collections; using System.Collections.Specialized; using System.Data; usi ...
- C#简单构架之EF进行读写分离+多数据库(Mysql/SqlService)
最近因为项目需要,研究了下EF的读写分离,所以做了一个demo进行测试,下面是项目的结构 表现层view 主要提供Web.WebApi等表现层的解决方案 公共层public 主要提供项目公共类库,数据 ...
- MySQL如何记录binlog
--MySQL如何记录binlog -------------------------------2014/07/08 binlog文件的内容 log event MySQL的 ...
- C#操作SqlServer MySql Oracle通用帮助类Db_Helper_DG(默认支持数据库读写分离、查询结果实体映射ORM)
[前言] 作为一款成熟的面向对象高级编程语言,C#在ADO.Net的支持上已然是做的很成熟,我们可以方便地调用ADO.Net操作各类关系型数据库,在使用了多年的Sql_Helper_DG后,由于项目需 ...
- VS连接数据库的通用方法(SQL/MySql)
在vs里面连接数据库的方法有很多,这里是通用的方法和基本操作 SQL /// <summary> /// 数据访问抽象基础类 /// Copyright (C) Maticsoft /// ...
随机推荐
- bzoj1048(记忆化搜索)
1048: [HAOI2007]分割矩阵 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1218 Solved: 890[Submit][Statu ...
- YCOJ中国邮递员问题
题目: Description 一个邮递员从邮局出发,需要去 n - 2个城市送信,送完信件以后回家. 邮局在城市 1,家在城市 n,任意两个城市之间都有道路,但是这些道路是单向,也就是说 a 到 b ...
- SqlParameter 的使用
SqlParameter[] sqlParams = new SqlParameter[2];sqlParams[0] = new SqlParameter("@RoleId", ...
- CF1140G Double Tree
题解 首先如果我们要确定出每个\(dis_{i \to i+1 , i \in odd}\) 这个可以用两遍树形\(DP\)来解决 一遍是考虑走子树子树绕过来的 一遍是考虑从走祖先绕过来的 然后就可以 ...
- zoj 3649 lca与倍增dp
参考:http://www.xuebuyuan.com/609502.html 先说题意: 给出一幅图,求最大生成树,并在这棵树上进行查询操作:给出两个结点编号x和y,求从x到y的路径上,由每个结点的 ...
- 题解报告:hdu 1124 Factorial(求N!尾数有多少个0。)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1124 Problem Description The most important part of a ...
- 转-MAC 下安装PHONEGAP开发环境
来自:http://jinzhe.net/post/8.html 什么是Phonegap呢?Phonegap是一个利用HTML5去开发App的框架.可以为安卓.iOS.WP.黑莓.火狐等移动操作系统. ...
- 移动web开发基础(二)——viewport
本文主要研究为什么移动web开发需要设置viewport,且一般设置为<meta name="viewport" content="width=device-wid ...
- VMware虚拟机中涉及的3种常见网络模式
桥接模式.这种模式下,虚拟机和物理机连的是同一个网络,虚拟机和物理机是并列关系,地位是相当的.比如你家如果有用路由器,那么你的电脑和你的手机同时连接这个路由器提供的Wi-Fi,那么它们的关系就是这种模 ...
- CentOS 7 下配置 firewalld(firewall-cmd)实现 NAT 转发 软路由
如果配合 DHCP 服务或实现更多功能. ☼ NAT 转发软路由 开启 NAT 转发之后,只要本机可以上网,不论是单网卡还是多网卡,局域网内的其他机器可以将默认网关设置为已开启 NAT 转发的服务器 ...