7.1 连接数据库 (06:15) 1

7.2实例化模型 1

1.实例化基础模型 2

2. 实例化用户自定义模型 2

问题 2

3. 实例化公共模型 4

4. 实例化空模型 7

 

7.1 连接数据库 (06:15)

Tp内置啦一个数据库函数   支持大多主流数据库

数据库配置

'DB_TYPE'               =>  'mysql',     // 数据库类型
'DB_HOST'               =>  'www.234.com', // 服务器地址
'DB_NAME'               =>  'muck',          // 数据库名
'DB_USER'               =>  'root',      // 用户名
'DB_PWD'                =>  'root',          // 密码
'DB_PORT'               =>  '3306',        // 端口
'DB_PREFIX'             =>  'mk_',    // 数据库表前缀

 

7.2实例化模型

1.实例化基础模型

public function user(){

//1.实例化基础模型
//$user=new Model('user');//表名,表前缀,数据库连接信息
 $user=M('user');
 $data=$user->select();//查询表
 dump($data);

D方法是M方法的高级方法    调用模型中的

M方法是实例化模型,不用定义用户的模型和模型类,在使用D方法时候如果他没有找到他的自定义模型的话,自动转成M方法转化成   基础模型的实例

2.实例化用户自定义模型

问题   controller调用model层调用不出来

 

实例化时应该在类名前加上命名空间就行了

完整DEMO

Controller层

<?php
namespace Home\Controller;
use Think\Controller;
class IndexController extends Controller {
    public function user(){
        //1.实例化基础模型
        //$user=new Model('user');//表名,表前缀,数据库连接信息
//         $user=M('user');
//         $data=$user->select();//查询表
//         dump($data);
        //2.实例化用户自定义模型
        $user=D('User');
        echo   $user->getinfo();
     }
}

Model层

<?php
namespace Home\Model;
use Think\Model;
/**
 * Created by PhpStorm.
 * User: Administrator
 * Date: 2017/8/24 0024
 * Time: 21:05
 */
class UserModel extends Model{
      public function getinfo(){
          //添加自己的业务逻辑
          return 'helloworld';
      }

}

代码

<?php
namespace Home\Controller;
use Think\Controller;
class IndexController extends Controller {
    public function user(){
        //1.实例化基础模型
        //$user=new Model('user');//表名,表前缀,数据库连接信息
//         $user=M('user');
//         $data=$user->select();//查询表
//         dump($data);
        //2.实例化用户自定义模型
        $user=D('User');
//        echo   $user->getinfo();
        $data=$user->select();
        dump($data);
     }
}

http://www.234.com/test/index/user

3.实例化公共模型

数据库有十个二十个表,都是公共的表,公共模型就起到作用了

class CommonModel extends Model{
    public function strmake($str){
        return md5(shal(md5($str)));
    }
}

完整代码

model

<?php
namespace Home\Model;
use Think\Model;
/**
 * Created by PhpStorm.
 * User: Administrator
 * Date: 2017/8/25 0025
 * Time: 14:03
 */
class CommonModel extends Model{
    public function strmake($str){
        return (md5($str));
    }
}

Controller

<?php
namespace Home\Controller;
use Think\Controller;
class IndexController extends Controller {
    public function user(){
        //1.实例化基础模型
        //$user=new Model('user');//表名,表前缀,数据库连接信息
//         $user=M('user');
//         $data=$user->select();//查询表
//         dump($data);
        //2.实例化用户自定义模型
//        $user=D('User');
////        echo   $user->getinfo();
//        $data=$user->select();
//        dump($data);
        //3.实例化公共模型
        $user=D('Common');
        echo $user->strmake('aaaaa');
     }

}

OOP思想,在继承里面

Model

<?php
namespace Home\Model;
use Think\Model;
/**
 * Created by PhpStorm.
 * User: Administrator
 * Date: 2017/8/25 0025
 * Time: 14:03
 */
class CommonModel extends Model{
    public function strmake($str){
        return (md5($str));
    }
}

<?php
namespace Home\Model;
use Think\Model;
/**
 * Created by PhpStorm.
 * User: Administrator
 * Date: 2017/8/24 0024
 * Time: 21:05
 */
class UserModel extends CommonModel{
      public function getinfo(){
          //添加自己的业务逻辑
          return 'helloworld';
      }

}

Controller

<?php
namespace Home\Controller;
use Home\Model\CommonModel;
use Think\Controller;
class IndexController extends Controller {
    public function user(){
        //1.实例化基础模型
        //$user=new Model('user');//表名,表前缀,数据库连接信息
//         $user=M('user');
//         $data=$user->select();//查询表
//         dump($data);
        //2.实例化用户自定义模型
//        $user=D('User');
////        echo   $user->getinfo();
//        $data=$user->select();
//        dump($data);
        //3.实例化公共模型
//        $user=new CommonModel();
//        echo $user->strmake('aaaaa');
        $user=D('User');
        echo $user->strmake('bbbbbb');
     }

}

结果

4.实例化空模型

//实例化空模型
         $model=M();
//        $data=$model->query('select * from mk_user');//读取日常select
//        dump($data);
        $data=$model->execute('update mk_user set user_name="kitty" where id=6');//写入 update  insert
        dump($data);

}

结果

总结,一般用1,2,3方法,4 方法不推荐使用

M   D     实例化模型的   区别

thinkphp 连接数据库 & 实例化模型操作 (下接thinkphp CURD 操作)/慕课的更多相关文章

  1. Thinkphp入门 五 —模型 (49)

    原文:Thinkphp入门 五 -模型 (49) [数据库操作model模型] model  模型  数据库操作 tp框架主要设计模式:MVC C:controller   控制器   shop/Li ...

  2. 【三十二】thinkphp之连接数据库、实例化模型

    1.连接数据库 Thinlphp内置了抽象数据库访问层,把不同的数据操作封装起来.我们只需要调用公共的DB类进行操作即可.DB类会自动调用相应的数据库驱动来处理. 在应用目录/common/conf/ ...

  3. ThinkPHP学习笔记 实例化模型的四种方法

    创建Action类   [php]   <?php   class NewObjectAction extends Action{       public function index(){ ...

  4. thinkphp模型事件(钩子函数:模型中在增删改等操作前后自动执行的事件)

    thinkphp模型事件(钩子函数:模型中在增删改等操作前后自动执行的事件) 一.总结 1.通过模型事件(钩子函数),可以在插入更新删除等前后执行一些特定的功能 2.模型事件是写在模型里面的,控制器中 ...

  5. [转]ThinkPHP中实例化对象M()和D()的区别,select和find的区别

    1.ThinkPHP中实例化对象M()和D()的区别 在实例化的过程中,经常使用D方法和M方法,这两个方法的区别在于M方法实例化模型无需用户为每个数据表定义模型类,如果D方法没有找到定义的模型类,则会 ...

  6. ThinkPHP中的模型二

    ThinkPHP中的模型 1.为什么要创建数据对象 案例:使用ThinkPHP完成部门管理 ① 设计数据库 ② 创建Dept控制器 路径:./Application/Admin/Controller创 ...

  7. ThinkPHP中的模型

    ThinkPHP中的模型 1.什么是模型(Model) 模型表示企业数据和业务规则,实际项目开发中,主要实现与数据库进行操作. 2.模型的定义规则 模型类的命名规则是除去表前缀的数据表名称,采用驼峰法 ...

  8. thinkphp框架之模型(数据库查询)

    1. 模型定义 文件名称必须是 表名+Model.class.php 例如:UserModel.class.php namespace Home\Model; //该模型类的命名空间 use Thin ...

  9. ThinkPHP中实例化对象M()和D()的区别,select和find的区别

    原文:ThinkPHP中实例化对象M()和D()的区别,select和find的区别 1.ThinkPHP中实例化对象M()和D()的区别 在实例化的过程中,经常使用D方法和M方法,这两个方法的区别在 ...

随机推荐

  1. SQL属性第一个值不被选中,属性默认第一个值

    把 Please Choose Color 属性名设置为不可选的 UPDATE `products_attributes` SET `attributes_display_only` = '1' WH ...

  2. eval(function(p,a,c,k,e,r)解密程序

    以eval(function(p,a,c,k,e,r){e=function(c)开头的js文件是经过加密的 使用下面方法可以对js文件进行加密.解密 步骤:1.新建html页面,内容如下列代码 2. ...

  3. src路径

  4. 开发环境入门 linux基础(部分)虚拟内存,rpm和yum安装

    虚拟内存,rpm和yum安装 文本中查找 /内容 替换:扩展模式下(:)%s /替换目标/要替换的文件/ (只替换第一个)(后边加g全部替换) :set u添加行号 raid  lvm逻辑卷 df - ...

  5. delphi 10.2.2.2004 Tokyo 安装步骤

    delphi 各版本的安装,其XX工具都附有详细说明.遵守其安装步骤,很容易成功. 本教就以 delphi 10.2.2.2004 为例,演示一下整个安装过程.其它各版本就自行尝试. 附: delph ...

  6. linux 信号量之SIGNAL 0<转>

    我们可以使用kill -l查看所有的信号量解释,但是没有看到SIGNAL 0的解释. [root@testdb~]# kill -l 1) SIGHUP 2) SIGINT 3) SIGQUIT 4) ...

  7. Android中Activity之间的数据传递

    在开发中,我们经常涌用到Activity,那么既然用到了Activity,就一定免不了在两个或者多个Activity之间传递数据.这里我们先说一说原理,然后在看看代码和例子. 情况A:我们需要从Act ...

  8. 9-EasyNetQ之基于主题的路由

    RabbitMQ有一个很酷的功能,基于主题的路由,这个功能允许订阅者基于多个条件去过滤消息.一个主题是由点号分隔的单词列表,随消息一同发布.例如:"stock.usd.nyse" ...

  9. 一些API的用法

    //1.init初始化 NSString * str1 = [[NSString alloc] init]; NSLog(@"str1 = %@",str1); //2.initW ...

  10. Redis Cluster 伪集群的搭建

    简介 为何要搭建Redis集群?Redis是在内存中保存数据的,而我们的电脑一般内存都不大,这也就意味着Redis不适合存储大数据,适合存储大数据的是Hadoop生态系统的Hbase或者是MogoDB ...