欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

完美解決Thinkphp3.2中插入相同數(shù)據(jù)的問題

 更新時(shí)間:2017年08月01日 14:35:58   投稿:jingxian  
下面小編就為大家?guī)?lái)一篇完美解決Thinkphp3.2中插入相同數(shù)據(jù)的問題。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

問題描述

今天在使用TP3.2插入數(shù)據(jù)的時(shí)候,為了避免插入相同的數(shù)據(jù)(所謂相同的數(shù)據(jù),其主鍵相同或者是唯一索引的字段相同),我創(chuàng)建的索引如下圖,主鍵索引為自增字段,不可能出現(xiàn)重復(fù),即唯一索引可能會(huì)出現(xiàn)重復(fù),我希望的是uid,year,mounth,day 這三個(gè)字段出現(xiàn)相同的話,就更新當(dāng)前記錄。

問題解決辦法

在之前面對(duì)這樣的問題的時(shí)候,我們知道,MySQL提供了ON DUPLICATE KEY UPDATE或者REPLACE INTO來(lái)解決。

使用ON DUPLICATE KEY UPDATE

插入數(shù)據(jù)之前,表中就一條記錄,如下圖

SQL語(yǔ)句如下,當(dāng)插入記錄時(shí)候,與表中已有記錄相同,則更新改條記錄,否則插入記錄。

INSERT INTO `work_log` (
`uid`,
`year`,
`mounth`,
`day`,
`status`
) 
VALUES
(1, 2016, 6, 3, 1) 
ON DUPLICATE KEY 
UPDATE 
`status` = 
VALUES
(`status`),
`updated_ts` = NOW();

使用REPLACE INTO

代碼如下:

先執(zhí)行如下代碼插入一條數(shù)據(jù)

REPLACE INTO `work_log` (
`uid`,
`year`,
`mounth`,
`day`,
`status`
) 
VALUES
(1, 2016, 6, 2, 1)

效果如下圖

再次執(zhí)行如下代碼,就會(huì)更新上面插入的代碼

REPLACE INTO `work_log` (
`uid`,
`year`,
`mounth`,
`day`,
`status`
) 
VALUES
(1, 2016, 6, 2, 5)

效果如下圖

ON DUPLICATE KEY UPDATE與REPLACE INTO區(qū)別

當(dāng)出現(xiàn)相同的值時(shí)候,ON DUPLICATE KEY UPDATE是更新已經(jīng)存在的記錄,REPLACE INTO是刪除之前的記錄,然后插入新的記錄。

Thinkphp3.2中解決辦法

在Thinkphp3.2中,通過(guò)add()函數(shù)的第三個(gè)參數(shù)來(lái)處理插入相同數(shù)據(jù)的問題。

Model.class.PHP中add()方法,調(diào)用了Db.class.php中insert中方法,在insert方法中,我們可以看到有如下代碼:

其中$replace 正好是add方法中第三個(gè)參數(shù)。

以上這篇完美解決Thinkphp3.2中插入相同數(shù)據(jù)的問題就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • PHP下載遠(yuǎn)程圖片并保存到本地方法總結(jié)

    PHP下載遠(yuǎn)程圖片并保存到本地方法總結(jié)

    這篇文章主要介紹了PHP下載遠(yuǎn)程圖片并保存到本地方法總結(jié)的相關(guān)資料,需要的朋友可以參考下
    2016-01-01
  • Laravel框架Eloquent ORM新增數(shù)據(jù)、自定義時(shí)間戳及批量賦值用法詳解

    Laravel框架Eloquent ORM新增數(shù)據(jù)、自定義時(shí)間戳及批量賦值用法詳解

    這篇文章主要介紹了Laravel框架Eloquent ORM新增數(shù)據(jù)、自定義時(shí)間戳及批量賦值用法,結(jié)合實(shí)例形式詳細(xì)分析了Laravel框架Eloquent ORM通過(guò)模型新增數(shù)據(jù)、時(shí)間戳設(shè)置、批量賦值模型、Create新增等相關(guān)使用方法,需要的朋友可以參考下
    2019-12-12
  • Thinkphp集成抖音SDK的實(shí)現(xiàn)方法

    Thinkphp集成抖音SDK的實(shí)現(xiàn)方法

    這篇文章主要介紹了Thinkphp集成抖音SDK的實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-04-04
  • php獲取''/''傳參的值簡(jiǎn)單方法

    php獲取''/''傳參的值簡(jiǎn)單方法

    下面小編就為大家?guī)?lái)一篇php獲取'/'傳參的值簡(jiǎn)單方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-07-07
  • 關(guān)于laravel模板中生成URL的幾種模式總結(jié)

    關(guān)于laravel模板中生成URL的幾種模式總結(jié)

    今天小編就為大家分享一篇關(guān)于laravel模板中生成URL的幾種模式總結(jié),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-10-10
  • 如何重寫Laravel異常處理類詳解

    如何重寫Laravel異常處理類詳解

    這篇文章主要給大家介紹了關(guān)于如何重寫Laravel異常處理類的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • WordPress后臺(tái)中實(shí)現(xiàn)圖片上傳功能的實(shí)例講解

    WordPress后臺(tái)中實(shí)現(xiàn)圖片上傳功能的實(shí)例講解

    這篇文章主要介紹了WordPress后臺(tái)中實(shí)現(xiàn)圖片上傳功能的實(shí)例講解,包括多個(gè)圖片上傳表單功能的實(shí)現(xiàn),需要的朋友可以參考下
    2016-01-01
  • yii操作cookie實(shí)例簡(jiǎn)介

    yii操作cookie實(shí)例簡(jiǎn)介

    這篇文章主要介紹了yii操作cookie實(shí)例,需要的朋友可以參考下
    2014-07-07
  • PHP中遍歷二維數(shù)組_以不同形式的輸出操作實(shí)例

    PHP中遍歷二維數(shù)組_以不同形式的輸出操作實(shí)例

    下面小編就為大家?guī)?lái)一篇PHP中遍歷二維數(shù)組_以不同形式的輸出操作實(shí)例。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-08-08
  • php微信公眾號(hào)開發(fā)之現(xiàn)金紅包

    php微信公眾號(hào)開發(fā)之現(xiàn)金紅包

    這篇文章主要為大家詳細(xì)介紹了php微信公眾號(hào)開發(fā)之現(xiàn)金紅包,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-04-04

最新評(píng)論