thinkphp의 모델 작업

풀어 주다: 2020-05-09 09:12:04
앞으로
2711명이 탐색했습니다.

thinkphp의 모델 작업

새 모델을 만드는 방법에는 두 가지가 있습니다

:

하나는 수동으로 만드는 것입니다

1 새 모델 폴더를 만듭니다

2. 이름은 테이블 이름과 일치하는 것이 가장 좋습니다

3. 코드 작성

<?php
namespace app\index\model;
use think\Model;
class User extends Model
{
//如果表名和文件名不是对应的,用下面代码修改
protected $table = &#39;think_user&#39;;
    }
로그인 후 복사

두 번째는

>php think make:model index/Blog
로그인 후 복사

모델 인스턴스화

세 가지 방법이 있습니다.

1.

use app\index\model\User;
 $li= User::get(1);
로그인 후 복사

2. 로딩 클래스를 사용하세요

use think\Loader;
$user= Loader::model(&#39;user&#39;);
 $li= $user::get(1);
로그인 후 복사

3. 시스템 메소드를 사용하세요

$user= model(&#39;User&#39;);
 $li= $user::get(1);
로그인 후 복사

데이터베이스의 쿼리 작업

get은 기본 키 1로 데이터를 쿼리하는 것을 의미합니다. 다음은 name=thinkphp

//取出主键为1的数据
$user = User::get(1);
// 使用数组查询
$user = User::get([&#39;name&#39; => &#39;thinkphp&#39;]);
로그인 후 복사

의 데이터를 쿼리하는 방법입니다

$user = new User();
$user->where(&#39;name&#39;, &#39;thinkphp&#39;)->find();
로그인 후 복사

시스템 쿼리 방법을 사용하여 여러 개의 데이터를 쿼리할 수도 있습니다

all() 메서드를 사용하거나

// 根据主键获取多个数据
$list = User::all(&#39;1,2,3&#39;);
// 或者使用数组
$list = User::all([1,2,3]);
foreach($list as $key=>$user){
    echo $user->name;
}
// 使用数组查询
$list = User::all([&#39;status&#39;=>1]);
// 使用闭包查询
$list = User::all(function($query){
    $query->where(&#39;status&#39;, 1)->limit(3)->order(&#39;id&#39;, &#39;asc&#39;);
});
foreach($list as $key=>$user){
    echo $user->name;
}
로그인 후 복사

또는 쿼리 방법을 사용하세요

$user = new User();
// 查询数据集
$user->where(&#39;name&#39;, &#39;thinkphp&#39;)
    ->limit(10)
    ->order(&#39;id&#39;, &#39;desc&#39;)
    ->select();
로그인 후 복사

특정 필드 값을 쿼리하려면

// 获取某个用户的积分
User::where(&#39;id&#39;,10)->value(&#39;score&#39;);
// 获取某个列的所有值
User::where(&#39;status&#39;,1)->column(&#39;name&#39;);
// 以id为索引
User::where(&#39;status&#39;,1)->column(&#39;name&#39;,&#39;id&#39;);
User::where(&#39;status&#39;,1)->column(&#39;id,name&#39;);
로그인 후 복사

동적 쿼리를 사용할 수도 있습니다

// 根据name字段查询用户
$user = User::getByName(&#39;thinkphp&#39;);
// 根据email字段查询用户
$user = User::getByEmail(&#39;thinkphp@qq.com&#39;);
로그인 후 복사

새 데이터

저장 방법 사용

$user           = new User;
$user->name     = &#39;thinkphp&#39;;
$user->email    = &#39;thinkphp@qq.com&#39;;
$user->save();
로그인 후 복사

데이터 일괄 처리 방법을 사용하여 저장

$user = new User;
$user->data([
    &#39;name&#39;  =>  &#39;thinkphp&#39;,
    &#39;email&#39; =>  &#39;thinkphp@qq.com&#39;
]);
$user->save();
로그인 후 복사

가장 일반적으로 사용되는 방법은 다음과 같습니다. 게시물을 가져오거나 인스턴스화 중에 데이터를 가져온 다음 저장## 이것이 더 중요하다고 생각합니다

//如果需要过滤非数据表字段的数据,可以使用:
$user = new User($_POST);
// 过滤post数组中的非数据表字段数据
$user->allowField(true)->save();

//如果你通过外部提交赋值给模型,并且希望指定某些字段写入,可以使用:
$user = new User($_POST);
// post数组中只有name和email字段会写入
$user->allowField([&#39;name&#39;,&#39;email&#39;])->save();
로그인 후 복사

삽입된 데이터 ID 가져오기

$user           = new User;
$user->name     = &#39;thinkphp&#39;;
$user->email    = &#39;thinkphp@qq.com&#39;;
$user->save();
// 获取自增ID
echo $user->user_id;
로그인 후 복사

여러 데이터 조각 삽입

$user = new User;
$list = [
    [&#39;name&#39;=>&#39;thinkphp&#39;,&#39;email&#39;=>&#39;thinkphp@qq.com&#39;],
    [&#39;name&#39;=>&#39;onethink&#39;,&#39;email&#39;=>&#39;onethink@qq.com&#39;]
];
$user->saveAll($list);
로그인 후 복사

헬퍼 기능을 사용할 수도 있습니다

// 使用model助手函数实例化User模型
$user = model(&#39;User&#39;);
// 模型对象赋值
$user->data([
    &#39;name&#39;  =>  &#39;thinkphp&#39;,
    &#39;email&#39; =>  &#39;thinkphp@qq.com&#39;
]);
$user->save();

或者进行批量新增:
$user = model(&#39;User&#39;);
// 批量新增
$list = [
    [&#39;name&#39;=>&#39;thinkphp&#39;,&#39;email&#39;=>&#39;thinkphp@qq.com&#39;],
    [&#39;name&#39;=>&#39;onethink&#39;,&#39;email&#39;=>&#39;onethink@qq.com&#39;]
];
$user->saveAll($list);
로그인 후 복사

데이터 삭제, 먼저 쿼리한 후 삭제해야 합니다

한 개 삭제

$user = User::get(1);
$user->delete();
로그인 후 복사

여러 개 삭제

User::destroy(1);
// 支持批量删除多个数据
User::destroy(&#39;1,2,3&#39;);
// 或者
User::destroy([1,2,3]);
로그인 후 복사

조건에 따라 삭제

// 删除状态为0的数据
User::destroy([&#39;status&#39; => 0]);

还支持使用闭包删除,例如:
User::destroy(function($query){
    $query->where(&#39;id&#39;,&#39;>&#39;,10);
});

或者通过数据库类的查询条件删除
User::where(&#39;id&#39;,&#39;>&#39;,10)->delete();
로그인 후 복사

데이터 업데이트, 먼저 쿼리한 후 업데이트

$user = User::get(1);
$user->name     = &#39;thinkphp&#39;;
$user->email    = &#39;thinkphp@qq.com&#39;;
$user->save();
로그인 후 복사

에 따라 업데이트 조건

$user = new User;
// save方法第二个参数为更新条件
$user->save([
    &#39;name&#39;  => &#39;thinkphp&#39;,
    &#39;email&#39; => &#39;thinkphp@qq.com&#39;
],[&#39;id&#39; => 1]);
로그인 후 복사

제출 후 직접 업데이트

$user = new User();
// 过滤post数组中的非数据表字段数据
$user->allowField(true)->save($_POST,[&#39;id&#39; => 1]);

//如果你通过外部提交赋值给模型,并且希望指定某些字段写入,可以使用:
$user = new User();
// post数组中只有name和email字段会写入
$user->allowField([&#39;name&#39;,&#39;email&#39;])->save($_POST, [&#39;id&#39; => 1]);
로그인 후 복사

추가 방지를 위해 강제 업데이트

$user = new User;
$list = [
    [&#39;id&#39;=>1, &#39;name&#39;=>&#39;thinkphp&#39;, &#39;email&#39;=>&#39;thinkphp@qq.com&#39;],
    [&#39;id&#39;=>2, &#39;name&#39;=>&#39;onethink&#39;, &#39;email&#39;=>&#39;onethink@qq.com&#39;]
];
$user->isUpdate()->saveAll($list);
로그인 후 복사

데이터베이스 클래스로 추가

$user = new User;
$user->where(&#39;id&#39;, 1)
    ->update([&#39;name&#39; => &#39;thinkphp&#39;]);
或者使用:
$user = new User;
$user->update([&#39;id&#39; => 1, &#39;name&#39; => &#39;thinkphp&#39;]);
로그인 후 복사

추천 튜토리얼: "TP5"

위 내용은 thinkphp의 모델 작업의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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