ホームページ > PHPフレームワーク > ThinkPHP > thinkphp でのモデル操作

thinkphp でのモデル操作

リリース: 2020-05-09 09:12:04
転載
2747 人が閲覧しました

thinkphp でのモデル操作

#新しいモデルの作成

方法は 2 つあります:

1 つは手動で作成する方法です

1. 新しいモデル フォルダーを作成します

2. 新しいファイル user.php を作成します。名前がテーブル名に対応していることが最善です。

3. コードを記述します

<?php
namespace app\index\model;
use think\Model;
class User extends Model
{
//如果表名和文件名不是对应的,用下面代码修改
protected $table = &#39;think_user&#39;;
    }
ログイン後にコピー

2 つ目は、コマンド:


>php think make:model index/Blog
ログイン後にコピー

を使用します。モデルのインスタンス化

3 つの方法があります:

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();
ログイン後にコピー

最も一般的に使用されるのは、post または get をインポートすることです。インスタンス化中にデータを保存してから保存します##私はここの方が重要だと感じています

//如果需要过滤非数据表字段的数据,可以使用:
$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);
ログイン後にコピー

データ削除。最初にクエリを実行してから削除する必要があります。

1 つのアイテムを削除

$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 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:csdn.net
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート