thinkphp 连接数据库 & 实例化模型操作 (下接thinkphp CURD 操作)/慕课
7.1 连接数据库 (06:15) 1
7.2实例化模型 1
1.实例化基础模型 2
2. 实例化用户自定义模型 2
问题 2
3. 实例化公共模型 4
4. 实例化空模型 7
7.1 连接数据库 (06:15)
Tp内置啦一个数据库函数 支持大多主流数据库
数据库配置
'DB_TYPE' => 'mysql', // 数据库类型
'DB_HOST' => 'www.234.com', // 服务器地址
'DB_NAME' => 'muck', // 数据库名
'DB_USER' => 'root', // 用户名
'DB_PWD' => 'root', // 密码
'DB_PORT' => '3306', // 端口
'DB_PREFIX' => 'mk_', // 数据库表前缀
7.2实例化模型
1.实例化基础模型
public function user(){
//1.实例化基础模型
//$user=new Model('user');//表名,表前缀,数据库连接信息
$user=M('user');
$data=$user->select();//查询表
dump($data);
D方法是M方法的高级方法 调用模型中的
M方法是实例化模型,不用定义用户的模型和模型类,在使用D方法时候如果他没有找到他的自定义模型的话,自动转成M方法转化成 基础模型的实例
2.实例化用户自定义模型
问题 controller调用model层调用不出来
实例化时应该在类名前加上命名空间就行了
完整DEMO
Controller层
<?php
namespace Home\Controller;
use Think\Controller;
class IndexController extends Controller {
public function user(){
//1.实例化基础模型
//$user=new Model('user');//表名,表前缀,数据库连接信息
// $user=M('user');
// $data=$user->select();//查询表
// dump($data);
//2.实例化用户自定义模型
$user=D('User');
echo $user->getinfo();
}
}
Model层
<?php
namespace Home\Model;
use Think\Model;
/**
* Created by PhpStorm.
* User: Administrator
* Date: 2017/8/24 0024
* Time: 21:05
*/
class UserModel extends Model{
public function getinfo(){
//添加自己的业务逻辑
return 'helloworld';
}
}
代码
<?php
namespace Home\Controller;
use Think\Controller;
class IndexController extends Controller {
public function user(){
//1.实例化基础模型
//$user=new Model('user');//表名,表前缀,数据库连接信息
// $user=M('user');
// $data=$user->select();//查询表
// dump($data);
//2.实例化用户自定义模型
$user=D('User');
// echo $user->getinfo();
$data=$user->select();
dump($data);
}
}
http://www.234.com/test/index/user
3.实例化公共模型
数据库有十个二十个表,都是公共的表,公共模型就起到作用了
class CommonModel extends Model{
public function strmake($str){
return md5(shal(md5($str)));
}
}
完整代码
model
<?php
namespace Home\Model;
use Think\Model;
/**
* Created by PhpStorm.
* User: Administrator
* Date: 2017/8/25 0025
* Time: 14:03
*/
class CommonModel extends Model{
public function strmake($str){
return (md5($str));
}
}
Controller
<?php
namespace Home\Controller;
use Think\Controller;
class IndexController extends Controller {
public function user(){
//1.实例化基础模型
//$user=new Model('user');//表名,表前缀,数据库连接信息
// $user=M('user');
// $data=$user->select();//查询表
// dump($data);
//2.实例化用户自定义模型
// $user=D('User');
//// echo $user->getinfo();
// $data=$user->select();
// dump($data);
//3.实例化公共模型
$user=D('Common');
echo $user->strmake('aaaaa');
}
}
OOP思想,在继承里面
Model
<?php
namespace Home\Model;
use Think\Model;
/**
* Created by PhpStorm.
* User: Administrator
* Date: 2017/8/25 0025
* Time: 14:03
*/
class CommonModel extends Model{
public function strmake($str){
return (md5($str));
}
}
<?php
namespace Home\Model;
use Think\Model;
/**
* Created by PhpStorm.
* User: Administrator
* Date: 2017/8/24 0024
* Time: 21:05
*/
class UserModel extends CommonModel{
public function getinfo(){
//添加自己的业务逻辑
return 'helloworld';
}
}
Controller
<?php
namespace Home\Controller;
use Home\Model\CommonModel;
use Think\Controller;
class IndexController extends Controller {
public function user(){
//1.实例化基础模型
//$user=new Model('user');//表名,表前缀,数据库连接信息
// $user=M('user');
// $data=$user->select();//查询表
// dump($data);
//2.实例化用户自定义模型
// $user=D('User');
//// echo $user->getinfo();
// $data=$user->select();
// dump($data);
//3.实例化公共模型
// $user=new CommonModel();
// echo $user->strmake('aaaaa');
$user=D('User');
echo $user->strmake('bbbbbb');
}
}
结果
4.实例化空模型
//实例化空模型
$model=M();
// $data=$model->query('select * from mk_user');//读取日常select
// dump($data);
$data=$model->execute('update mk_user set user_name="kitty" where id=6');//写入 update insert
dump($data);
}
结果
总结,一般用1,2,3方法,4 方法不推荐使用
M D 实例化模型的 区别
thinkphp 连接数据库 & 实例化模型操作 (下接thinkphp CURD 操作)/慕课的更多相关文章
- Thinkphp入门 五 —模型 (49)
原文:Thinkphp入门 五 -模型 (49) [数据库操作model模型] model 模型 数据库操作 tp框架主要设计模式:MVC C:controller 控制器 shop/Li ...
- 【三十二】thinkphp之连接数据库、实例化模型
1.连接数据库 Thinlphp内置了抽象数据库访问层,把不同的数据操作封装起来.我们只需要调用公共的DB类进行操作即可.DB类会自动调用相应的数据库驱动来处理. 在应用目录/common/conf/ ...
- ThinkPHP学习笔记 实例化模型的四种方法
创建Action类 [php] <?php class NewObjectAction extends Action{ public function index(){ ...
- thinkphp模型事件(钩子函数:模型中在增删改等操作前后自动执行的事件)
thinkphp模型事件(钩子函数:模型中在增删改等操作前后自动执行的事件) 一.总结 1.通过模型事件(钩子函数),可以在插入更新删除等前后执行一些特定的功能 2.模型事件是写在模型里面的,控制器中 ...
- [转]ThinkPHP中实例化对象M()和D()的区别,select和find的区别
1.ThinkPHP中实例化对象M()和D()的区别 在实例化的过程中,经常使用D方法和M方法,这两个方法的区别在于M方法实例化模型无需用户为每个数据表定义模型类,如果D方法没有找到定义的模型类,则会 ...
- ThinkPHP中的模型二
ThinkPHP中的模型 1.为什么要创建数据对象 案例:使用ThinkPHP完成部门管理 ① 设计数据库 ② 创建Dept控制器 路径:./Application/Admin/Controller创 ...
- ThinkPHP中的模型
ThinkPHP中的模型 1.什么是模型(Model) 模型表示企业数据和业务规则,实际项目开发中,主要实现与数据库进行操作. 2.模型的定义规则 模型类的命名规则是除去表前缀的数据表名称,采用驼峰法 ...
- thinkphp框架之模型(数据库查询)
1. 模型定义 文件名称必须是 表名+Model.class.php 例如:UserModel.class.php namespace Home\Model; //该模型类的命名空间 use Thin ...
- ThinkPHP中实例化对象M()和D()的区别,select和find的区别
原文:ThinkPHP中实例化对象M()和D()的区别,select和find的区别 1.ThinkPHP中实例化对象M()和D()的区别 在实例化的过程中,经常使用D方法和M方法,这两个方法的区别在 ...
随机推荐
- Day3(1)linux文件系统及文件类型
Linux的文件系统 根文件系统(rootfs) root filesystem LSB,FHS:(FileSystem Heirache Standard) /etc,/usr,/var,/root ...
- 【转】Inter-eNB S1 切换
本博客介绍Inter-eNB的S1切换的流程 当eNB收到测量报告,或是因为内部负荷分担等原因,触发了切换判决,进行eNB间小区间通过S1口的切换. 源eNB通过S1接口的 HANDOVER REQU ...
- 2018年长沙理工大学第十三届程序设计竞赛 H数学考试
链接:https://www.nowcoder.com/acm/contest/96/H来源:牛客网 数学考试 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 32768K,其他语言6 ...
- Oracle 静默安装oracle client
静默安装oracle clint比较简单,修改instantclient.crsp文件的几个位置即可 [root@localhost ~]# vi /etc/oralnstloc inventory_ ...
- vmware全屏后去掉上面的横杠
全屏后选择查看—>独占模式最上面的杠就没了,而且不按退出快捷键,不会在切换到外面的系统中了.
- Beautiful Soup 4.2.0
Beautiful Soup 是一个可以从HTML或XML文件中提取数据的Python库.它能够通过你喜欢的转换器实现惯用的文档导航,查找,修改文档的方式 快速开始 pip install beaut ...
- Android 4学习(3):概述 - Resources
在应用程序中,处理与代码逻辑无关资源的最佳实践是将其放到程序的外部,典型的资源包括字符串,图片等.Android中的资源文件都在res文件夹中,这些资源包括字符串,颜色,主题,样式,图画,布局,动画, ...
- ABP仓储
简介 我们都知道ABP已经实现了仓储模式,支持EF core 和dapper 进行数据库的连接和管理,可以很方便的注入仓储来操作你的数据,不需要自己单独定义一个仓储来实现,通用的仓储实现了通用的cru ...
- 用JS,打印三角形
<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title&g ...
- 使用百度地图SDK 这是之前版本 现在的sdk v2-1-2使用方法完全改变
1.添加BMapApiDemoApp.java 2.AndroidManifest文件 application里添加 android:name=".ui.BMapApiDemoApp&q ...