ThinkPHP之M方法实例详解


Posted in PHP onJune 20, 2014

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');

实现同样的功能。

PHP 相关文章推荐
学习使用PHP数组
Oct 09 PHP
防止MySQL注入或HTML表单滥用的PHP程序
Jan 21 PHP
php 数组动态添加实现代码(最土团购系统的价格排序)
Dec 30 PHP
Zend的MVC机制使用分析(二)
May 02 PHP
curl不使用文件存取cookie php使用curl获取cookie示例
Jan 26 PHP
php删除左端与右端空格的方法
Nov 29 PHP
php实现图片局部打马赛克的方法
Feb 11 PHP
Laravel 5框架学习之用户认证
Apr 09 PHP
PHP编程实现阳历转换为阴历的方法实例
Aug 08 PHP
php使用mysqli和pdo扩展,测试对比mysql数据库的执行效率完整示例
May 09 PHP
PHP pthreads v3下的Volatile简介与使用方法示例
Feb 21 PHP
PHP isset()及empty()用法区别详解
Aug 29 PHP
php实现的短网址算法分享
Jun 20 #PHP
ThinkPHP3.1之D方法实例详解
Jun 20 #PHP
php写的AES加密解密类分享
Jun 20 #PHP
PHP提交表单失败后如何保留已经填写的信息
Jun 20 #PHP
将酷狗krc歌词解析并转换为lrc歌词php源码
Jun 20 #PHP
Yii Framework框架获取分类下面的所有子类方法
Jun 20 #PHP
windows下配置apache+php+mysql时出现问题的处理方法
Jun 20 #PHP
You might like
php 记录进行累加并显示总时长为秒的结果
2011/11/04 PHP
深入PHP中慎用双等于(==)的详解
2013/06/06 PHP
使用php将某个目录下面的所有文件罗列出来的方法详解
2013/06/21 PHP
php实现Mongodb自定义方式生成自增ID的方法
2015/03/23 PHP
PHP 设计模式系列之 specification规格模式
2016/01/10 PHP
php文件上传类的分享
2017/07/06 PHP
使用PHP开发留言板功能
2019/11/19 PHP
js限制textarea每行输入字符串长度的代码
2012/10/31 Javascript
node.js中的url.format方法使用说明
2014/12/10 Javascript
实例详解AngularJS实现无限级联动菜单
2016/01/15 Javascript
AngularJs 60分钟入门基础教程
2016/04/03 Javascript
JavaScript比较两个数组的内容是否相同(推荐)
2017/05/02 Javascript
Echarts之悬浮框中的数据排序问题
2018/11/08 Javascript
Vue-cli3.x + axios 跨域方案踩坑指北
2019/07/04 Javascript
微信小程序动画组件使用解析,类似vue,且更强大
2019/08/01 Javascript
Vue数据绑定实例写法
2019/08/06 Javascript
JavaScript 斐波那契数列 倒序输出 输出100以内的质数代码实例
2019/09/11 Javascript
webpack proxy 使用(代理的使用)
2020/01/10 Javascript
如何通过vscode运行调试javascript代码
2020/07/24 Javascript
[04:15]DOTA2-DPC中国联赛 正赛 Ehome vs Aster 选手采访
2021/03/11 DOTA
Python 比较文本相似性的方法(difflib,Levenshtein)
2018/10/15 Python
python3 unicode列表转换为中文的实例
2018/10/26 Python
Python OOP类中的几种函数或方法总结
2019/02/22 Python
Python字典的概念及常见应用实例详解
2019/10/30 Python
Keras实现支持masking的Flatten层代码
2020/06/16 Python
实列教程 一款基于jquery和css3的响应式二级导航菜单
2014/11/13 HTML / CSS
浅析CSS3 用text-overflow解决文字排版问题
2020/10/28 HTML / CSS
HTML5 绘制图像(上)之:关于canvas元素引领下一代web页面的问题
2013/04/24 HTML / CSS
美国知名运动产品零售商:Foot Locker
2016/07/23 全球购物
New Balance加拿大官方网站:运动鞋和健身服装
2018/11/19 全球购物
输入一行文字,找出其中大写字母、小写字母、空格、数字、及其他字符各有多少
2016/04/15 面试题
绿色城市实施方案
2014/03/19 职场文书
出国签证在职证明
2014/09/20 职场文书
敬老院志愿者活动总结
2015/05/06 职场文书
2016年教师党员公开承诺书
2016/03/24 职场文书
MySQL生成千万测试数据以及遇到的问题
2022/08/05 MySQL