ThinkPHP之数据库操作

Model文件位置


ThinkPHP使用的是MVC架构,所以我们我们在操作数据库时,首先需要创建自己的Model类。

在每个模块下有个Model文件夹,我们可以将Model类放置在该文件夹下。如果多个模块需要使用同一的Model,则可以选择在项目的下创建Model文件夹来存放Model

ThinkPHP之数据库操作

配置数据库


在使用Model类来操作数据时,应先把数据库配置好。在每个模块下有个Conf/config.php文件,我们可以在里面配置数据库。

ThinkPHP之数据库操作

数据库配置

<?php
return array(
//'配置项'=>'配置值'
'SHOW_PAGE_TRACE'=>true,
'MODULE_ALLOW_LIST' => array('Home','Admin','Public'),
'MODULE_DENY_LIST' => array('Common','Runtime'),
'DB_TYPE' => 'mysql', // 数据库类型
'DB_HOST' => '127.0.0.1', // 服务器地址
'DB_NAME' => 'weibo', // 数据库名
'DB_USER' => 'root', // 用户名
'DB_PWD' => 'admin', // 密码
);

定义Model类


一个Model类对应一张表,这里操作user表,所以我们的文件名应命名为UserModel.class.php。

<?php
/**
* Created by PhpStorm.
* User: Administrator
* Date: 2016/6/20
* Time: 10:34
*/ namespace Home\Model;
use Think\Model; //父类Model Thinkphp/Think/library/Model.class/php
class UserModel extends Model{ }

如果我们不想这样写则可以在UserModel中直接指定表名

<?php
/**
* Created by PhpStorm.
* User: Administrator
* Date: 2016/6/20
* Time: 10:34
*/ namespace Home\Model;
use Think\Model; //父类Model Thinkphp/Think/library/Model.class/php
class UserModel extends Model{
//该属性继承自Model类
protected $trueTableName = 'user';
}

控制器中实例化Model类


  • 普通方式
<?php
/**
* Created by PhpStorm.
* User: Administrator
* Date: 2016/6/20
* Time: 10:39
*/ namespace Home\Controller;
use Think\Controller; class UserController {
public function showList(){
$users = new \Home\Model\UserModel();
var_dump($users);
}
}
  • 快捷方式

如果在开发中认为没必要去添加自己的Model类,则可以使用系统提供的Model。这个Model类其实就是我们在写自己的Model时,继承的那个Model类。

<?php
/**
* Created by PhpStorm.
* User: Administrator
* Date: 2016/6/20
* Time: 10:39
*/ namespace Home\Controller;
use Think\Controller; class UserController {
public function showList(){
$m = M('user');
var_dump($m);
}
}

  $m就是一个model对象了。M函数会根据我们传入的表明来生成相应的Model对象。这里传入的是user字符串,所以$m对象操作的是数据库中的user表。

上一篇:PHP商品秒杀计时实现(解决大流量方案)


下一篇:Linux设备驱动01