thinkphp5项目--企业单车网站(三)

项目地址

fry404006308/BicycleEnterpriseWebsite: Bicycle Enterprise Website
https://github.com/fry404006308/BicycleEnterpriseWebsite

一、动态查询

thinkphp支持动态查询,这就很方便了,可以根据自己功能或者用户查询自由查找

所以thinkphp功能应该很全,很多时候我可能需要多去找,有很多我不知道的功能

还有很多操作需要自己多用多敲才能会,不管多么复杂和难的,敲着敲着就特别简单了

动态查询

支持动态查询方法,例如:
// 根据name字段查询用户
$user = User::getByName('thinkphp');
// 根据email字段查询用户
$user = User::getByEmail('thinkphp@qq.com');
 动态调用:

 $user = new User;
$user->count();
$user->where('status','>',0)->count();
$user->where('status',1)->avg('score');
$user->max('score');

二、模型的两种使用方法

以查询为例:

1、直接在控制器中调用模型对象或者模型的静态方法查找数据库数据

2、在模型中通过方法查找好数据,然后在控制器中调用

1、直接在控制器中调用模型对象或者模型的静态方法查找数据库数据

 <?php
namespace app\admin\controller;
use think\Controller;
use app\admin\model\Admin as ModelAdmin; class Admin extends Controller
{
// //初始胡方法
// public function _initialize(){
// $modelAdmin= new ModelAdmin();
// } //列表页
public function lst()
{
$data=ModelAdmin::select();
dump($data);die;
return view('list');
}

2、在模型中通过方法查找好数据,然后在控制器中调用

模型

     public function getAdmin(){
return $this->select();
}

控制器

     public function lst()
{
$modelAdmin= new ModelAdmin();
$data=$modelAdmin->getAdmin();
dump($data);die;
return view('list');
}

注意调用方法是->,老是写成java中的.(点)

三、增删改查的业务逻辑

(1)、增加

  1、在控制器中获取页面表单数据然后传到数据库

 //增加页
public function add()
{
if(request()->isPost()){
//获取post提交的数据
$data=input('post.');
//模型处理获取的数据
$modelAdmin= new ModelAdmin();
//结果
$res=$modelAdmin->addAdmin($data); // $res=db('admin')->insert($data);
if($res){
$this->success('添加管理员成功!!',url('admin/lst'));
}else{
$this->error('添加管理员失败!!');
}
return;
}
return view();
}

(2)、删除

   1、在页面通过链接将用户id传给控制器

 <a href="#" onClick="warning('确实要删除吗', '{:url('admin/delete',array('id'=>$vo['id']))}')" class="btn btn-danger btn-sm shiny">
<i class="fa fa-trash-o"></i> 删除
</a>

   2、在控制中处理然后在数据库中删除这个特定id的用户

 //删除页
public function delete(){
//获取从页面传入的管理员id
$data=input('id');
//模型处理获取的数据
$modelAdmin= new ModelAdmin();
$res=$modelAdmin->deleteAdmin($data);
if($res){
$this->success('删除管理员成功!!',url('admin/lst'));
}else{
$this->error('删除管理员失败!!');
}
}

(3)、修改

  修改操作好像是删除操作和增加操作的一个综合体,步骤比较像删除操作+增加操作

  1、在页面通过链接将用户id传给控制器

 <a href="{:url('admin/edit',array('id'=>$vo['id']))}" class="btn btn-primary btn-sm shiny">
<i class="fa fa-edit"></i> 编辑
</a>

  2、在数据库中查询数据显示到修改页面

 /**part2**/
//获取界面传过来的id
$id=input('id');
//根据id查询数据
$modelAdmin= new ModelAdmin();
$data=$modelAdmin->findAdmin($id);
// dump($data);die;
//将数据传递到修改界面
$this->assign('data',$data);

  3、在控制器中获取页面修改好的表单数据然后传到数据库

         /**part3**/
//判断是否为用户post提交
if(request()->isPost()){
$data1=input('post.');
// dump($data1);die;
// 将修改好的数据传入到数据库
$res=$modelAdmin->editAdmin($data1);
if($res){
$this->success('修改管理员成功!!',url('admin/lst'));
}else{
$this->error('修改管理员失败!!');
}
}

(4)、查询

  1、从数据库中查询数据然后分配给页面

 //列表页
public function lst()
{
// $data=ModelAdmin::select();
$modelAdmin= new ModelAdmin();
$data=$modelAdmin->getAdmin();
$this->assign('data',$data);
return view('list');
}

三、thinkphp中引用自己的bootstrap分页样式

1、新增分页php页面,修改分页代码

2、修改配置文件

文件名字改的话就是该'type'=>'bootstrap',,如果你重写的样式是aaa.php,这里就弄成'type'=>'aaa',就好

四、部分字段更新

在更新数据的时候我们可能需要部分字段更新,比如密码为空表示不修改的情况

 //密码字段为空说明不修改密码
return $this->allowField(['username'])->save($data,['id']);

上面的代码是在模型中,表示只允许修改username字段,并且是根据id来修改

1、传数组进去修改的方法很棒

2、thinkphp模型中的方法和数据库中的方式有些是互通的

3、allowField用于部分字段更新

4、用save的时候直接返回成功或者失败的条数(0,1等),用update的时候就是一堆其它的

5、allowField只对save有效,对update无效

五、没必要所有的数据库操作都通过模型

没必要所有的数据库操作都通过模型,有些很简单不用处理数据的就直接在控制器就好

比较一下下面两种根据id查找管理员信息的方法

1、直接控制器中:

$data=db('admin')->find($id);

2、通过模型:

在控制中代码

 /**part2**/
//获取界面传过来的id
$id=input('id');
//根据id查询数据
$modelAdmin= new ModelAdmin();
$data=$modelAdmin->findAdmin($id);
// dump($data);die;
//将数据传递到修改界面
$this->assign('data',$data);

模型中代码

     /**
* 根据管理员id查找数据
* @param [type] $id [description]
* @return [type] [description]
*/
public function findAdmin($id){
$data=$this->find($id);
// dump($data);die;
return $data;
}

一个通过助手函数一行代码,一个19行代码还容易错,不用太规矩,怎么简单怎么来,怎么方便自己,方便大家怎么来。

六、field关键词取部分数据

比如当我们表单不需要显示密码的时候,我们可以不取密码,当然也可以取了不显示

$date=db('admin')->field('id,username')->find($id);

比如文章表里面,用不到的时候可以指定不用取文章,不然浪费服务器性能太大了

七、关于注释

不是所有的方法都需要写注释,有一些非常非常非常见名知意的方法就不用写啊,比如add,delete,edit,,或者说不用写那么详细

因为注释的作用是方便你,方便大家,怎么简单方便怎么来

关于算法步骤,这个一定要写,这个写了之后思路特别清晰,效率非常高

thinkphp5项目--企业单车网站(三)的更多相关文章

  1. thinkphp5项目--企业单车网站(五)

    thinkphp5项目--企业单车网站(五) 项目地址 fry404006308/BicycleEnterpriseWebsite: Bicycle Enterprise Websitehttps:/ ...

  2. thinkphp5项目--企业单车网站(四)

    thinkphp5项目--企业单车网站(四) 项目地址 fry404006308/BicycleEnterpriseWebsite: Bicycle Enterprise Websitehttps:/ ...

  3. thinkphp5项目--企业单车网站(二)

    thinkphp5项目--企业单车网站(二) 项目地址 fry404006308/BicycleEnterpriseWebsite: Bicycle Enterprise Websitehttps:/ ...

  4. thinkphp5项目--企业单车网站(一)

    thinkphp5项目--企业单车网站(一) 项目地址 fry404006308/BicycleEnterpriseWebsite: Bicycle Enterprise Websitehttps:/ ...

  5. thinkphp5项目--企业单车网站(七)

    thinkphp5项目--企业单车网站(七) 项目地址 fry404006308/BicycleEnterpriseWebsite: Bicycle Enterprise Websitehttps:/ ...

  6. thinkphp5项目--企业单车网站(九)(加强复习啊)(花了那么多时间写的博客,不复习太浪费了)

    thinkphp5项目--企业单车网站(九)(加强复习啊)(花了那么多时间写的博客,不复习太浪费了) 项目地址 fry404006308/BicycleEnterpriseWebsite: Bicyc ...

  7. thinkphp5项目--企业单车网站(六)

    thinkphp5项目--企业单车网站(六) 项目地址 fry404006308/BicycleEnterpriseWebsite: Bicycle Enterprise Websitehttps:/ ...

  8. thinkphp5项目--企业单车网站(八)(文章板块要点)(删除图片)

    thinkphp5项目--企业单车网站(八)(文章板块要点)(删除图片) 项目地址 fry404006308/BicycleEnterpriseWebsite: Bicycle Enterprise ...

  9. thinkphp5项目--练手--企业单车网站(九)(友情链接)

    thinkphp5项目--练手--企业单车网站(九)(友情链接) 项目地址 fry404006308/BicycleEnterpriseWebsite: Bicycle Enterprise Webs ...

随机推荐

  1. PHP通过DOM操作XML

    PHP XML操作类DOMDocument属性及方法 注意大小写一定不能弄错. 属性: Attributes 存储节点的属性列表(只读) childNodes 存储节点的子节点列表(只读) dataT ...

  2. axios 使用post方式传递参数,后端接受不到问题

    一.URLSearchParams var params = new URLSearchParams(); params.append('key1', 'value1'); //你要传给后台的参数值 ...

  3. 用centos镜像 制作本地yum源

    1.上传iso镜像 2.挂载镜像到相应目录 mkdir /yumiso #创建目录mount -t iso9660 /dev/cdrom/sr0 /yumiso #挂载镜像文件到对应目录 3.备份旧的 ...

  4. 【Henu ACM Round#24 D】Iterated Linear Function

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 把B提取出来就是一个等比数列了. 求和一下会发现是这种形式. \(B*\frac{(A^n-1)}{A-1}+A^n*x\) 则求一 ...

  5. Google C++ Style Guide的哲学

    Google C++ Style Guide并不是一个百科全书,也不是一个C++使用指南,但它描述适用于Google及其开源项目的编码指南,并不追求全面和绝对正确,也有许多人置疑它的一些规则.但作为一 ...

  6. 洛谷 P2183 巧克力

    P2183 巧克力 题目描述 佳佳邀请了M个同学到家里玩.为了招待客人,她需要将巧克力分给她的好朋友们.她有N(1<=N<=5000)块巧克力,但是大小各不一样,第i块巧克力大小为为1*X ...

  7. ajax动态添加复选框

    function getLands() { $.ajax({ url:"httpserver.do?doPost&userQygs="+$("#userQygs& ...

  8. 去除ListView 上下边界蓝色或黄色阴影

    默认的情况下,在 ListView 滑动到顶部或者是底部的时候,会有黄色或者蓝色的阴影出现.在不同的版本号上解决办法是不同的,在 2.3 版本号之前能够在 ListView 的属性中通过设置 andr ...

  9. spark 卡在spark context,运行出现spark Exception encountered while connecting to the server : javax.security.sasl.SaslException

    原因: 使用root用户运行spark代码 解决方法:使用非管理员账户运行spark即可 [userone@localhost bin]$ ./add-user.sh What type of use ...

  10. BZOJ 2049 LCT

    思路:LCT的基本操作 //By SiriusRen #include <cstdio> #include <cstring> #include <algorithm&g ...