다음 기사에서는 Thinkphp3.2에서 동일한 데이터를 삽입하는 문제에 대한 완벽한 솔루션을 제공합니다. 내용이 꽤 괜찮아서 지금 공유해서 참고용으로 올려드리겠습니다.
문제 설명
오늘 TP3.2를 사용하여 데이터를 삽입할 때 동일한 데이터(소위 동일 데이터라고 함)의 삽입을 피하기 위해 기본 키가 동일하거나 고유 인덱스의 필드가 동일), 제가 만든 인덱스는 다음 그림과 같습니다. 기본 키 인덱스는 자동 증가 필드이므로 중복이 불가능합니다. 즉, 고유 인덱스가 중복될 수 있습니다. , 연도, 산, 일이 동일할 경우 현재 기록이 업데이트됩니다.
문제 해결
이전에 이 문제에 직면했을 때, 우리는 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)
효과는 아래와 같습니다
ON DUPLICATE KEY UPDATE와 REPLACE INTO의 차이점
동일한 값이 나타나면 ON DUPLICATE KEY UPDATE는 기존 레코드를 업데이트하고 REPLACE INTO는 이전 레코드를 삭제하고 새 레코드를 삽입합니다.
Thinkphp3.2의 솔루션
여기서 $replace는 add입니다. 메서드의 세 번째 매개변수입니다.
관련 권장 사항:
thinkphp3.2.3 버전 데이터베이스 추가, 삭제, 수정 및 구현 코드 확인
위 내용은 Thinkphp3.2에서 동일한 데이터를 삽입하는 문제를 완벽하게 해결의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

의존성 (di) inphpenhancescodeflexibility 및 testability는 theiredections 의존성에 대한 classessecouplassessecouplesseviaconstructors, useconstructorinjectionsforpostforpost-creationdencecanchanges, t

간단한 프로젝트에는 Pimple이 권장되며 Symfony의 종속성은 복잡한 프로젝트에 권장됩니다. 1) Pimple은 단순성과 유연성으로 인해 소규모 프로젝트에 적합합니다. 2) Symfony의 종속성 주입은 강력한 기능으로 인해 대규모 프로젝트에 적합합니다. 선택할 때 프로젝트 규모, 성능 요구 사항 및 학습 곡선을 고려해야합니다.

의존성 (di) inphpisadesignpatternwhereclassdectionsearepassedtoittratherthathertancreatedincreatedincreatedincreatedincreatedincreatedincreatedincecreatedincecreatedince.itimprovessoftwarequalityby : 1) 향상된 testability througheasydectionmocking, 2) lextibility oca

의존성 주사 (di) inphpenhancescodemodularity, testability 및 mainainability

tooptimizephpcodeforregedmemoryUsageancutionEcution-time, followthesesteps : 1) usereferencesinsteAdArgedArgedArgeDatureStoredUcememoryConsumption.2) leveragephp'sbuilt-infunctionslikearray_mapforfosterexecution

phpisusedforendingemailsduetoitsintegrationwithsermailservices 및 externalsmtpproviders, 1) setupyourphpenvironmentwitheberverandphp, temailfuncpp를 보장합니다

이메일을 보내는 가장 좋은 방법은 Phpmailer 라이브러리를 사용하는 것입니다. 1) Mail () 함수를 사용하는 것은 간단하지만 신뢰할 수 없으므로 이메일이 스팸으로 입력되거나 배송 할 수 없습니다. 2) Phpmailer는 더 나은 제어 및 신뢰성을 제공하며 HTML 메일, 첨부 파일 및 SMTP 인증을 지원합니다. 3) SMTP 설정이 올바르게 구성되었는지 확인하고 (예 : STARTTLS 또는 SSL/TLS) 암호화가 보안을 향상시키는 데 사용됩니다. 4) 많은 양의 이메일의 경우 메일 대기열 시스템을 사용하여 성능을 최적화하십시오.

CustomHeadersAndAdAncedFeaturesInpHeAmailEnhanceFectionality.1) 1) CustomHeadersAdDmetAdataFortrackingand Categorization.2) htmlemailsallowformattingandinteractivity.3) attachmentSentUsingLibraries likePhpMailer.4) smtpauthenticimprpr


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

Eclipse용 SAP NetWeaver 서버 어댑터
Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

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

에디트플러스 중국어 크랙 버전
작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

MinGW - Windows용 미니멀리스트 GNU
이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경