使用Codeigniter重寫(xiě)insert的方法(推薦)
使用Codeiginter 框架插入數(shù)據(jù)時(shí)有唯一索引鍵值存在解決辦法
對(duì)數(shù)據(jù)進(jìn)行存儲(chǔ)的時(shí)候,會(huì)有一些唯一索引的字段已經(jīng)有值了,插入數(shù)據(jù)的時(shí)候會(huì)失敗我們通常解決辦法是先查詢這個(gè)值是否存在,存在就跟新update,不存在就insert。以下是重寫(xiě)了Codeigniter 模型中的insert方法,極大的簡(jiǎn)化了步驟!
/**
* 插入單條記錄(Insert)
*
* @param array $params 插入字段及值數(shù)組
* @param string $table 插入表名,未指定的場(chǎng)景插入主表
* @param array $columns 插入表中所屬字段名數(shù)組,若指定則按此進(jìn)行過(guò)濾
* @param array $updateColumns 若唯一鍵沖突時(shí)需要更新的列數(shù)組
* @return mixed FALSE:沒(méi)有插入的字段 int:插入記錄id
*
* @throws \C_DB_Exception
*/
public function insert($params, $table = NULL, $columns = array(), $updateColumns = array())
{
// 如果未指定表名,則認(rèn)為對(duì)本Model層的主表進(jìn)行操作
if (empty($table)) {
$table = $this->table;
$columns = $this->columns;
}
// 過(guò)濾掉不屬于該表中的字段
if ( ! empty($columns)) {
foreach ($params as $column => $val) {
if (in_array($column, $columns)) {
$row[$column] = $val;
}
}
}
// 不過(guò)濾
else {
$row = $params;
}
// 沒(méi)有插入字段,直接返回
if ( ! isset($row)) {
return FALSE;
}
// 保證創(chuàng)建時(shí)間、更新時(shí)間必須設(shè)置
if ( ! isset($row['create_at']) && in_array('create_at', $columns)) {
$this->load->helper('common_function');
$datetime = get_datetime();
$row['create_at'] = $datetime;
$row['update_at'] = $datetime;
}
// 封裝SQL文,過(guò)濾不安全因素
$sql = $this->db->insert_string($table, $row);
// 若唯一鍵沖突時(shí)需要更新的列數(shù)組,則再次封裝SQL文
if ( ! empty($updateColumns)) {
$updateValues = '';
foreach ($updateColumns as $updateColumn) {
if (isset($updateValues[0])) {
$updateValues .= ',';
}
$updateValues .= $updateColumn . '=VALUES(' . $updateColumn . ')';
}
$sql = $sql . ' ON DUPLICATE KEY UPDATE ' . $updateValues;
}
// SQL執(zhí)行
$query = $this->db->query($sql);
// SQL執(zhí)行失敗,拋出異常
if (FALSE === $query) {
$code = $this->db->_error_number();
$msg = $this->db->_error_message();
C_log::Error($code . ':' . $msg, $this->user_id, $sql, self::STATUS_DB_LOG);
throw new C_DB_Exception('', C_DB_Exception::DB_ERR_CODE);
}
// SQL文寫(xiě)入DB日志
if (LOG_UPDATE_SQL) {
C_log::Info('', $this->user_id, $sql, self::STATUS_DB_LOG);
}
// 取得插入ID返回
$id = $this->db->insert_id();
return $id;
}
如果直接寫(xiě)SQL還有一種語(yǔ)句
語(yǔ)法: INSERT INTO table VALUES () ON DUPLICATE KEY UPDATE row='$row'
舉個(gè)例子:
INSERT INTO it_teacher (uid,name,qq,create_at)
VALUES ('$userid','$name','$qq',NOW()) ON DUPLICATE KEY UPDATE name='$name',qq='$qq',phone='$phone'";
以上這篇使用Codeigniter重寫(xiě)insert的方法(推薦)就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
php顏色轉(zhuǎn)換函數(shù)hex-rgb(將十六進(jìn)制格式轉(zhuǎn)成十進(jìn)制格式)
將十六進(jìn)制格式轉(zhuǎn)成十進(jìn)制格式的函數(shù)代碼,也就是hex-rgb顏色轉(zhuǎn)換需要的2013-09-09
PHP面向接口編程 耦合設(shè)計(jì)模式 簡(jiǎn)單范例
了解些面向?qū)ο蟮闹R(shí),自己寫(xiě)了段代碼測(cè)試一下,歡迎高手指點(diǎn)2011-03-03
php通過(guò)修改header強(qiáng)制圖片下載的方法
這篇文章主要介紹了php通過(guò)修改header強(qiáng)制圖片下載的方法,實(shí)例分析了php強(qiáng)制圖片下載的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-03-03
PHP preg_match實(shí)現(xiàn)正則表達(dá)式匹配功能【輸出是否匹配及匹配值】
這篇文章主要介紹了PHP preg_match實(shí)現(xiàn)正則表達(dá)式匹配功能,較為詳細(xì)的介紹了preg_match函數(shù)的功能、參數(shù)含義、返回值及使用方法,并結(jié)合實(shí)例給出了preg_match輸出是否匹配及匹配值的相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2017-07-07
IIS下PHP連接數(shù)據(jù)庫(kù)提示mysql undefined function mysql_connect()
在很多php教程初學(xué)者都會(huì)在初次php mysql時(shí)出來(lái)undefined function mysql_connect() 錯(cuò)誤提示,下面我們來(lái)分析原因中。2010-06-06
PHP+ajax實(shí)現(xiàn)二級(jí)聯(lián)動(dòng)菜單功能示例
這篇文章主要介紹了PHP+ajax實(shí)現(xiàn)二級(jí)聯(lián)動(dòng)菜單功能,涉及php結(jié)合ajax的數(shù)據(jù)交互與頁(yè)面元素動(dòng)態(tài)操作相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2018-08-08
PHP基于curl模擬post提交json數(shù)據(jù)示例
這篇文章主要介紹了PHP基于curl模擬post提交json數(shù)據(jù)操作,結(jié)合實(shí)例形式分析了php使用curl實(shí)現(xiàn)post方式提交json數(shù)據(jù)相關(guān)操作步驟與注意事項(xiàng),代碼簡(jiǎn)單實(shí)用,需要的朋友可以參考下2018-06-06
php中json_encode不兼容JSON_UNESCAPED_UNICODE的解決方案
本文主要介紹針對(duì)PHP5.4以下版本的json_encode不兼容JSON_UNESCAPED_UNICODE的處理,需要的朋友可以參考下。2016-05-05

