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

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

韦小宝
풀어 주다: 2023-03-17 17:04:02
원래의
1838명이 탐색했습니다.

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

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

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

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

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

연속 작업

추가 전에 데이터 개체가 생성된 경우(예: 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 메소드

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

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

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

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

相关推荐:

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

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

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

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

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿