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读写文件的方法(生成HTML)
Nov 27 PHP
php巧获服务器端信息
Dec 06 PHP
PHP校验ISBN码的函数代码
Jan 17 PHP
用php的ob_start来生成静态页面的方法分析
Mar 09 PHP
linux下安装php的memcached客户端
Aug 03 PHP
PHP中COOKIES使用示例
Jul 26 PHP
[原创]PHP简单开启curl的方法(测试可行)
Jan 11 PHP
php注册登录系统简化版
Dec 28 PHP
Thinkphp实现短信验证注册功能
Oct 18 PHP
PHP中危险的file_put_contents函数详解
Nov 04 PHP
php-app开发接口加密详解
Apr 18 PHP
PHP中非常有用却鲜有人知的函数集锦
Aug 17 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获取当前完整URL地址的函数
2014/12/21 PHP
编写PHP脚本来实现WordPress中评论分页的功能
2015/12/10 PHP
Yii2隐藏frontend/web和backend/web的方法
2015/12/12 PHP
thinkphp3.2点击刷新生成验证码
2016/02/16 PHP
php数组指针操作详解
2017/02/14 PHP
Prototype Number对象 学习
2009/07/19 Javascript
禁止JQuery中的load方法装载IE缓存中文件的方法
2009/09/11 Javascript
javascript同页面多次调用弹出层具体实例代码
2013/08/16 Javascript
Jquery中"$(document).ready(function(){ })"函数的使用详解
2013/12/30 Javascript
jQuery中click事件的定义和用法
2014/12/20 Javascript
全面解析Javascript无限添加QQ好友原理
2016/06/15 Javascript
DropDownList控件绑定数据源的三种方法
2016/12/24 Javascript
JS日程管理插件FullCalendar简单实例
2017/02/07 Javascript
JavaScript编写一个贪吃蛇游戏
2017/03/09 Javascript
jQuery滚动插件scrollable.js用法分析
2017/05/25 jQuery
Angularjs中date过滤器失效的问题及解决方法
2018/07/06 Javascript
ajax与jsonp的区别及用法
2018/10/16 Javascript
JS使用对象的defineProperty进行变量监控操作示例
2019/02/02 Javascript
angular2 NgModel模块的具体使用方法
2019/04/10 Javascript
vue实现手机号码的校验实例代码(防抖函数的应用场景)
2019/09/05 Javascript
[56:01]2018DOTA2亚洲邀请赛 3.31 小组赛 B组 Effect vs EG
2018/03/31 DOTA
[03:12]完美世界DOTA2联赛PWL DAY6集锦
2020/11/05 DOTA
浅谈Python中的作用域规则和闭包
2018/03/20 Python
Python实现定期检查源目录与备份目录的差异并进行备份功能示例
2019/02/27 Python
Win10系统下安装labelme及json文件批量转化方法
2019/07/30 Python
Pytorch中accuracy和loss的计算知识点总结
2019/09/10 Python
flask利用flask-wtf验证上传的文件的方法
2020/01/17 Python
如何使用Python调整图像大小
2020/09/26 Python
索引覆盖(Index Covering)查询含义
2012/02/18 面试题
初入社会应届生求职信
2013/11/18 职场文书
招商业务员岗位职责
2013/12/16 职场文书
乔迁之喜主持词
2014/03/27 职场文书
2014年党员自我评价材料
2014/09/22 职场文书
2015年五四青年节演讲稿
2015/03/18 职场文书
MBA推荐信怎么写
2015/03/25 职场文书
2019年最新借条范本!
2019/07/08 职场文书