Maison >cadre php >PensezPHP >Opérations de modèle dans thinkphp

Opérations de modèle dans thinkphp

尚
avant
2020-05-09 09:12:042767parcourir

Opérations de modèle dans thinkphp

Créer un nouveau modèle

Il existe deux méthodes :

La première consiste à créer manuellement

1. Créez un nouveau dossier modèle

2. Créez un nouveau fichier user.php. Il est préférable que le nom corresponde au nom de la table

3. Écrivez le code

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

La seconde consiste à utiliser la commande :

>php think make:model index/Blog

Modèle instanciation

Il existe trois manières :

1. Utilisez la méthode statique

use app\index\model\User;
 $li= User::get(1);

2. Utilisez la classe de chargement

use think\Loader;
$user= Loader::model(&#39;user&#39;);
 $li= $user::get(1);

3.

$user= model(&#39;User&#39;);
 $li= $user::get(1);

Opération de requête de base de données

get signifie interroger les données dont la clé primaire est 1. Ce qui suit consiste à interroger les données de name=thinkphp

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

Vous pouvez également utiliser la méthode de requête système

$user = new User();
$user->where(&#39;name&#39;, &#39;thinkphp&#39;)->find();

pour interroger plusieurs éléments de données

Utilisez la méthode 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;
}

Ou utilisez la méthode de requête pour afficher

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

Interrogez une valeur de champ

// 获取某个用户的积分
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;);

Vous pouvez également utiliser une requête dynamique

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

Nouvelles données

Utilisez la méthode de sauvegarde

$user           = new User;
$user->name     = &#39;thinkphp&#39;;
$user->email    = &#39;thinkphp@qq.com&#39;;
$user->save();

Utilisez la méthode par lots de données pour enregistrer

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

La méthode la plus couramment utilisée consiste à importer la publication ou obtenez des données pendant l'instanciation, puis enregistrez-les##Je le suis, je pense que c'est plus important

//如果需要过滤非数据表字段的数据,可以使用:
$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();

Obtenir l'identifiant des données insérées

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

Insérer plusieurs éléments de données

$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);

Vous pouvez également utiliser la fonction d'assistance

// 使用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);

Suppression des données, vous devez d'abord interroger, puis supprimer

Supprimer un

$user = User::get(1);
$user->delete();

Supprimer plusieurs

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

Supprimer selon les conditions

// 删除状态为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();

Mise à jour des données, il faut d'abord interroger, puis mettre à jour

$user = User::get(1);
$user->name     = &#39;thinkphp&#39;;
$user->email    = &#39;thinkphp@qq.com&#39;;
$user->save();

Mettre à jour selon les conditions

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

après la soumission, mettez directement à jour

$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]);

forcez la mise à jour pour empêcher l'ajout de

$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);

Ajoutez

$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;]);

à l'aide de la classe de base de données Tutoriel recommandé : "TP5"

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer