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目录与文件操作
Dec 30 PHP
php获取字段名示例分享
Mar 03 PHP
PHP连接MySQL的2种方法小结以及防止乱码
Mar 11 PHP
php实现按文件名搜索文件的远程文件查找器
May 10 PHP
php使用$_POST或$_SESSION[]向js函数传参
Sep 16 PHP
php+mysql实现简单的增删改查功能
Jul 13 PHP
php禁用cookie后session设置方法分析
Oct 19 PHP
php使用preg_match()函数验证ip地址的方法
Jan 07 PHP
PHP编程计算两个时间段是否有交集的实现方法(不算边界重叠)
May 30 PHP
Laravel 默认邮箱登录改成用户名登录的实现方法
Aug 12 PHP
PHP连接MySQL数据库操作代码实例解析
Jul 11 PHP
PHP7新增函数
Mar 09 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
解决GD中文乱码问题
2007/02/14 PHP
PHP垃圾回收机制简单说明
2010/07/22 PHP
一款简单实用的php操作mysql数据库类
2014/12/08 PHP
深入讲解PHP的Yii框架中的属性(Property)
2016/03/18 PHP
PHP.vs.JAVA
2016/04/29 PHP
Ext第一周 史上最强学习笔记---GridPanel(基础篇)
2008/12/29 Javascript
JS获取浏览器语言动态加载JS文件示例代码
2014/10/31 Javascript
javascript强制点击广告的方法
2015/02/06 Javascript
JavaScript中逗号运算符介绍及使用示例
2015/03/13 Javascript
js简单实现调整网页字体大小的方法
2016/07/23 Javascript
浅析JS中常用类型转换及运算符表达式
2017/07/23 Javascript
webpack4 入门最简单的例子介绍
2018/09/05 Javascript
webpack4.0+vue2.0利用批处理生成前端单页或多页应用的方法
2019/06/28 Javascript
node实现爬虫的几种简易方式
2019/08/22 Javascript
微信小程序实现pdf、word等格式文件上传的方法
2019/09/10 Javascript
Vue.js实现大屏数字滚动翻转效果
2019/11/29 Javascript
微信小程序自定义navigationBar顶部导航栏适配所有机型(附完整案例)
2020/04/26 Javascript
[06:16]DOTA2守卫传承者——职业选手谈心路历程
2015/02/26 DOTA
python zip文件 压缩
2008/12/24 Python
Python中的一些陷阱与技巧小结
2015/07/10 Python
详解Python设计模式编程中观察者模式与策略模式的运用
2016/03/02 Python
Python-嵌套列表list的全面解析
2016/06/08 Python
python实现各进制转换的总结大全
2017/06/18 Python
urllib和BeautifulSoup爬取维基百科的词条简单实例
2018/01/17 Python
Python subprocess模块详细解读
2018/01/29 Python
浅谈python下tiff图像的读取和保存方法
2018/12/04 Python
opencv导入头文件时报错#include的解决方法
2019/07/31 Python
Python+opencv+pyaudio实现带声音屏幕录制
2019/12/23 Python
使用Python通过oBIX协议访问Niagara数据的示例
2020/12/04 Python
html svg生成环形进度条的实现方法
2019/09/23 HTML / CSS
SmartBuyGlasses美国官网:太阳眼镜和眼镜
2017/08/20 全球购物
Java程序开发中如何应用线程
2016/03/03 面试题
中层干部考核评语
2015/01/04 职场文书
高中生打架检讨书1000字
2015/02/17 职场文书
2015年政务公开工作总结
2015/05/19 职场文书
河童之夏观后感
2015/06/11 职场文书