다음 에디터는 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!