1. Model definition
The file name must be the table name Model.class.php For example: UserModel.class.php
namespace Home\Model; <span>//</span><span>该模型类的命名空间</span> <span>use</span> Think\Model; <span>//</span><span>下面的模型类需要继承Model基类,Model是系统定义的模型类,在 Think\Model 这个命名空间中</span> <span>class</span> UserModel <span>extends</span><span> Model { }</span>
The class name in the file is consistent with the "table name" in the file name ( This item is required. If it is inconsistent, the model class will not be found in the controller ).
The corresponding relationship between class name and table name is (Note: There is an underscore in front of the data table corresponding to each upper case in the model name, as shown in the second line below )
模型名 | 约定对应数据表(如果数据库的前缀是think_) |
UserModel | think_user |
UserTypeModel | think_user_type |
2. 模型实例化
2.1 直接实例化
2.1.1 不带参数实例化 $user=new \Home\Model\UserModel();
2.1.2 带参数实例化 $user=new \Home\Model\UserModel(['模型名'],['数据表前缀'],['数据库连接信息']);
上述两种方法的区别在于,第一种在实例化的时候回去读取默认配置(例如在模型中的配置或者是模块中的数据库配置),而第二种方法是直接读取传入参数的数据库配置
模型名是对应的数据库中的去掉前缀的表名,如果不指定这会读取模型类的名称但是是去掉Model后的名称 例如:
UsereModel.class.php 文件中的 UsereModel 类 ,如果在实例化的时候传入模型名"User"会按传入查找数据表 前缀+“user”,如果不传则会提取 UsereModel类的 “Usere” 去查找数据表。这样可以解决模型名与数据表明不一致的问题。
2.2 D方法实例化
D方法的参数是模型的名称,并且和模型类的大写定义是一致的。
<?<span>php </span><span>//</span><span>实例化模型</span> <span>$user</span>=D("User"<span>); </span><span>//</span><span>相当于 $user=new \Home\Model\UserModel(); </span>
跨模块实例化
D('Admin/User') 其中 “Admin” 是模块名称,“User”是模型名称
实例化 Extend扩展名空间下的Info模型
D('Extend://Editor/Info')
2.3 M方法实例化
M('User') 与D方法实例化的区别是这个方法不需要该模型存在,并且如果模型存在则其中的方法也会别忽略,该方法主要是用来对数据库的操作。
当D方法没有找到模型时会默认的调用 M方法。
2.4 实例化空模型
$Model=new Model() 或者 $Model=M();
这种空实例可以用老进行原生的sql查询(注:其他的模型也可以进行原生的sql查询,并且查询的表不必跟模型对应)
3. 模型中的字段
$fields=array('','') 表示数据表中的字段
$pk 表示数据表的主键
$connection=array('db_type' => 'mysql','db_user' => 'root','db_pwd' => '1234','db_host' => 'localhost','db_port' => '3306','db_name' => 'thinkphp','db_charset' => 'utf8','db_params' => array(), // 非必须); 表示数据库连接
数据库类型://用户名:密码@数据库地址:数据库端口/数据库名#字符集
$connection = 'mysql://root:1234@localhost:3306/thinkphp#utf8';