mysql数据库封装
<?php /**
* name: sql操作封装,可扩展 .
* User: 张云山
* Date: 2016/9/4
* Time: 22:02
*/ //php文件编码设置
header('Content-type: text/html; charset=utf-8');
//数据库类
class sqled {
public function addTabase($sql_url,$sql_name,$sql_pss,$sql_DB){//创建数据库
$conn = new mysqli($sql_url,$sql_name,$sql_pss);
if(!$conn){
echo "连接失败<br>";
};
$sql = "CREATE DATABASE ".$sql_DB;
if($conn->query($sql) == TRUE){
return true;
}else{
echo $conn->error."<br>";
};
$conn -> close();
}
//示例(创建数据库)************/// addTabase($sql_url,$sql_name,$sql_pss,$sql_DB);
///*************************************************************************/// public function addTable($sql_url,$sql_name,$sql_pss,$sql_DB,$data){//创建表以及字段
$conn = new mysqli($sql_url,$sql_name,$sql_pss,$sql_DB);
// 检测连接
if (!$conn) {
echo "连接失败";
};
$sql = "CREATE TABLE {$data['name']} (
id INT(6) UNSIGNED AUTO_INCREMENT PRIMARY KEY,
{$data['data']}
)";
/*
id INT(6) UNSIGNED AUTO_INCREMENT PRIMARY KEY,
firstname VARCHAR(30) NOT NULL,
lastname VARCHAR(30) NOT NULL,
email VARCHAR(50),
reg_date TIMESTAMP
*/
if($conn->query($sql) == TRUE){
return true;
}else{
echo $conn->error."<br>";
};
$conn -> close();
}
//示例(创建表以及字段)************/// addTable($sql_url,$sql_name,$sql_pss,$sql_DB,array("name"=>"ceshi_biao","data"=>"
// test VARCHAR(30) NOT NULL
// "));
//***************************************************************************************/// public function addDB($sql_url,$sql_name,$sql_pss,$sql_DB,$data){//添加字段数据
$conn = new mysqli($sql_url,$sql_name,$sql_pss,$sql_DB);
if(!$conn){
echo "连接失败";
};
$sql = "INSERT INTO {$data['name']} (
{$data["key"]}
)
VALUES (
{$data['value']}
)";
if($conn->query($sql) == TRUE){
return true;
}else{
echo $conn->error;
};
$conn -> close();
}
//示例(添加字段数据)************/// addDB($sql_url,$sql_name,$sql_pss,$sql_DB,array(
// "name"=>"ceshi_biao",
// "key"=>"zanIndex",
// "value"=>"0",
//));
///***********************************************************************************/// public function queryDB($sql_url,$sql_name,$sql_pss,$sql_DB,$data){//读取数据
// 创建连接
$conn = new mysqli($sql_url,$sql_name,$sql_pss,$sql_DB);
// 检测连接
if ($conn->connect_error) {
die("连接失败: " . $conn->connect_error);
};
$sql = "SELECT {$data['data']} FROM {$data['name']}";
$result = $conn->query($sql);
if ($result->num_rows > 0) {
// 输出每行数据
$data_data = explode(",",$data['data']);
$key = '{';
$fh = ',';
for($i = 0 ; $i < count($data_data) ; $i++){
if($i == count($data_data)-1){
$fh = '';
};
$key = $key.'"'.$data_data[$i].'":"$row[\''.$data_data[$i].'\']"'.$fh;
};
$key = $key.'}';
$returnData = array();
while($row = $result->fetch_assoc()) {
$key1 = json_decode($key,true);
foreach($key1 as $keyName=>$value){
$value = "{".$value."}";
eval("\$value = \"$value\";");
$key1[$keyName] = $value;
};
array_push($returnData,$key1);
};
// echo $returnData;//执行回调,并返回查询结果
} else {
echo "0 个结果";
};
return $returnData;
$conn->close();
}
//示例(数据读取或数据查询)************/// queryDB($sql_url,$sql_name,$sql_pss,$sql_DB,array(
// "name" => "ceshi_biao",
// "data" => "id,zanIndex",
// ));
//******************************************************************/// public function updateDB($sql_url,$sql_name,$sql_pss,$sql_DB,$data){//数据更新
$con=mysqli_connect($sql_url,$sql_name,$sql_pss,$sql_DB);
// 检测连接
if (mysqli_connect_errno())
{
echo "连接失败: " . mysqli_connect_error();
};
$sqlUpdate_set = null;
$sqlUpdate_WHERE = null;
//无条件设置,全部更新
$index = 0;
$fh = ",";
foreach ($data['newdata'] as $key => $value){
$index += 1;
if($index == count($data['newdata'])){
$fh = null;
};
$sqlUpdate_set = $sqlUpdate_set.$key."='".$value."'".$fh;
};
//有条件限制s
if(count($data["data"]) > 0 ){
$sqlUpdate_WHERE = "WHERE";
$fh1 = "AND";
$index1 = 0;
foreach ($data["data"] as $key=>$value){
$index1 += 1;
if($index1 == count($data['data'])){
$fh1 = null;
};
$sqlUpdate_WHERE = $sqlUpdate_WHERE." ".$key."='".$value."'".$fh1;
};
};
//有条件限制e
mysqli_query($con,"UPDATE {$data['name']} SET ".$sqlUpdate_set.$sqlUpdate_WHERE);
mysqli_close($con);
return true;
}
//示例(数据更新)************/// updateDB($sql_url,$sql_name,$sql_pss,$sql_DB,array(
// "name"=>"ceshi_biao",
// "newdata" => array(
// "zanIndex"=>"豆腐干发给豆腐",
// "id"=>"1",
// ),
// "data"=> array()//条件
// ));
//*****************************************************************/// public function deleteDB($sql_url,$sql_name,$sql_pss,$sql_DB,$data){//数据删除
$con=mysqli_connect($sql_url,$sql_name,$sql_pss,$sql_DB);
// 检测连接
if (mysqli_connect_errno())
{
echo "连接失败: " . mysqli_connect_error();
};
$result = mysqli_query($con,"DELETE FROM {$data['name']} WHERE {$data['data']}");
echo $result;
mysqli_close($con);
return true;
}
//示例(数据删除)************/// deleteDB($sql_url,$sql_name,$sql_pss,$sql_DB,array(
// "name"=>"ceshi_biao",
// ));
//*********************************************************************************// //数据初始值赋值
public function aab($a,$b){
if($a){
$a = $a;
}else{
$a = $b;
};
return $a;
}
//*********************************************************************************// //数据库操作类型
public static $sql_type = array(
"addTabase"=>"addTabase",//创建数据库
"addTable"=>"addTable",//创建表以及字段
"addDB"=>"addDB",//添加字段数据
"queryDB"=>"queryDB",//读取数据
"updateDB"=>"updateDB",//数据更新
"deleteDB"=>"deleteDB"//数据删除
);
//*********************************************************************************// //sql综合调用方法;
public function fn($sql){
$sql['type'] = $this->aab($sql['type'],sqled::$sql_type['queryDB']);//默认数据库操作设置为(数据查询)
$sql['url'] = $this->aab($sql['url'],"127.0.0.1");
$sql['name'] = $this->aab($sql['name'],"root");
$sql['pss'] = $this->aab($sql['pss'],"admin");
$sql['db'] = $this->aab($sql['db'],"");
$sql['table'] = $this->aab($sql['table'],"");
$sql['array'] = $this->aab($sql['array'],array());
switch ($sql['type']){
case "addTabase";//创建数据库
return $this->addTabase($sql['url'],$sql['name'],$sql['pss'],$sql['db']);
break;
case "addTable";//创建表以及字段
return $this->addTable($sql['url'],$sql['name'],$sql['pss'],$sql['db'],$sql['array']);
break;
case "addDB";//添加字段数据
return $this->addDB($sql['url'],$sql['name'],$sql['pss'],$sql['db'],$sql['array']);
break;
case "queryDB";//读取数据
return $this->queryDB($sql['url'],$sql['name'],$sql['pss'],$sql['db'],$sql['array']);
break;
case "updateDB";//数据更新
return $this->updateDB($sql['url'],$sql['name'],$sql['pss'],$sql['db'],$sql['array']);
break;
case "deleteDB";//数据删除
return $this->deleteDB($sql['url'],$sql['name'],$sql['pss'],$sql['db'],$sql['array']);
break;
}
}
//示例(sql操作)*****************///
//$sql = new sqled();
//$q = $sql->fn(array(
// "db"=>sql_db,
// 'type'=>sqled::$sql_type['deleteDB'],
// "array"=>array(
// "name"=>"user",
// "data"=>"id",
// "newdata"=>array(
// "id"=>"5",
// "user" => "new-d"
// )
// )
//));
///******************************************************************************// };
mysql数据库封装的更多相关文章
- mysql数据库封装和 分页查询
1 之前我们学到了php连接mysql数据库的增删改查,中间要多次调用数据库, 而且以后用到的表比较多,上传中如果需要改数据的话会非常麻烦,但是如果 我们把数据库封装,到时就可以很轻松的把改掉一些数据 ...
- MySQL数据库封装和分页查询
1.数据库封装 <?php //我用的数据库名是housedb class DBDA {public $host="localhost";public $uid=" ...
- python连接mysql数据库封装
源码: import pymysql class MysqlConnect(object): # 魔术方法, 初始化, 构造函数 def __init__(self, host, user, pass ...
- 如何实现一个php框架系列文章【6】mysql数据库
实现一个mysql数据库封装需要考虑的问题 使用方便性 采用直接sql语句操作方式.只要会写sql语句,那么将没有其他学习成本. uctphp框架提供的dba辅助封装类,用会之后将爱不释手. 使用前需 ...
- python3操作MySQL数据库
安装PyMySQL 下载地址:https://pypi.python.org/pypi/PyMySQL 1.把操作Mysql数据库封装成类,数据库和表先建好 import pymysql.cursor ...
- MySQL数据库学习笔记(十)----JDBC事务处理、封装JDBC工具类
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...
- nodejs学习(三)--express连接mysql数据库,mysql查询封装
一.说一下 连接不同的数据库需要安装相应的插件,此demo使用mysql数据库,需自行安装mysql数据库软件. 新建数据库webapp, 新建表users: 二.直接开码 npm install m ...
- 使用jdbc将mysql数据库中的内容封装为指定对象的list集合
使用jdbc将mysql数据库中的内容封装为指定对象的list集合 public List<User> findAll() { private JdbcTemplate template ...
- JDBC Java 程序从 MySQL 数据库中读取数据,并封装到 Javabean 对象中
MySQL 版本:Server version: 5.7.17-log MySQL Community Server (GPL) 相关内容:JDBC Java 连接 MySQL 数据库 用于测试的 M ...
随机推荐
- 试图加载格式不正确的程序。 (异常来自HRESULT:0x8007000B)
异常来自HRESULT:0x8007000B 缘由:在64位操作系统下IIS发布32位的项目,报“项目依赖的dll无法读取,试图加载格式不正确的程序”错误. 原因:程序集之间的通讯要么全是64位环 ...
- [Algorithm] 字符串匹配算法——KMP算法
1 字符串匹配 字符串匹配是计算机的基本任务之一. 字符串匹配是什么?举例来说,有一个字符串"BBC ABCDAB ABCDABCDABDE",我想知道,里面是否包含另一个字符串& ...
- C/C++ 结构体内存对齐
内存对齐是指的是编译器在编译的时候总是会将结构体的元素的地址放在一些合适的位置使得CPU访问这些数据的效率变得更高.首先来看下面这个例子: struct A{ char a; char b; int ...
- 清理系统 cmd
echo 正在清除系统垃圾文件,请稍等......del /f /s /q %systemdrive%*.tmpdel /f /s /q %systemdrive%*._mpdel /f /s /q ...
- XCTest各种断言
XCTFail(format…) 生成一个失败的测试: XCTAssertNil(a1, format...)为空判断,a1为空时通过,反之不通过: XCTAssertNotNil(a1, forma ...
- python __call__ 内置函数的使用
对象通过提供__call__(slef, [,*args [,**kwargs]])方法可以模拟函数的行为, 如果一个对象x提供了该方法,就可以像函数一样使用它,也就是说x(arg1, arg2... ...
- 数据库分库分表(sharding)系列(一) 拆分规则
第一部分:实施策略 数据库分库分表(sharding)实施策略图解 1. 垂直切分垂直切分的依据原则是:将业务紧密,表间关联密切的表划分在一起,例如同一模块的表.结合已经准备好的数据库ER图或领域模型 ...
- 《linux命令》ps -aux详细解释
本文转载自http://blog.chinaunix.net/uid-21516619-id-1824945.html 显示其他用户启动的进程(a) 查看系统中属于自己的进程(x) 启动这个进程的用户 ...
- Javascript 执行环境及作用域
执行环境是javascript中最为重要的一个概念. 执行环境定义了变量或函数有权访问的其他数据,决定了他们各自的行为. 每个执行环境都有一个与之关联的变量对象(variable object),环境 ...
- vim编辑技巧
算上大学上课linux接触四年了,可惜除了工作接触的那些,其他地方还是很水的,都不精通,今日翻来看了看以前过目即忘的vim技巧,发现,如无几年操作经验,这些技巧很难领悟的.这里写下来,以备后查. 区块 ...