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方法,这两个方法的区别在 ...
随机推荐
- SQL属性第一个值不被选中,属性默认第一个值
把 Please Choose Color 属性名设置为不可选的 UPDATE `products_attributes` SET `attributes_display_only` = '1' WH ...
- eval(function(p,a,c,k,e,r)解密程序
以eval(function(p,a,c,k,e,r){e=function(c)开头的js文件是经过加密的 使用下面方法可以对js文件进行加密.解密 步骤:1.新建html页面,内容如下列代码 2. ...
- src路径
- 开发环境入门 linux基础(部分)虚拟内存,rpm和yum安装
虚拟内存,rpm和yum安装 文本中查找 /内容 替换:扩展模式下(:)%s /替换目标/要替换的文件/ (只替换第一个)(后边加g全部替换) :set u添加行号 raid lvm逻辑卷 df - ...
- delphi 10.2.2.2004 Tokyo 安装步骤
delphi 各版本的安装,其XX工具都附有详细说明.遵守其安装步骤,很容易成功. 本教就以 delphi 10.2.2.2004 为例,演示一下整个安装过程.其它各版本就自行尝试. 附: delph ...
- linux 信号量之SIGNAL 0<转>
我们可以使用kill -l查看所有的信号量解释,但是没有看到SIGNAL 0的解释. [root@testdb~]# kill -l 1) SIGHUP 2) SIGINT 3) SIGQUIT 4) ...
- Android中Activity之间的数据传递
在开发中,我们经常涌用到Activity,那么既然用到了Activity,就一定免不了在两个或者多个Activity之间传递数据.这里我们先说一说原理,然后在看看代码和例子. 情况A:我们需要从Act ...
- 9-EasyNetQ之基于主题的路由
RabbitMQ有一个很酷的功能,基于主题的路由,这个功能允许订阅者基于多个条件去过滤消息.一个主题是由点号分隔的单词列表,随消息一同发布.例如:"stock.usd.nyse" ...
- 一些API的用法
//1.init初始化 NSString * str1 = [[NSString alloc] init]; NSLog(@"str1 = %@",str1); //2.initW ...
- Redis Cluster 伪集群的搭建
简介 为何要搭建Redis集群?Redis是在内存中保存数据的,而我们的电脑一般内存都不大,这也就意味着Redis不适合存储大数据,适合存储大数据的是Hadoop生态系统的Hbase或者是MogoDB ...