ThinkPHP est un excellent framework de développement PHP et est profondément apprécié des développeurs PHP. Dans le framework ThinkPHP, le modèle est l'un des éléments essentiels et constitue également un élément fréquemment utilisé dans les opérations de base de données. Le modèle résume les opérations de la base de données, ce qui rend l'exploitation de la base de données plus facile et plus pratique.
Cet article expliquera comment utiliser les modèles dans le framework ThinkPHP.
Dans le framework ThinkPHP, vous pouvez définir un modèle en héritant de la classe ThinkModel.
namespace app\model; use think\Model; class UserModel extends Model { // }
Ce qui précède est le code permettant de définir un modèle utilisateur simple. Parmi eux, UserModel hérite de la classe ThinkModel, indiquant que cette classe est un modèle. Nous pouvons définir certaines méthodes dans cette classe, par exemple :
public function getUserByName($name) { return $this->where('name', $name)->find(); }
Pour utiliser des modèles dans les contrôleurs, vous devez d'abord instancier le modèle, puis vous pouvez appeler les méthodes définies via le modèle.
namespace app\controller; use app\model\UserModel; use think\Controller; class UserController extends Controller { public function getUserByName($name) { $userModel = new UserModel(); $user = $userModel->getUserByName($name); return json($user); } }
Ce qui précède utilise le modèle dans le contrôleur. Nous introduisons d’abord la classe UserModel, puis instancions cette classe et appelons la méthode getUserByName.
Dans le framework ThinkPHP, les modèles prennent en charge l'association de tables de données, ce qui est très courant en développement. Par exemple, nous pouvons définir un modèle de commande et un modèle d'utilisateur, où le modèle de commande est associé à un utilisateur, et le code est le suivant :
class Order extends Model { public function user() { return $this->belongsTo('User'); } }
Ce ci-dessus est le code pour définir le modèle de commande, où la méthode utilisateur indique que le modèle Order appartient à un modèle User.
Si nous souhaitons interroger les informations utilisateur d'une commande, nous pouvons facilement y parvenir grâce à l'association de modèles :
$order = Order::get($id); $user = $order->user;
Le code ci-dessus renverra les informations utilisateur de la commande.
Dans le framework ThinkPHP, les modèles prennent en charge l'achèvement et la vérification automatiques. Par exemple, nous pouvons ajouter un champ de saisie semi-automatique au modèle User :
class UserModel extends Model { protected $auto = ['password']; protected function setPasswordAttr($value) { return md5($value); } }
Le code ci-dessus indique que lors de l'écriture des données, si le champ du mot de passe est transmis, il sera automatiquement converti en une chaîne cryptée en md5.
Si vous devez vérifier les données, vous pouvez ajouter une méthode de validation au modèle :
class UserModel extends Model { public function validateUser($data) { $rule = [ 'name' => 'require|unique:user', 'email' => 'require|email|unique:user', 'password' => 'require|min:6' ]; $message = [ 'name.require' => '用户名不能为空', 'name.unique' => '用户名已存在', 'email.require' => '邮箱不能为空', 'email.email' => '邮箱格式不正确', 'email.unique' => '邮箱已存在', 'password.require' => '密码不能为空', 'password.min' => '密码长度不能小于6位' ]; $validate = new Validate($rule, $message); return $validate->check($data); } }
Dans le code ci-dessus, nous avons défini une méthode validateUser pour vérifier les informations d'enregistrement de l'utilisateur. Des règles et des messages d'erreur sont définis. Appelez cette méthode dans le contrôleur pour effectuer la vérification.
Ce qui précède explique comment utiliser les modèles dans le framework ThinkPHP. Le modèle est une partie très couramment utilisée. Maîtriser comment utiliser le modèle rendra les opérations de base de données et le traitement des données plus pratiques.
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!