PHP实现的构造sql语句类实例


Posted in PHP onFebruary 03, 2016

本文实例讲述了PHP实现的构造sql语句类。分享给大家供大家参考,具体如下:

/**
* @package Database Class
* @author injection (mail:injection.mail@gmail.com)
* @version 1.0
*/
@ini_set( 'display_errors',0 );
class DataBase{
 private $mDb_host,$mAb_user,$mAb_pwd,$mConn_No;
 function DataBase( $Conn_Obj ){
 $this->connectDb( $Conn_Obj );
 }
 function connectDb( $Conn_Obj ){
 $this->mDb_host = $Conn_Obj->host;
 $this->mAd_name = $Conn_Obj->user;
 $this->mAd_pwd = $Conn_Obj->pwd;
 $this->mConn_No = mysql_connect( $this->mDb_host, $this->mAd_name, $this->mAd_pwd );
 }
 function selectDb( $Conn_Obj ){
 $this->mDb_name = $Conn_Obj->dbname;
 mysql_select_db( $this->mDb_name );
 }
}
/**
* @package Making Sqls Class exetends Database Class
* @author injection (mail:injection.mail@gmail.com)
* @version 1.0
*/
class MakeSql extends DataBase{
 private $mSql;
 function MakeSql( $type,$arr_colum_list, $arr_sql_choice ){
 $this->MakeSqlType( $arr_colum_list, $arr_sql_choice );
 }
 //switch make list
 function MakeSqlType( $type, $arr_colum_list, $arr_sql_choice ){
 switch( $type ){
 case 'insert':
 return $this->makeInsert( $arr_colum_list, $arr_sql_choice );
 case 'select':
 return $this->makeSelect( $arr_colum_list, $arr_sql_choice );
 case 'update':
 return $this->makeUpdate( $arr_colum_list, $arr_sql_choice );
 case 'delete':
 return $this->makeDelete( $arr_colum_list, $arr_sql_choice );
 }
 }
 //make insert
 function makeInsert( $arr_colum_list,$arr_sql_choice ){
 $colum_key = array_keys( $arr_colum_list );
 $colum_value = array_values( $arr_colum_list );
 $this->mSql = "INSERT INTO ".$arr_sql_choice["tbl_name"]."( ".join( ',' , $colum_key )." ) VALUES( '".join( "','" , $colum_value )."')";
 return $this->mSql;
 }
 //making select
 function makeSelect( $arr_colum_list = '*' , $arr_sql_choice ){
 $colum_value = array_keys( $arr_colum_list );
 foreach( $arr_sql_choice as $sql_key => $sql_value ){
 if( strcmp( $sql_key, 'tbl_name' ) == 0 ){
 if( strcmp($arr_colum_list, '*' ) !== 0 )
  $this->mSql = "SELECT ".join( ',' , $colum_value )." FROM ".$sql_value;
 else
  $this->mSql = "SELECT * FROM ".$sql_value;
 }
 else
 if( strcmp( $sql_value, '' ) !== 0 )
  if(strcmp( $sql_key, 'WHERE' ) === 0 && strcmp( $sql_value, 'colum' ) === 0 ){
  foreach($arr_colum_list As $colum_key => $colum_value )
  $this->mSql .= "$colum_key = '$colum_value' AND ";
  $this->mSql = rtrim( $this->mSql, " AND " );
  }
  else
  $this->mSql .= " $sql_key ".$sql_value;
 }
 return $this->mSql; 
 }
 //making update 
 function makeUpdate( $arr_colum_list, $arr_sql_choice ){
 $this->mSql = "UPDATE ".$arr_sql_choice['tbl_name']." SET ";
 foreach( $arr_colum_list as $colum_key => $colum_value )
 $this->mSql .= "$colum_key = '$colum_value',";
 $this->mSql = rtrim( $this->mSql , ',');
 foreach( $arr_sql_choice as $sql_key => $sql_value ){
 if( strcmp( $sql_value, '' ) !== 0 && strcmp( $sql_key, 'tbl_name' ) !==0 && strcmp( $sql_key, 'ORDER BY' ) !== 0 )
  $this->mSql .= " $sql_key ".$sql_value;
 }
 return $this->mSql;
 }
 //making delete
 function makeDelete( $arr_colum_list, $arr_sql_choice ){
 $this->mSql = "DELETE FROM ".$arr_sql_choice['tbl_name'];
 foreach( $arr_sql_choice as $sql_key => $sql_value ){
 if( strcmp( $sql_key, 'tbl_name' ) !== 0 && strcmp( $sql_value, '' ) !== 0 ){
 $this->mSql .= " $sql_key ".$sql_value;
 }
 }
 return $this->mSql;
 }
}

希望本文所述对大家PHP程序设计有所帮助。

PHP 相关文章推荐
PHP利用COM对象访问SQLServer、Access
Oct 09 PHP
PHP的类 功能齐全的发送邮件类
Oct 09 PHP
PHP获得用户使用的代理服务器ip即真实ip
Dec 31 PHP
在PHP中利用wsdl创建标准webservice的实现代码
Dec 07 PHP
PHP中的排序函数sort、asort、rsort、krsort、ksort区别分析
Aug 18 PHP
php将日期格式转换成xx天前的格式
Apr 16 PHP
jQuery+PHP发布的内容进行无刷新分页(Fckeditor)
Oct 22 PHP
使用PHP uniqid函数生成唯一ID
Nov 18 PHP
CI框架(ajax分页,全选,反选,不选,批量删除)完整代码详解
Nov 01 PHP
Yii2框架加载css和js文件的方法分析
May 25 PHP
laravel利用中间件防止未登录用户直接访问后台的方法
Sep 30 PHP
PHP如何开启Opcache功能提升程序处理效率
Apr 27 PHP
PHP快速生成各种信息提示框的方法
Feb 03 #PHP
PHP实现原比例生成缩略图的方法
Feb 03 #PHP
PHP获取昨天、今天及明天日期的方法
Feb 03 #PHP
PHP实现长文章分页实例代码(附源码)
Feb 03 #PHP
PHP开发中常用的十个代码样例
Feb 02 #PHP
必须收藏的php实用代码片段
Feb 02 #PHP
PHP执行linux命令常用函数汇总
Feb 02 #PHP
You might like
如何利用PHP执行.SQL文件
2013/07/05 PHP
Yii开启片段缓存的方法
2016/03/28 PHP
php使用Jpgraph创建柱状图展示年度收支表效果示例
2017/02/15 PHP
Mootools 1.2教程 设置和获取样式表属性
2009/09/15 Javascript
解决火狐浏览器下JS setTimeout函数不兼容失效不执行的方法
2012/11/14 Javascript
Jquery getJSON方法详细分析
2013/12/26 Javascript
jquery 实现两级导航菜单附效果图
2014/03/07 Javascript
原生js和jquery实现图片轮播淡入淡出效果
2015/04/23 Javascript
nodejs修复ipa处理过的png图片
2016/02/17 NodeJs
javascript实现一个简单的弹出窗
2016/02/22 Javascript
学习使用Bootstrap页面排版样式
2017/05/11 Javascript
老生常谈js数据类型
2017/08/03 Javascript
three.js加载obj模型的实例代码
2017/11/10 Javascript
vue2导航根据路由传值,而改变导航内容的实例
2017/11/10 Javascript
150行代码带你实现微信小程序中的数据侦听
2019/05/17 Javascript
layui点击数据表格添加或删除一行的例子
2019/09/12 Javascript
Python中利用原始套接字进行网络编程的示例
2015/05/04 Python
python3制作捧腹网段子页爬虫
2017/02/12 Python
Python实现字符串逆序输出功能示例
2017/06/24 Python
python pandas中DataFrame类型数据操作函数的方法
2018/04/08 Python
python远程邮件控制电脑升级版
2019/05/23 Python
wxPython实现整点报时
2019/11/18 Python
基于TensorFlow的CNN实现Mnist手写数字识别
2020/06/17 Python
CSS3.0实现霓虹灯按钮动画特效的示例代码
2021/01/12 HTML / CSS
HTML5地理定位与第三方工具百度地图的应用
2016/11/17 HTML / CSS
NFL墨西哥官方商店:Tienda NFL
2017/11/28 全球购物
英国品牌男装折扣网站:Brown Bag
2018/03/08 全球购物
美国在线家居装饰店:Belle&June
2018/10/24 全球购物
学生会主席竞聘书
2014/03/31 职场文书
专升本学生毕业自我鉴定
2014/10/04 职场文书
师德师风学习材料
2014/12/19 职场文书
清明节网上祭英烈寄语2015
2015/03/04 职场文书
2015年大学生社会实践评语
2015/03/26 职场文书
解决Django transaction进行事务管理踩过的坑
2021/04/24 Python
MongoDB支持的数据类型
2022/04/11 MongoDB
Windows Server 修改远程桌面端口的实现
2022/06/25 Servers