**1 小试身手**
1 数据库配置 打开应用目录的数据库配置文件
application\database.php 修改数据库配置为
~~~
return [
// 数据库类型
'type' => 'mysql',
// 数据库连接DSN配置
'dsn' => '',
// 服务器地址
'hostname' => '127.0.0.1',
// 数据库名
'database' => 'tp5',
// 数据库用户名
'username' => 'root',
// 数据库密码
'password' => 'root',
// 数据库连接端口
'hostport' => '3306',
// 数据库连接参数
'params' => [],
// 数据库编码默认采用utf8
'charset' => 'utf8',
// 数据库表前缀
'prefix' => 'tp5_',
// 数据库调试模式
'debug' => APP_DEBUG,
// 数据库部署方式:0 集中式(单一服务器),1 分布式(主从服务器)
'deploy' => 0,
// 数据库读写是否分离 主从式有效
'rw_separate' => false,
// 读写分离后 主服务器数量
'master_num' => 1,
// 指定从服务器序号
'slave_no' => '',
];
~~~
基础修改包括
hostname,hostport,database,
username,password,prefix。
2 浏览器输入http://127.0.0.1/
![](https://box.kancloud.cn/2016-02-24_56cd4dd1e245e.jpg)
点击箭头所指phpMyAdmin管理,进入数据库登录界面
![](https://box.kancloud.cn/2016-02-24_56cd4dd210776.jpg)
输入默认账号root密码root,进入数据库管理界面。
![](https://box.kancloud.cn/2016-02-24_56cd4dd2284d3.jpg)
创建数据库tp5与数据表tp5_test
![](https://box.kancloud.cn/2016-02-24_56cd4dd2439f1.jpg)
![](https://box.kancloud.cn/2016-02-24_56cd4dd25f51b.jpg)
![](https://box.kancloud.cn/2016-02-24_56cd4e9837f66.jpg)
![](https://box.kancloud.cn/2016-02-24_56cd4dd2761ab.jpg)
注意这里的数据库tp5与数据表tp5_test与数据库配置的对应关系
~~~
database =>'tp5',
prefix =>'tp5_,
~~~
3 打开目录D:\upnp5.6\htdocs\tp5\application\index\controller
新建文件Modeltest.php,输入以下内容
~~~
<?php
namespace app\index\controller;
class Modeltest
{
public function echo_model(){
$Model = M('test');
// tp5框架在App::run()使用Response::send()统一返回客户端数据
// 因此控制器最后最好使用 return $result; 形式的语句返回数据到App::run()
// 这里只是作为学习测试。
dump($Model);
}
public function add_model(){
$Model = M('test');
$data = [
'id' =>1,
'name' =>'test_name',
'title' =>'test_title',
'sort' =>1
];
$result = $Model->add($data);
// tp5框架在App::run()使用Response::send()统一返回客户端数据
// 因此控制器最后最好使用 return $result; 形式的语句返回数据到App::run()
// 这里只是作为学习测试。
dump($result);
}
public function select_model(){
$Model = M('test');
$return1 = $Model->where('id=1')->getField('title');
dump($return1);
$return2 = $Model->where('id=1')->find();
dump($return2);
$return3 = $Model->where('id=1')->select();
dump($return3);
}
public function update_model(){
$Model = M('test');
$data = [
'name' =>'update_name',
'title' =>'update_title'
];
$result = $Model->where('id=1')->save($data);
dump($result);
}
public function delete_model(){
$Model = M('test');
$result = $Model->where('id=1')->delete();
dump($result);
}
}
~~~
3 浏览器输入
http://127.0.0.1/tp5/public/index.php/Index/ModelTest/echo_model
由上节可知这里运行Modeltest.php的echo_model()方法。
输出Model的对象信息
4 浏览器输入
http://127.0.0.1/tp5/public/index.php/Index/ModelTest/add_model
向数据库添加信息,
返回int(1),表示添加成功
5 浏览器输入
http://127.0.0.1/tp5/public/index.php/Index/ModelTest/select_model
查询数据库信息
输出如下![](https://box.kancloud.cn/2016-02-24_56cd4dd28f1bd.jpg)
6 浏览器输入
http://127.0.0.1/tp5/public/index.php/Index/ModelTest/delete_model
返回int(1)表示删除成功
再次输入
http://127.0.0.1/tp5/public/index.php/Index/ModelTest/select_model
返回空值。
7 总结
以上是数据库的增删改查的基本操作。
1 修改应用的数据库配置文件database.php。
2 数据库后台添加数据库与数据表
3 控制器使用M()方法创建$Model对象
4 使用$Model对象的add() find() save() delete()方法实现数据的增删改查
**2 开发场景**
数据模型用来保存系统信息以及用户操作信息。
在thinkp框架中可以使用强大的链式操作来操作数据库。
还可以自定义数据模型实现多表操作。
更多操作参考[官方手册](http://ihavenolimitations.xyz/thinkphp/thinkphp5-guide/90122)与[tp3.2的模型](http://ihavenolimitations.xyz/thinkphp/thinkphp_quickstart/2142)
**3 开发进阶**
模块中自定义模型是在application/index/下建立model目录。
建立对应模型文件,继承think\Model,
实现业务数据操作与控制器分离。
具体实现见[官方手册](http://ihavenolimitations.xyz/thinkphp/thinkphp5-guide/90122)
**4 框架底层**
1 模型是对数据库操作的抽象。在thinkphp/helper.php中定义了两个方法来简化模型的创建
~~~
function M($name = '', $tablePrefix = null, $connection = '')
{
return \think\Loader::table($name, ['prefix' => $tablePrefix, 'connection' => $connection]);
}
function D($name = '', $layer = MODEL_LAYER)
{
return \think\Loader::model($name, $layer);
}
~~~
分析可知是调用Loader自动加载器实现模型的实例化
2 Loader自动加载器的实例化操作见 [另:自动加载器实例化](http://ihavenolimitations.xyz/zmwtp/tp5/120008)
- 更新记录
- 概述
- 文件索引
- 函数索引
- 章节格式
- 框架流程
- 前:章节说明
- 主:(index.php)入口
- 主:(start.php)框架引导
- 主:(App.php)应用启动
- 主:(App.php)应用调度
- C:(Controller.php)应用控制器
- M:(Model.php)数据模型
- V:(View.php)视图对象
- 附:(App.php)应用启动
- 附:(base.php)全局变量
- 附:(common.php)模式配置
- 附:(convention.php)全局配置
- 附:(Loader.php)自动加载器
- 附:(Build.php)自动生成
- 附:(Hook.php)监听回调
- 附:(Route.php)全局路由
- 附:(Response.php)数据输出
- 附:(Log.php)日志记录
- 附:(Exception.php)异常处理
- 框架工具
- 另:(helper.php)辅助函数
- 另:(Cache.php)数据缓存
- 另:(Cookie.php)cookie操作
- 另:(Console.php)控制台
- 另:(Debug.php)开发调试
- 另:(Error.php)错误处理
- 另:(Url.php)Url操作文件
- 另:(Loader.php)加载器实例化
- 另:(Input.php)数据输入
- 另:(Lang.php)语言包管理
- 另:(ORM.php)ORM基类
- 另:(Process.php)进程管理
- 另:(Session.php)session操作
- 另:(Template.php)模板解析
- 框架驱动
- D:(\config)配置解析
- D:(\controller)控制器扩展
- D:(\model)模型扩展
- D:(\db)数据库驱动
- D:(\view)模板解析
- D:(\template)模板标签库
- D:(\session)session驱动
- D:(\cache)缓存驱动
- D:(\console)控制台
- D:(\process)进程扩展
- T:(\traits)Trait目录
- D:(\exception)异常实现
- D:(\log)日志驱动
- 使用范例
- 服务器与框架的安装
- 控制器操作
- 数据模型操作
- 视图渲染控制
- MVC开发初探
- 模块开发
- 入口文件定义全局变量
- 运行模式开发
- 框架配置
- 自动生成应用
- 事件与插件注册
- 路由规则注册
- 输出控制
- 多种应用组织
- 综合应用
- tp框架整合后台auto架构快速开发
- 基础原理
- php默认全局变量
- php的魔术方法
- php命名空间
- php的自动加载
- php的composer
- php的反射
- php的trait机制
- php设计模式
- php的系统时区
- php的异常错误
- php的输出控制
- php的正则表达式
- php的闭包函数
- php的会话控制
- php的接口
- php的PDO
- php的字符串操作
- php的curl
- 框架心得
- 心:整体结构
- 心:配置详解
- 心:加载器详解
- 心:输入输出详解
- 心:url路由详解
- 心:模板详解
- 心:模型详解
- 心:日志详解
- 心:缓存详解
- 心:控制台详解
- 框架更新
- 4.20(验证类,助手函数)
- 4.27(新模型Model功能)
- 5.4(新数据库驱动)
- 7.28(自动加载)