初识thinkphp(5)

这次主要内容是模型的基本操作

0x01:什么是模型

通过手册的阅览,笼统的说就是,把打开数据库等操作在另一个php文件中进行

以及对变量的规则具体细节,查询,取值等操作进行定义,方便在控制器中直接使用。

0x02:模型的使用

在index目录下创建与controller同级的目录model

创建php模型文件,并调用think\Model文件

<?php
    namespace app\index\model;
    use think\Model;
    class User extends Model{
        protected $table = 'think_user';
        protected function getBirthdayAttr($birthday){
            return date('Y-m-d', $birthday);
        }
        protected function setBirthdayAttr($value){
            return strtotime($value);
        }
        protected function scopeEmail($query){
            $query->where('email', '[email protected]');
        }
    }

?>

table是获取数据库变量,之前在application\database.php文件中已经对打开数据库进行关联了。

getBirthdayAttr函数中命名规则 get + 名称 + Attr

这样能在控制器中直接调用 echo birthday变量 而不用再用date()函数进行转换

setBirthdayAttr函数中命名规则 set + 名称 + Attr

这样在控制器中修改birthday不用调用strtotime()函数,而是直接的user->birthday = 'xxxx-xx-xx'

scopeEmail函数中命名规则 scope + 名称

这样在查询的时候不用再写sql语句或者thinkphp自带的sql调用,就可以查询相关联内容

注意:这里的函数中“名称”即使变量名,如果不是变量名,会出现错误。

0x03:在控制器中模型的调用

对于数据库的操作无意就是增删改查

 public function add()
    {
        $user           = new UserModel;
        $user->nickname = 'sijidou';
        $user->email    = '[email protected]';
        $user->birthday = "1998-10-30"      //strtotime('1998-10-30');
        if ($user->save()) {
            return 增加成功信息;
        } else {
            return $user->getError();
        }
    }

增加无疑就是new一个模型,注意这里的对象是模型里面的类名,这里因为控制器名字也叫User于是用引用修改了下模型中的User的名字

    use app\index\model\User as UserModel;

这里的birthday实则调用了模型中的setBirthdayAttr函数,如果没有setBirthdayAttr函数,信息可以存储,但在最后输出时候时间固定是1970-01-01的默认值(我这里是这样的)

    public function update($id){
            $user = UserModel::get($id);
            $user->nickname = 'tudou';
            $user->email = '[email protected]';
            $user->birthday = '1999-4-5';
            $user->save();
        }

        public function delete($id){
            $user = UserModel::get($id);
            if($user){
                $user->delete();
                return '删除用户成功';
            }
            else{
                return '删除用户不成功';
            }
        }
        public function search($email){
            $list = UserModel::scope('email', $email)->select();
            foreach($list as $user){
                echo $user->nickname . '<br/>';
                echo $user->email . '<br/>';
                echo $user->birthday . '<br/>';
            }
        }

改删查中,改和删都用到的是get,对应的默认调用了getBirthdayAttr函数,而查中的scope则调用的是scopeEmail函数,如果将email变量该为nickname并在模型中添加相应的scopeNickname($nickname)那么可以根据nickname的值进行查询。

0x04:与view之间的交互

这里我使用的官方提供的html模板,源码就不贴了,反正就是个form表格,和一点css。

 这里将控制器的内容传到视图里面去,需要用view方法,且对应打开的视图文件名称默认为方法名称

 

访问的路径为http://192.168.60.132/index/user/create

这里对add()函数进行修改

input函数这里是thinkphp特有的参数,主要功能是用来修改将代码赋值内容改为用接收post传参这里的"post."中的'.'主要是用来匹配所有的参数,如果具体到某一个可以"post.nickname"

allowField(true)是thinkphp中特有的函数,功能是用来过滤非数据表中的数据

validate()函数是tinkphp中特有的函数,功能主要是用来校验post过来的数据是否符合规范。

validate的内容在validate的模板中定义(在5.1版本中不可这样定义了,直接在控制器下写个函数就行)

validate模板路径  .\index\validate\User.php

内容为

 

用rule来给键值对规定

require是必填

min:5是长度最小为5

email是检测是否符合邮箱规范

dateFormat:Y-m-d检测是否符合日期规范(数值不在月份日份以内也不行)

checkMail自定义方法:$value => email参数 $rule => 'qq.com'规则,用if语句判断

preg_match是用于正则表达式匹配的比较函数

0x05:关联与输出

手册讲的挺多的,无非就是一对一、一对多、多对多

一对一:在一个中用this->hasOne(另一个模型名),另一个用belongsTo(前一个模型名)

一对多:在一个中用this->hasMany()来定义额外的(),其他与一对一一样

多对多:与一对多差不多,即在每个模型中的belongToMany(对应模型1,对应模型2,。。。)

在add中如果要对关联的模型修改

当前模型->关联模型->关联模型变量 = 内容

 保存时候用(这里用的示例函数,作者懒不想测试了,以后用得上再使用)

模型输出

无非就是操作器里面输出或者跳转到视图里面输出

跳转到视图用view('视图文件名字'),一般是在controller同级目录下的view文件里面

不带参数默认与方法名字相同。

在操作器内输出用var_dump也行,return也行

这里还可以用ToArray()来将数组输出,hidden([变量名])来隐藏相应变量输出,visible([变量])来指定有且只有定义的变量输出。

总结:这节内容差不多就这样,之前写的几篇示例我觉得太详细了,以至于像教科书般的流水账,写博文主要还是记笔记,记重点,所以这里比较精简。以及最后的关联相关的内容并没有测试,等到以后实际操作时候再用吧。最近要期末了,又没期末复习,又没写博客,真是太颓废了。

猜你喜欢

转载自www.cnblogs.com/sijidou/p/9195986.html
今日推荐