ThinkPHP之实例化模型
发布:smiling 来源: PHP粉丝网 添加日期:2014-04-12 13:29:09 浏览: 评论:0
四种实例化模型的方式:
方式一:创建一个基础模型(实例化一个系统自带的数据库操作类);2.0以后更加科学方便,实例化一个数据库操作类的时候,可以不用自己去定义一个数据库操作类,thinkphp会自动的去找到数据库当中的表,并且把表当中的字段全部拿过来,直接操作的对象就是操作的这张表:
$user=new Model("User");<==>$user=M("User");
User首字母大写,我们命名表的时候表名:think_user,在这个当中thinkphp会按照大小写来区别你在前面有没有下划线,think_user_message_id,$mes=new Model("UserMessageID");而写think_userMessageId,则不行.
方式二:实例化一个表的时候,同时实例化自己写的自定义数据库模型操作类
Model文件夹下:
- class CommonModel extends Model{
- function abc(){
- echo "我的common模型里的方法abc输出的";
- }
- }
Action文件夹下:
- $user=M('User','CommonModel');<==>$user=new CommonModel('User');
- $list = $user->select();
- dump($list);
- $list -> abc();
方式二:可以实现更加复杂的业务逻辑
方式三:(实例化一个用户定义的模型)
需要用户手动创建一个模型,可以针对这个表(如user),来写上一个自定义模型,在自定义模型中可以封装thinkphp为我们提供的高级功能,还可以封装一些自定义方法来实现更加复杂的业务逻辑.
Model文件夹下:
- class UserModel extends Model{
- function aa(){
- echo "aaaaaaaaaaaaaaaaaaa";
- }
- }
Action文件夹下:
- $user = new UserModel();<==>$user=D("User");
- $list = $user->select();
- dump($list);
- $user->aa();
第二种方式和第三种方式的不同在于
第二种方式:在你的业务逻辑中通常情况下有一些公共的业务逻辑,公共的逻辑每次单独定义模型很麻烦,而采用方式二就很方便,公共的业务逻辑可以放到CommonModel中
第三种方式:适用于只针对所操作表的更加复杂的业务逻辑,但是它不需要使用到公共业务逻辑(它的业务逻辑
针对用户表,它是唯一的,不需要在其他模型中使用)
方式四:此种方式实例化一个空模型,并不知道你要实例化操作的哪一张表,此时的查询语句中必须要加表前缀:
- $user=new Model();<==>$user=M();
- $list = $user->query("select * from think_user");
- dump($list);
另:D()方法和new Model()的不同:
D()方法:可以自动检测模型类,不存在时会抛出一个异常,同时对于一个已经实例化的模型不会重复
实例化,默认的D()只能支持调用当前项目(应用)下的模型;如果是前台项目(home)中,想实例化后台项目(admin)的模型怎么操作:$user=D('admin','User');如果启用分组:$user=D("admin.user");
Tags: ThinkPHP 实例 模型
相关文章
- ·ThinkPHP中自定义错误页面和提示页面 (2013-11-15)
- ·ThinkPHP中Ajax返回(2013-11-15)
- ·ThinkPHP中处理表单中注意(2013-11-15)
- ·ThinkPHP中I(),U(),$this->post()等函数(2013-11-15)
- ·ThinkPHP中公共函数路径和配置项路径的映射(2013-11-15)
- ·ThinkPHP中公共配置文件和各自项目中的配置文件组合(2013-11-15)
- ·ThinkPHP在控制器里的javascript代码不能执行解决方法(2013-11-29)
- ·ThinkPHP3.0略缩图不能保存到子目录(2013-12-03)
- ·thinkphp的循环结构(2014-01-10)
- ·thinkphp特殊标签使用(2014-01-10)
- ·thinkphp模板输出汇总(2014-01-10)
- ·thinkphp模板的赋值与替换(2014-01-10)
- ·thinkphp连贯操作(2014-01-10)
- ·thinkphp区间查询、统计查询、SQL直接查询(2014-01-10)
- ·thinkphp的普通查询与表达式查询(2014-01-10)
- ·RBAC类在ThinkPHP中的四种使用方法(2014-01-10)
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)