ThinkPHP讲解(五)——数据库配置及Model数据模型层、查询

时间:2023-01-18 18:59:24

数据库配置

在TP框架中要进行连接数据库操作,要进行配置

要在convertion.php中找到“数据库配置”,并复制到项目配置文件config.php中

ThinkPHP讲解(五)——数据库配置及Model数据模型层、查询

Model模型层制作

model:数据库中每张表对应一个模型
       类名就是表名,类里面的成员变量就是列名
       把一张表对应一个类,其中一条数据对应一个对象

如果我们对该表的模型没有特殊操作的话可以不用建立该模型

现在要制作一个最简单的model模型InfoModel.class.php

<?php
namespace Home\Model; //命名空间在home里的model文件夹下
use Think\Model; //父类文件在ThinkPHP/Library/Think/Model.class.php中 class InfoModel extends Model
{ }

  

三种实例化model方式

//实例化model类
//new 命名空间\Model\模型层名()
//$info= new \Home\Model\InfoModel();
//var_dump($info); //$info=D("Info"); //D("模型标志")
//var_dump($info); $car=M("car"); //M("数据表标志");
//var_dump($car);

  

查询数据库

//var_dump($car->select());//查询,返回数据的二维数组形势

		//$attr=$car->where("brand='b002'")->select();//where方法可以添加查询条件

		//$attr=$car->table("nation")->select();//table方法切换操作表

		//$attr=$car->field("code,name")->select();//field 可以指定查询的字段

		//$attr=$car->order("oil desc")->select();//排序

		//$attr=$car->limit(2,2)->select();//分页查询,如果一个参数n代表取前n个;如果两个参数m,n代表跳过前m个,取n个。

		//$attr=$car->page(3,2)->select();//分页,两个参数m,n代表第m页,n条数据

		//$attr=$car->field("brand,count(*)")->group("brand")->select();//分组查询

		//select * from info join nation on 条件;

		//$attr=$car->join("brand on car.brand=brand.brand_code")->select();//连接查询

		//$attr=$car->distinct(true)->field("brand")->select();//去重查询

		//$attr=$car->find("c001");//根据主键取一条数据,返回一维数组;不写主键值,默认返回第一条

		//$attr=$car->select("c001,c002");//根据主键值查询,返回二维数组

		$attr=$car->where("name like '%奥迪%'")->order("powers desc")->select();

		$this->assign("shuzu",$attr);

                $this->display()

  

ThinkPHP讲解(五)——数据库配置及Model数据模型层、查询的更多相关文章

  1. 2016&sol;05&sol;10 thinkphp 3&period;2&period;2 ①系统常量信息 ②跨控制器调用 ③连接数据库配置及Model数据模型层 ④数据查询

    [系统常量信息] 获取系统常量信息: 如果加参数true,会分组显示: 显示如下: [跨控制器调用] 一个控制器在执行的时候,可以实例化另外一个控制,并通过对象访问其指定方法. 跨控制器调用可以节省我 ...

  2. 6月16 ThinkPHP连接数据库及Model数据模型层--------查询及数据添加

    连接数据库配置及Model数据模型层 convertion.php config.php 1.在config.php做数据库连接配置 2.修改配置 /* 数据库设置 */ 'DB_TYPE' =&gt ...

  3. TP【连接数据库配置及Model数据模型层】

    [连接数据库配置及Model数据模型层] convertion.php config.php 在config.php做数据库连接配置 制作model模型 a) model本身就是一个类文件 b) 数据 ...

  4. tp框架连接数据库配置及Model数据模型层

    在config.php做数据库连接配置 <?php return array( //'配置项'=>'配置值' 'SHOW_PAGE_TRACE'=>true, /* 数据库设置 */ ...

  5. ThinPHP命名空间&comma;连接数据库是要修改的配置文件,Model数据模型层&comma;跨控制器调用,如何获取系统常量信息,

    一.命名空间(主要是为了实现自动加载类) *命名空间(相当于虚拟的目录),为了让类有一个统一的文件夹来管理(可以自动加载'类'),每个文件都要有命名空间*tp如何做命名空间:*TP框架下有一个初始命名 ...

  6. ThinkPHP的主从数据库配置

    Thinkphp 框架本身是支持读写分离的,如何做呢?   最简单的做法是在配置文件中修改:   PHP代码 'DB_TYPE'=> 'mysql', 'DB_DEPLOY_TYPE' =&gt ...

  7. Thinkphp 数据库配置参数

    mysql配置 'DB_USER' => array( 'DB_TYPE' => 'mysql', 'DB_HOST' => '127.0.0.1', 'DB_NAME' => ...

  8. Thinkphp入门 五 —模型 (49)

    原文:Thinkphp入门 五 -模型 (49) [数据库操作model模型] model  模型  数据库操作 tp框架主要设计模式:MVC C:controller   控制器   shop/Li ...

  9. ThinkPhp框架对&OpenCurlyDoubleQuote;数据库”的基本操作

    框架有时会用到数据库的内容,在"ThinkPhp框架知识"的那篇随笔中提到过,现在这篇随笔详细的描述下. 数据库的操作,无疑就是连接数据库,然后对数据库中的表进行各种查询,然后就是 ...

随机推荐

  1. SQL必知必会 14-22(完)

    博主依然不想打字,又向你仍来了一堆代码... 13(续) 在SELECT中用COUNT()以及联合 mysql> SELECT customers.cust_id,COUNT(orders.or ...

  2. Python3 学习第十二弹: 补充something

    python中遇到 *keys, **keys的形式 其实 * 代表传递任意个无名字参数,这些参数通过Tuple访问 >>> def sum(*keys): ret= 0 for i ...

  3. Careercup - Facebook面试题 - 6204973461274624

    2014-05-02 02:28 题目链接 原题: I/P: N, k O/P: all subset of N with exactly K elements. eg: I/p: N = , K = ...

  4. NOIP2014 生活大爆炸版石头剪刀布

    生活大爆炸版石头剪刀布 (rps.cpp/c/pas) [问题描述] 石头剪刀布是常见的猜拳游戏:石头胜剪刀,剪刀胜布,布胜石头.如果两个人出拳一样,则不分胜负.在<生活大爆炸>第二季第8 ...

  5. &lpar;转&rpar;Spring读书笔记-----Spring核心机制:依赖注入

    Java应用(从applets的小范围到全套n层服务端企业应用)是一种典型的依赖型应用,它就是由一些互相适当地协作的对象构成的.因此,我们说这些对象间存在依赖关系.加入A组件调用了B组件的方法,我们就 ...

  6. bzoj 2819 Nim(BIT,dfs序,LCA)

    2819: Nim Time Limit: 20 Sec  Memory Limit: 128 MBSubmit: 1596  Solved: 597[Submit][Status][Discuss] ...

  7. Android第一次打开应用程序,实现向导界面

    转载请注明出处,谢谢http://blog.csdn.net/harryweasley/article/details/42079167 先说下思路:1.利用Preference存储数据,来记录是否是 ...

  8. 读Vue源码 (依赖收集与派发更新)

    vue的依赖收集是定义在defineReactive方法中,通过Object.defineProperty来设置getter,红字部分主要做依赖收集,先判断了Dep.target如果有的情况会执行红字 ...

  9. ultraEdit MAC 破解方法

    安装了个UltraEdit 但是需要验证码,太麻烦了,破解方法: 拷贝附件(command +c )然后在MAC的底下点击访达==>应用程序==>UltraEdit==>右击 显示包 ...

  10. matlabr2015b安装教程

    R2015b MATLAB破解版安装教程 MATLAB和Mathematica.Maple并称为三大数学软件.它在数学类科技应用软件中在数值计算方面首屈一指.MATLAB可以进行矩阵运算.绘制函数和数 ...