찾다
백엔드 개발PHP 튜토리얼ThinkPHP에서 추가, 삭제, 수정 및 체크인

ThinkPHP에서 추가, 삭제, 수정 및 체크인

Nov 29, 2017 am 10:32 AM
thinkphptp추가, 삭제, 수정 및 확인

thinkphp는 tp로 축약되는 PHP 프레임워크입니다. 오늘은 tp의 추가, 삭제, 수정에 대해 알아보겠습니다. 이전에 사용했던 네이티브가 정말 너무하다고 생각합니다. 죄송합니다. 제가 쓰는 모든 것에 빨리 사용하고 싶습니다 tp, 살펴보겠습니다!

1. 작업 생성 ThinkPHP의 add 메소드를 사용하여 데이터베이스에 데이터를 추가합니다.

사용 방법은 다음과 같습니다.

$User = M("User"); // 实例化User对象
$data['name'] = 'ThinkPHP';
$data['email'] = 'ThinkPHP@gmail.com';
$User->add($data);

또는 데이터 방법을 사용합니다

연속 작업

$User->data($data)->add();
추가 전에 데이터 개체가 생성된 경우(예: create 또는 data 방법 사용) add 방법은 수행되지 않습니다. 데이터를 전달해야 합니다.

create 메소드 사용 예:

$User = M("User"); // 实例化User对象

//

$User->create();
$User->add(); // 根据条件保存修改的数据

양식으로 제출한 POST 데이터를 기반으로 데이터 객체를 생성합니다. 기본 키가 자동 성장 유형이고

데이터 삽입

이 성공하면 Add 메서드의 반환 값은 최신입니다. 삽입된 기본 키 값을 직접 얻을 수 있습니다.

2. 데이터 읽기 ThinkPHP에서 데이터를 읽는 방법은 여러 가지가 있는데, 일반적으로 데이터 읽기와 데이터 세트 읽기로 나누어집니다.

findall 또는 select 메소드를 사용하여 데이터 세트 읽기(findall과 select 메소드는 동일함):

$User = M("User"); // 实例化User对象

// 상태 값이 1인 사용자 데이터를 찾아 생성 시간별로 정렬된 10개의 데이터를 반환합니다.

$list = $User->where('status=1')->order('create_time')->limit(10)->select();

반환 select 메소드의 값은

2차원 배열

이며, 결과가 없으면 빈 배열이 반환됩니다. 위에서 언급한 일관된 작업 방법을 사용하면 복잡한 데이터 쿼리를 완료할 수 있습니다. 가장 복잡하고 일관된 방법은 where 메소드를 사용하는 것입니다. 이 부분은 많은 내용을 포함하기 때문에 쿼리 언어 부분에서 쿼리 조건을 조합하는 방법에 대한 자세한 지침을 제공합니다. 기본 질의에는 당분간 관련 질의 부분은 포함하지 않으나, 연관 모델을 이용하여 데이터 연산을 수행하는 부분은 연관 모델 부분을 참고하시기 바랍니다. 찾기 방법을 사용하여 데이터 읽기:

데이터 읽기 작업은 실제로 데이터 세트의 작업과 유사합니다. 선택에 사용할 수 있는 모든 일관된 작업 방법은 찾기 방법에도 사용할 수 있습니다. 메소드는 최대 하나의 레코드만 반환하므로 찾기 쿼리 작업에는 제한 메소드가 유효하지 않습니다.

$User = M("User"); // 实例化User对象

// 상태값이 1이고 이름값이 있는 사용자 데이터 찾기 think

$User->where('status=1 AND name="think" ')->find();

조건에 맞는 데이터가 2개 이상 있어도 find 메소드는 첫 번째 레코드만 반환합니다.

특정 필드의 값을 읽으려면 getField 메소드를 사용할 수 있습니다. 예:

$User = M("User"); // 实例化User对象

//ID가 3인 사용자의 닉네임을 가져옵니다

$nickname = $User->where('id=3')->getField('nickname');

필드가 하나만 있는 경우 값 항상 반환됩니다.

여러 필드가 전달되면 연관 배열이 반환될 수 있습니다.

$User = M("User"); // 实例化User对象

// 모든 사용자의 ID 및 닉네임 목록 가져오기

$list = $User->getField('id,nickname');

반환된 목록은 배열이고, 키 이름은 사용자의 ID이며, 키 값은 사용자 별명입니다.

3. 데이터 업데이트 ThinkPHP의 save 메소드를 사용하여 데이터베이스를 업데이트하고 일관된 작업 사용도 지원합니다.

$User = M("User"); // 实例化User对象

//수정할 데이터 개체 속성 할당

$data['name'] = 'ThinkPHP';
$data['email'] = 'ThinkPHP@gmail.com';
$User->where('id=5')->save($data); // 根据条件保存修改的数据

데이터베이스의 보안을 보장하고 오류를 방지하려면 업데이트 조건이 없고 데이터 개체 자체에 포함되지 않은 경우 전체 데이터 테이블을 업데이트하세요. 기본 키 필드에서는 저장 방법이 데이터베이스의 레코드를 업데이트하지 않습니다.

따라서 다음 코드는 데이터베이스의 어떤 레코드도 변경하지 않습니다.

$User->save($data);

다음 방법을 사용하지 않는 한:

$User = M("User"); // 实例化User对象

//수정할 데이터 개체 속성 할당

$data['id'] = 5;
$data['name'] = 'ThinkPHP';
$data['email'] = 'ThinkPHP@gmail.com';
$User->save($data); // 根据条件保存修改的数据

id가 데이터 테이블의 기본 키인 경우 , 시스템은 자동으로 기본 키 값을 업데이트 조건으로 사용하여 다른 필드의 값을 업데이트합니다.

또 다른 방법은 create나 data 메소드를 통해 업데이트할 데이터 객체를 생성한 후 저장하는 방법이 있어서, save 메소드의 매개변수를 전달할 필요가 없습니다.

$User = M("User"); // 实例化User对象

// 수정할 데이터 객체 속성 지정

$data['name'] = 'ThinkPHP';
$data['email'] = 'ThinkPHP@gmail.com';
$User->where('id=5')->data($data)->save(); // 根据条件保存修改的数据

create 메소드 사용 예:

$User = M("User"); // 实例化User对象

//

$User->create();
$User->save(); //根据条件保存要修改的数据

양식으로 제출된 POST 데이터를 기반으로 데이터 객체를 생성합니다. 위의 경우 양식에는 기본 키가 포함되어야 합니다. 저장 작업을 완료하려면 이름의 숨겨진 필드가 필요합니다.

개별 필드의 값만 업데이트하는 경우 setField 메서드를 사용할 수 있습니다.

$User = M("User"); // 实例化User对象

// 사용자 이름 값 변경

$User-> where('id=5')->setField('name','ThinkPHP');

setField 메서드는 동시에 여러 필드 업데이트를 지원합니다. 배열을 전달하기만 하면 됩니다. 예:

$User = M("User"); // 实例化User对象

//사용자 이름 및 이메일 값 변경

$User-> where('id=5')->setField(array('name','email'),array('ThinkPHP','ThinkPHP@gmail.com'));

통계 필드(일반적으로 숫자 유형) 업데이트를 위해 시스템은 setInc 및 setDec 메소드도 제공합니다.

$User = M("User"); // 实例化User对象
$User->setInc('score','id=5',3);// 用户的积分加3
$User->setInc('score','id=5'); // 用户的积分加1
$User->setDec('score','id=5',5);// 用户的积分减5
$User->setDec('score','id=5'); // 用户的积分减1

4. 데이터 삭제 ThinkPHP의

delete 메소드

를 사용하여 데이터베이스의 레코드를 삭제하세요. 삭제 작업은 일관된 작업을 사용하여 수행할 수도 있습니다.

$User = M("User"); // 实例化User对象
$User->where('id=5')->delete(); // 删除id为5的用户数据
$User->where('status=0')->delete(); // 删除所有状态为0的用户数据

delete方法可以用于删除单个或者多个数据,主要取决于删除条件,也就是where方法的参数,也可以用order和limit方法来限制要删除的个数,例如:

// 删除所有状态为0的5个用户数据按照创建时间排序

$User->where('status=0')->order('create_time')->limit('5')->delete();

以上就是tp的增删查改四种方法了,更多关于tp的内天请到本站搜索哦~

相关推荐:

tp上传图片与生成缩略图功能的实现示例

TP5实现邮件发送服务封装以及可发附件的实例

TP5改写跳转提示页面的实现方法

위 내용은 ThinkPHP에서 추가, 삭제, 수정 및 체크인의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
세션을 저장하기 위해 데이터베이스를 사용하면 어떤 장점이 있습니까?세션을 저장하기 위해 데이터베이스를 사용하면 어떤 장점이 있습니까?Apr 24, 2025 am 12:16 AM

데이터베이스 스토리지 세션 사용의 주요 장점에는 지속성, 확장 성 및 보안이 포함됩니다. 1. 지속성 : 서버가 다시 시작 되더라도 세션 데이터는 변경되지 않아도됩니다. 2. 확장 성 : 분산 시스템에 적용하여 세션 데이터가 여러 서버간에 동기화되도록합니다. 3. 보안 : 데이터베이스는 민감한 정보를 보호하기 위해 암호화 된 스토리지를 제공합니다.

PHP에서 사용자 정의 세션 처리를 어떻게 구현합니까?PHP에서 사용자 정의 세션 처리를 어떻게 구현합니까?Apr 24, 2025 am 12:16 AM

SessionHandlerInterface 인터페이스를 구현하여 PHP에서 사용자 정의 세션 처리 구현을 수행 할 수 있습니다. 특정 단계에는 다음이 포함됩니다. 1) CustomsessionHandler와 같은 SessionHandlerInterface를 구현하는 클래스 만들기; 2) 인터페이스의 방법 (예 : Open, Close, Read, Write, Despare, GC)의 수명주기 및 세션 데이터의 저장 방법을 정의하기 위해 방법을 다시 작성합니다. 3) PHP 스크립트에 사용자 정의 세션 프로세서를 등록하고 세션을 시작하십시오. 이를 통해 MySQL 및 Redis와 같은 미디어에 데이터를 저장하여 성능, 보안 및 확장 성을 향상시킬 수 있습니다.

세션 ID 란 무엇입니까?세션 ID 란 무엇입니까?Apr 24, 2025 am 12:13 AM

SessionId는 웹 애플리케이션에 사용되는 메커니즘으로 사용자 세션 상태를 추적합니다. 1. 사용자와 서버 간의 여러 상호 작용 중에 사용자의 신원 정보를 유지하는 데 사용되는 무작위로 생성 된 문자열입니다. 2. 서버는 쿠키 또는 URL 매개 변수를 통해 클라이언트로 생성하여 보낸다. 3. 생성은 일반적으로 임의의 알고리즘을 사용하여 독창성과 예측 불가능 성을 보장합니다. 4. 실제 개발에서 Redis와 같은 메모리 내 데이터베이스를 사용하여 세션 데이터를 저장하여 성능 및 보안을 향상시킬 수 있습니다.

무국적 환경 (예 : API)에서 세션을 어떻게 처리합니까?무국적 환경 (예 : API)에서 세션을 어떻게 처리합니까?Apr 24, 2025 am 12:12 AM

JWT 또는 쿠키를 사용하여 API와 같은 무국적 환경에서 세션을 관리 할 수 ​​있습니다. 1. JWT는 무국적자 및 확장 성에 적합하지만 빅 데이터와 관련하여 크기가 크다. 2. 쿠키는보다 전통적이고 구현하기 쉽지만 보안을 보장하기 위해주의해서 구성해야합니다.

세션과 관련된 크로스 사이트 스크립팅 (XSS) 공격으로부터 어떻게 보호 할 수 있습니까?세션과 관련된 크로스 사이트 스크립팅 (XSS) 공격으로부터 어떻게 보호 할 수 있습니까?Apr 23, 2025 am 12:16 AM

세션 관련 XSS 공격으로부터 응용 프로그램을 보호하려면 다음 조치가 필요합니다. 1. 세션 쿠키를 보호하기 위해 Httponly 및 Secure 플래그를 설정하십시오. 2. 모든 사용자 입력에 대한 내보내기 코드. 3. 스크립트 소스를 제한하기 위해 컨텐츠 보안 정책 (CSP)을 구현하십시오. 이러한 정책을 통해 세션 관련 XSS 공격을 효과적으로 보호 할 수 있으며 사용자 데이터가 보장 될 수 있습니다.

PHP 세션 성능을 어떻게 최적화 할 수 있습니까?PHP 세션 성능을 어떻게 최적화 할 수 있습니까?Apr 23, 2025 am 12:13 AM

PHP 세션 성능을 최적화하는 방법 : 1. 지연 세션 시작, 2. 데이터베이스를 사용하여 세션을 저장, 3. 세션 데이터 압축, 4. 세션 수명주기 관리 및 5. 세션 공유 구현. 이러한 전략은 높은 동시성 환경에서 응용의 효율성을 크게 향상시킬 수 있습니다.

SESSION.GC_MAXLIFETIME 구성 설정은 무엇입니까?SESSION.GC_MAXLIFETIME 구성 설정은 무엇입니까?Apr 23, 2025 am 12:10 AM

THESESSION.GC_MAXLIFETIMESETTINGINSTTINGTINGSTINGTERMINESTERMINESTERSTINGSESSIONDATA, SETINSECONDS.1) IT'SCONFIGUDEDINPHP.INIORVIAINI_SET ()

PHP에서 세션 이름을 어떻게 구성합니까?PHP에서 세션 이름을 어떻게 구성합니까?Apr 23, 2025 am 12:08 AM

PHP에서는 Session_Name () 함수를 사용하여 세션 이름을 구성 할 수 있습니다. 특정 단계는 다음과 같습니다. 1. Session_Name () 함수를 사용하여 Session_Name ( "my_session")과 같은 세션 이름을 설정하십시오. 2. 세션 이름을 설정 한 후 세션을 시작하여 세션을 시작하십시오. 세션 이름을 구성하면 여러 응용 프로그램 간의 세션 데이터 충돌을 피하고 보안을 향상시킬 수 있지만 세션 이름의 독창성, 보안, 길이 및 설정 타이밍에주의를 기울일 수 있습니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

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

뜨거운 도구

SecList

SecList

SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

PhpStorm 맥 버전

PhpStorm 맥 버전

최신(2018.2.1) 전문 PHP 통합 개발 도구

WebStorm Mac 버전

WebStorm Mac 버전

유용한 JavaScript 개발 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

DVWA

DVWA

DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는