php使用sprintf拼接sql

一.封装常用增删查改操作方法

<?php
class BaseDAO{

	//创建数据
	public function create($table_name,$model){
		$columns_k='';
		$columns_v='';
		foreach($model as $key=>$value){
			$columns_k=empty($columns_k)?
				sprintf('`%s`',$key):
				sprintf('%s,`%s`',$columns_k,$key);
			$columns_v=empty($columns_v)?
				sprintf("'%s'",$value):
				sprintf("%s,'%s'",$columns_v,$value);
		}
		$sqlcmd=sprintf("INSERT INTO `%s`(%s) VALUES(%s)",$table_name,
			$columns_k,$columns_v);
		echo $sqlcmd;
	}

	//修改数据
	public function modify($table_name,$model,$primary){
		$columns='';
		$wheres='';
		foreach($model as $key=>$value){
			$columns=empty($columns)?
				sprintf("`%s`='%s'",$key,$value):
				sprintf("%s,`%s`='%s'",$columns,$key,$value);
		}
		$wheres=sprintf("`%s`='%s'",$primary['pk'],$primary['pv']);
		$sqlcmd=sprintf("UPDATE `%s` SET %s WHERE %s",$table_name,$columns,$wheres);
		echo $sqlcmd;
	}

	//删除数据
	public function remove($table_name,$model){
		$wheres='';
		foreach($model as $key=>$value){
			$wheres=empty($wheres)?
				sprintf("`%s`='%s'",$key,$value):
				sprintf("%s and `%s`='%s'",$wheres,$key,$value);
		}
		$sqlcmd=sprintf("DELETE FORM `%s` WHERE %s",
			$table_name,$wheres);
		echo $sqlcmd;
	}

	//查询数据
	public function select($table_name,$conditons){
		$wheres='';
		foreach($conditons as $key=>$value){
			$wheres=empty($wheres)?
				sprintf("`%s`='%s'",$key,$value):
				sprintf("%s and `%s`='%s'",$wheres,$key,$value);
		}
		$sqlcmd=sprintf("SELECT * FROM `%s` WHERE %s",$table_name,$wheres);
		echo $sqlcmd;
	}
	
	//根据主键查找数据
	public function findById($table_name,$primary){
		$sqlcmd=sprintf("SELECT * FROM `%s` WHERE `%s`='%s' LIMIT 1",$table_name,$primary['pk'],$primary['pv']);
		echo $sqlcmd;
	}
}

二.调用实例

<?php
require_once("./BaseDAO.class.php");
echo '<br/>增加<br/>';
BaseDAO::create('cb_admin',array('username'=>'admin','password'=>md5('pwd')));
echo '<br/>查询<br/>';
BaseDAO::select('cb_admin',array('username'=>'admin','password'=>md5('pwd')));
echo '<br/>修改<br/>';
BaseDAO::modify('cb_admin',array('username'=>'admin','password'=>md5('pwd')),array('pk'=>'id','pv'=>1));
echo '<br/>删除<br/>';
BaseDAO::remove('cb_admin',array('username'=>'admin','password'=>md5('pwd')));
echo '<br/>明细<br/>';
BaseDAO::findById('cb_admin',array('pk'=>'id','pv'=>1));



  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值