当前位置:  编程技术>php

ThinkPHP之M方法实例教程

    来源: 互联网  发布时间:2014-08-30

    本文导语:  ThinkPHP之M方法实例教程 M方法用于实例化一个基础模型类,和D方法的区别在于: 1、不需要自定义模型类,减少IO加载,性能较好; 2、实例化后只能调用基础模型类(默认是Model类)中的方法; 3、可以在实例化的时候指定表...

ThinkPHP之M方法实例教程

M方法用于实例化一个基础模型类,和D方法的区别在于:
1、不需要自定义模型类,减少IO加载,性能较好;
2、实例化后只能调用基础模型类(默认是Model类)中的方法;
3、可以在实例化的时候指定表前缀、数据库和数据库的连接信息;
D方法的强大则体现在你封装的自定义模型类有多强,不过随着新版ThinkPHP框架的基础模型类的功能越来越强大,M方法也比D方法越来越实用了。
M方法的调用格式:
M('[基础模型名:]模型名','数据表前缀','数据库连接信息')

M方法具体有哪些用法:
1、实例化基础模型(Model) 类
在没有定义任何模型的时候,我们可以使用下面的方法实例化一个模型类来进行操作:
 

代码示例:
//实例化User模型
$User = M('User');
//执行其他的数据操作
$User->select();
 

这种方法最简单高效,因为不需要定义任何的模型类,所以支持跨项目调用。
缺点也是因为没有自定义的模型类,因此无法写入相关的业务逻辑,只能完成基本的CURD操作。
 

代码示例:
$User = M('User');

其实等效于:
 

代码示例:
$User = new Model('User');

表示操作think_user表。M方法和D方法一样也有单例功能,多次调用并不会重复实例化。
M方法的模型名参数在转换成数据表的时候会自动转换成小写,也就是说ThinkPHP的数据表命名规范是全小写的格式。

2、实例化其他公共模型类
第一种方式实例化因为没有模型类的定义,因此很难封装一些额外的逻辑方法,不过大多数情况下,也许只是需要扩展一些通用的逻辑,那么就可以尝试下面一种方法。
 

代码示例:
$User = M('CommonModel:User');

改用法其实等效于:
 

代码示例:
$User = new CommonModel('User');

因为系统的模型类都能够自动加载,因此不需要在实例化之前手动进行类库导入操作。模型类CommonModel必须继承Model。
可以在CommonModel类里面定义一些通用的逻辑方法,就可以省去为每个数据表定义具体的模型类,如果项目已有超过100个数据表了,而大多数情况都是一些基本的CURD操作的话,只是个别模型有一些复杂的业务逻辑需要封装,那么第一种方式和第二种方式的结合是一个不错的选择。

3、传入表前缀、数据库和其他信息
M方法有三个参数,第一个参数是模型名称(可以包括基础模型类和数据库),第二个参数用于设置数据表的前缀(留空则取当前项目配置的表前缀),第三个参数用于设置当前使用的数据库连接信息(留空则取当前项目配置的数据库连接信息),例如:
 

代码示例:
$User = M('db2.User','think_');

表示实例化Model模型类,并操作db2数据库中的think_user表。

如果第二个参数留空或者不传,表示使用当前项目配置中的数据表前缀,如果操作的数据表没有表前缀,那么可以使用:
 

代码示例:
$User = M('db1.User',null);

表示实例化Model模型类,并操作db1数据库中的user表。

如果你操作的数据库需要不同的用户账号,可以传入数据库的连接信息,例如:
 

代码示例:
$User = M('User','think_','mysql://user_a:1234@localhost:3306/thinkphp');

表示基础模型类用Model,然后对think_user表进行操作,用user_a账号进行数据库连接,操作数据库是thinkphp。
第三个连接信息参数可以使用DSN配置或者数组配置,甚至可以支持配置参数。

例如,在项目配置文件中配置了:
 

代码示例:
'DB_CONFIG'=>'mysql://user_a:1234@localhost:3306/thinkphp';

则可以使用:
 

代码示例:
$User = M('User','think_','DB_CONFIG');

基础模型类和数据库可以一起使用,例如:
 

代码示例:
$User = M('CommonModel:db2.User','think_');

如果要实例化分层模型的话,利用公共模型类的方式,我们可以使用:
 

代码示例:
M('UserLogic:User');

来实例化UserLogic,虽然这样做的意义不大,因为可以用
 

代码示例:
D('User','Logic');

实现同样的功能。

您可能感兴趣的文章:
  • ThinkPHP之A方法实例教程
  • ThinkPHP之N方法实例教程
  • ThinkPHP中import方法实例教程
  • ThinkPHP中R方法实例教程
  • ThinkPHP模板引擎导入资源文件教程详解
  • ThinkPHP令牌验证实例教程
  • ThinkPHP中L方法实例教程
  • ThinkPHP中Mobile用法实例教程
  • Thinkphp中volist标签用法实例教程
  • ThinkPHP中I方法使用实例教程

    
 
 

您可能感兴趣的文章:

  • ThinkPHP之N方法实例教程
  • ThinkPHP之A方法实例教程
  • ThinkPHP标签怎么制作?thinkphp标签制作实例教程
  • ThinkPHP之A方法实例讲解
  • ThinkPHP之N方法实例详解
  • ThinkPHP实现批量删除数据的代码实例
  • ThinkPHP中L方法实例教程
  • 采用ThinkPHP中F方法实现快速缓存实例
  • ThinkPHP中R方法实例教程
  • ThinkPHP3.1之D方法实例详解
  • ThinkPHP的Widget扩展实例
  • ThinkPHP的MVC开发机制实例解析
  • ThinkPHP之R方法实例详解
  • thinkphp自定义标签与view直接标签实例教程
  • thinkphp一键清除缓存实例教程
  • ThinkPHP文件上传实例教程
  • ThinkPHP实例化模型的四种方法概述
  • Thinkphp中volist标签用法实例教程
  • ThinkPHP模板替换与系统常量及应用实例教程
  • ThinkPHP使用UTFWry地址库进行IP定位实例
  • ThinkPHP CURD方法之order方法教程详解
  • ThinkPHP CURD方法中limit方法教程详解
  • ThinkPHP CURD方法之order方法详解
  • ThinkPHP CURD方法之table方法教程详解
  • thinkphp分页保持搜索状态实现方法
  • ThinkPHP CURD方法之limit方法详解
  • ThinkPHP让分页保持搜索状态的方法
  • ThinkPHP CURD方法中page方法教程详解
  • ThinkPHP的模版中调用session数据的方法
  • ThinkPHP查询中的魔术方法简述
  • 浅析ThinkPHP中execute和query方法的区别
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • ThinkPHP学习笔记(一)ThinkPHP部署
  • ThinkPHP3.1新特性之对分组支持的改进与完善概述
  • 轻量级PHP开发框架 ThinkPHP
  • 模仿 thinkphp 的 nodejs MVC 框架 Nstorm
  • ThinkPHP中的关联模型注意点
  • ThinkPHP使用心得分享-ThinkPHP + Ajax 实现2级联动下拉菜单
  • ThinkPHP实现事务回滚示例代码
  • Thinkphp模板中截取字符串函数简介
  • ThinkPHP命令行工具 Tptool
  • ThinkPHP之foreach标签使用概述
  • ThinkPHP中URL路径访问与模块控制器之间的关系
  • ThinkPHP3.1新特性之内容解析输出详解
  • Thinkphp中import的几个用法详细介绍
  • ThinkPHP模板判断输出Empty标签用法详解
  • ThinkPHP模板判断输出Present标签用法详解
  • Thinkphp实现MySQL读写分离操作示例
  • ThinkPHP模板IF标签用法详解
  • ThinkPHP3.1新特性之动态设置自动完成和自动验证示例
  • 在nginx中配置pathinfo模式支持thinkphp的URL重写
  • ThinkPHP3.1新特性之动态设置自动完成及自动验证示例代码


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3