Yii框架批量插入数据扩展类的简单实现方法
发布时间:2020-12-12 22:09:01 所属栏目:PHP教程 来源:网络整理
导读:本篇章节讲解Yii框架批量插入数据扩展类的简单实现方法。供大家参考研究具体如下: MySQL INSERT语句允许插入多行数据,如下所示: 那么要实现批量插入,主要的任务就是按照列顺序,把数据组装成上述格式即可,可以使用sprintf和vsprintf函数来实
本篇章节讲解Yii框架批量插入数据扩展类的简单实现方法。分享给大家供大家参考,具体如下: MySQL INSERT语句允许插入多行数据,如下所示: 那么要实现批量插入,主要的任务就是按照列顺序,把数据组装成上述格式即可,可以使用sprintf和vsprintf函数来实现。 下面是一个实现批量插入的Yii扩展类的简单示例(支持VARCHAR类型数据): class = $class;
$this->createtpl();
parent::_construct($db);
}
private function createtpl(){
$this->fresh = true;
$value_tpl = "";
$columns_string = "";
$this->columns = $this->class->getMetaData()->tableSchema->columns;
$counter = 0;
foreach($this->columns as $column){
/** @var CDbColumnSchema $column */
if($column->autoIncrement){
$value_tpl .= "0";
}else{
$value_tpl .= ""%s"";
}
$columns_string .= $column->name;
$counter ++;
if($counter != sizeof($this->columns)){
$columns_string .= ",";
$value_tpl .= ",";
}
}
$this->insert_tpl = sprintf($this->insert_tpl,$this->class->tableName(),$columns_string);
$this->value_tpl = sprintf($this->value_tpl,$value_tpl);
}
/**
* @param CActiveRecord $record
*/
public function add($record){
$values = array();
$i = 0;
foreach($this->columns as $column){
if($column->autoIncrement){
continue;
}
$values[$i] = $this->class->{$column->name};
$i ++;
}
if(!$this->fresh){
$this->query .= ",";
}else{
$this->query = "values";
}
$this->fresh = false;
$this->query .= vsprintf($this->value_tpl,$values);
return true;
}
public function execute(){
$this->setText($this->insert_tpl." ".$this->query);
return parent::execute();
}
}
使用方法是通过add方法逐个加入数据,然后调用execute执行。 更多关于Yii相关内容感兴趣的读者可查看本站专题:《》、《》、《》、《》、《》、《》及《》 希望本文所述对大家基于Yii框架的PHP程序设计有所帮助。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |