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方法,这两个方法的区别在 ...
随机推荐
- List<T> JIT 分配策略
参考 http://www.cnblogs.com/brookshi/p/5353021.html defaultCapacity意思是new List<T>时默认大小是4. _items ...
- 关于pipe管道的读写端关闭问题
知识概述 通过pipe在内核中创建一个文件,然后可以实现两个进程通信 管道是一种最基本的IPC机制,由 pipe 函数创建: #include <unistd.h> ]); 调用 pipe ...
- linux yum 脚本实现
yum 位于linux /usr/bin/yum yum命令是python脚本进行编写的(python 2.6) #!/usr/bin/python2.6 import sys try: import ...
- CTF中常见文件的文件头(十六进制)
jpg/jpeg FF D8 FF E0 或 FF D8 FF E1 或 FF D8 FF E8 png 89 50 4E 47 bmp 42 4D 36 5D gif 47 49 46 38 zip ...
- sql server小知识
SELECT TOP 10000 * FROM [LogFeedback].[dbo].[ahwater_perf_monitor] order by timestramp desc 降序 asc ...
- spring @Resource与@Autowired注解详解
具有依赖关系的Bean对象,利用下面任意一种注解都可以实现关系注入: 1)@Resource (默认首先按名称匹配注入,然后类型匹配注入) 2)@Autowired/@Qualifier (默认按类型 ...
- 程序中使用log4J打印信息的两种方式
(1)通过org.apache.commons.logging.Log 接口实例化: public static Log log = LogFactory.getLog(String name); p ...
- [Python Study Notes]气泡散点图绘制
''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''' ...
- 通过测试确定GCC中 INT DOUBLE的最大/最小值和精度(DOUBLE)
INT 确定最大/最小值 由于达到极限之后会变符号,直接循环判断条件即可 DOUBLE确定精度 设置一个DOUBLE变量初始值为1/3.0,每次*10,然后取整数部分,当两次的结果相同时说明已经到最大 ...
- 框架之 hibernate之各种查询
1. Hibernate的查询方式 2. Hibernate的查询策略 案例:使用Hibernate完成查询所有联系人功能 需求分析 1. 完成所有的联系人的查询 技术分析之Hibernate框架的查 ...