Thinkphp3.2에 동일한 데이터를 삽입하는 솔루션
다음 에디터는 Thinkphp3.2에서 동일한 데이터를 삽입하는 문제를 완벽하게 해결하는 기사를 가져올 것입니다. 편집자님이 꽤 좋다고 생각하셔서 지금 공유하고 모두에게 참고용으로 드리고자 합니다. 에디터를 따라가서 함께 살펴볼까요
문제 설명
오늘 TP3.2를 사용하여 데이터를 삽입할 때, 동일한 데이터(소위 동일 데이터라고 불리는데, 기본 키가 동일)가 삽입되지 않도록 하기 위해 또는 유일한 인덱스 필드 동일), 제가 생성한 인덱스는 아래와 같습니다. 기본 키 인덱스는 자동 증가 필드이며, 즉, 고유 인덱스가 복제될 수 있다는 것입니다. uid, year, mounth 및 day 세 필드가 동일한 경우 현재 레코드를 업데이트합니다.
문제 해결
이전에 이 문제에 직면했을 때, 우리는 MySQL이 이 문제를 해결하기 위해 ON DUPLICATE KEY UPDATE 또는 REPLACE INTO를 제공한다는 것을 알고 있습니다.
ON DUPLICATE KEY UPDATE를 사용하세요
데이터를 삽입하기 전에는 아래와 같이 테이블에 레코드가 하나만 있습니다.
레코드를 삽입할 때 다음과 같은 경우 SQL 문은 다음과 같습니다. 테이블의 기존 레코드인 경우 레코드를 업데이트합니다. 그렇지 않으면 레코드가 삽입됩니다.
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를 사용하세요
코드는 다음과 같습니다.
먼저 다음 코드를 실행하여 데이터 조각을 삽입하세요
REPLACE INTO `work_log` ( `uid`, `year`, `mounth`, `day`, `status` ) VALUES (1, 2016, 6, 2, 1)
효과는 아래와 같습니다
다음 코드를 실행하세요 다시 입력하면 위에 삽입된 코드가 업데이트됩니다
REPLACE INTO `work_log` ( `uid`, `year`, `mounth`, `day`, `status` ) VALUES (1, 2016, 6, 2, 5)
효과는 아래와 같습니다
ON DUPLICATE KEY UPDATE와 REPLACE INTO의 차이점
같은 값이 나타날 때 ON DUPLICATE KEY UPDATE는 기존 레코드를 업데이트합니다. , REPLACE INTO는 이전 레코드를 삭제한 다음 새 레코드를 삽입합니다.
Thinkphp3.2의 솔루션
Thinkphp3.2에서는 동일한 데이터를 삽입하는 문제를 add() 함수의 세 번째 매개변수를 통해 처리합니다.
Model.class.PHP의 add() 메서드는 Db.class.php의 insert 메서드를 호출합니다. insert 메서드에서 다음 코드를 볼 수 있습니다.
여기서 $replace는 add입니다. 메서드의 세 번째 매개변수입니다.
위 내용은 Thinkphp3.2에 동일한 데이터를 삽입하는 솔루션의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











이번 장에서는 CakePHP의 환경 변수, 일반 구성, 데이터베이스 구성, 이메일 구성에 대해 알아봅니다.

PHP 8.4는 상당한 양의 기능 중단 및 제거를 통해 몇 가지 새로운 기능, 보안 개선 및 성능 개선을 제공합니다. 이 가이드에서는 Ubuntu, Debian 또는 해당 파생 제품에서 PHP 8.4를 설치하거나 PHP 8.4로 업그레이드하는 방법을 설명합니다.

CakePHP는 PHP용 오픈 소스 프레임워크입니다. 이는 애플리케이션을 훨씬 쉽게 개발, 배포 및 유지 관리할 수 있도록 하기 위한 것입니다. CakePHP는 강력하고 이해하기 쉬운 MVC와 유사한 아키텍처를 기반으로 합니다. 모델, 뷰 및 컨트롤러 gu

VS Code라고도 알려진 Visual Studio Code는 모든 주요 운영 체제에서 사용할 수 있는 무료 소스 코드 편집기 또는 통합 개발 환경(IDE)입니다. 다양한 프로그래밍 언어에 대한 대규모 확장 모음을 통해 VS Code는
