久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

Yii框架批量插入數據擴展類的簡單實現方法

這篇文章主要介紹了Yii框架批量插入數據擴展類的簡單實現方法,涉及Yii擴展類及數據庫相關操作技巧,需要的朋友可以參考下

本文實例講述了Yii框架批量插入數據擴展類的簡單實現方法。分享給大家供大家參考,具體如下:

MySQL INSERT語句允許插入多行數據,如下所示:

INSERT INTO tbl_name (a,b,c) VALUES(1,2,3),(4,5,6),(7,8,9);

那么要實現批量插入,主要的任務就是按照列順序,把數據組裝成上述格式即可,可以使用sprintf和vsprintf函數來實現。

下面是一個實現批量插入的Yii擴展類的簡單示例(支持VARCHAR類型數據):

<?php
/**
 * class for sql batch insert
 */
class CDbBICommand extends CDbCommand{
  /** @var CActiveRecord $class */
  private $class;
  /** @var string $insert_tpl */
  private $insert_tpl = "insert into %s(%s) ";
  /** @var string $value_tpl */
  private $value_tpl = "(%s)";
  /** @var string $query */
  public $query;
  /** @var CDbColumnSchema[] $columns */
  private $columns;
  /** @var boolean $fresh */
  private $fresh;
  /** @param CActiveRecord $class
   * @param CDbConnection $db
   */
  public function __construct($class,$db){
   $this->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優秀開發框架總結》、《smarty模板入門基礎教程》、《php面向對象程序設計入門教程》、《php字符串(string)用法總結》、《php+mysql數據庫操作入門教程》及《php常見數據庫操作技巧匯總》

希望本文所述對大家基于Yii框架的PHP程序設計有所幫助。

【網站聲明】本站除付費源碼經過測試外,其他素材未做測試,不保證完整性,網站上部分源碼僅限學習交流,請勿用于商業用途。如損害你的權益請聯系客服QQ:2655101040 給予處理,謝謝支持。

相關文檔推薦

這篇文章主要介紹了ThinkPHP實現轉換數據庫查詢結果數據到對應類型的方法,涉及thinkPHP模型類操作及針對源碼文件的相關修改方法,需要的朋友可以參考下
本篇文章主要介紹了Laravel 批量更新多條數據的示例,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
這篇文章主要介紹了Thinkphp5+PHPExcel實現批量上傳表格數據功能,需要的朋友可以參考下
這篇文章主要給大家介紹了關于Laravel中數據遷移與數據填充的相關資料,文中通過示例代碼給大家詳細介紹了實現的步驟,對大家的學習或者工作具有一定的參考學習價值,需要的朋友
下面小編就為大家帶來一篇利用PHP訪問數據庫_實現分頁功能與多條件查詢功能的示例。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
下面小編就為大家帶來一篇PHP中關于PDO數據訪問抽象層的功能操作實例。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
主站蜘蛛池模板: 日韩在线免费 | 日本精品在线视频 | 国产亚洲欧美在线 | 日韩欧美在线观看 | 亚洲成a人片 | 国产乱码精品一区二区三 | 亚洲精品乱码久久久久久蜜桃91 | 可以免费看av的网站 | 天天爽夜夜爽夜夜爽精品视频 | 高清免费视频日本 | 国产成人精品毛片 | 日韩福利视频 | 久久久免费看 | 国产精品成人免费视频 | 黄色三级网站 | 欧美手机在线 | www.在线播放 | 欧美成人性生活视频 | 国产日本在线 | 久久不卡| 在线一级片 | 97视频在线观看免费 | 亚洲一区日韩 | 四虎影音 | 一级黄色网 | 国产一区中文字幕 | 中文字字幕在线中文 | 91一区二区 | 欧美日韩精品久久久免费观看 | 一区二区国产视频 | 成人毛片在线播放 | 国产一区二区欧美 | 国产成人在线观看免费网站 | 一级免费黄色片 | 金银在线| 伊人久久中文字幕 | 国产做受入口竹菊 | 亚洲www | 亚色视频 | 91成人在线观看喷潮 | 亚洲激情欧美激情 |