Thinkphp CURD操作php中实例还对象即可操作 (目录)

1.Add 1

调式程序 3

调出显示页面Trace信息 3

Dump 的含义 4

2.数据库查询 4

1.直接使用字符串进行查找 4

2.使用数组的方式进行查询 5

3.表达式的方式进行查询 5

Php中的表达式定义 6

4.区间查询 6

5.混合用法  6

6. 统计用法 7

3.更新操作 8

4.删除操作 8

1.Add

$data=array(

'user_name'=>'xiaoming',
'nick_name'=>'小米',
'password'=>md5('123456'),
'score'=>'100',
'create_date'=>date('Y-m-d H:i:s'),
'update_date'=>date('Y-m-d H:i:s'),

);

echo M('user')->add($data);

二维数组插入

$data=array(
    0=>array(
         'user_name'=>'xiaoming',
         'nick_name'=>'小米',
         'password'=>md5('123456'),
         'score'=>'100',
         'create_date'=>date('Y-m-d H:i:s'),
         'update_date'=>date('Y-m-d H:i:s'),
     ),
    1=>array(
    'user_name'=>'xiaoming',
    'nick_name'=>'小wo',
    'password'=>md5('123456'),
    'score'=>'100',
    'create_date'=>date('Y-m-d H:i:s'),
    'update_date'=>date('Y-m-d H:i:s'),
),
    2=>array(
    'user_name'=>'xiaoming',
    'nick_name'=>'小sd',
    'password'=>md5('123456'),
    'score'=>'100',
    'create_date'=>date('Y-m-d H:i:s'),
    'update_date'=>date('Y-m-d H:i:s'),
),
    3=>array(
    'user_name'=>'xiaoming',
    'nick_name'=>'小fd',
    'password'=>md5('123456'),
    'score'=>'100',
    'create_date'=>date('Y-m-d H:i:s'),
    'update_date'=>date('Y-m-d H:i:s'),
)
//二维数组如何一次性插入进去
);
     echo M('user')->addAll($data);
}

调式程序

调出显示页面Trace信息

'

SHOW_PAGE_TRACE'=>true,//显示页面Trace信息

<?php
return array(
   //'配置项'=>'配置值'
   // 'name'=>'Donsen2',
    'LOAD_EXT_CONFIG'=>'user',
    'URL_MODEL'=> 2,
    'URL_HTML_SUFFIX'  =>  'shtml|html|xml',  // URL伪静态后缀设置
    'SHOW_PAGE_TRACE'=>true,//显示页面Trace信息
);

$this->display();

Dump 的含义

var_dump是php用来 打印 变量的 函数 用作 调试
dump ThinkPHP 框架 自定义的  用作框架变量 调试用的输出 功能可以说和 var_dump一样的

2.数据库查询

数据库查询   所有的数据

public functionindex()
{
    //select 查询
     $data=M('User')->select();
     dump($data);
     $this->display();
}

1.直接使用字符串进行查找

public function index()
{
    //select 查询
    //直接使用字符串进行查找
     $data=M('User')->where('id=1')->select();
     dump($data);
     $this->display();
}

2.使用数组的方式进行查询

public function index()
{
    //select 查询
    //使用数组的方式进行查询
     $where['id']=2;
     $data=M('User')->where($where)->select();
     dump($data);
     $this->display();
}

查询 id为小明

//select 查询
//使用数组的方式进行查询
 $where['id']=2;
 $where['user_name']='xiaoming';
 //SELECT * FROM `mk_user` WHERE `id` = 2 AND `user_name` = 'kitte' [ RunTime:0.0030s ]
//and  变成 or
$where['_logic']='or';//SELECT * FROM `mk_user` WHERE `id` = 2 OR `user_name` = 'xiaoming' [ RunTime:0.0010s ]
 $data=M('User')->where($where)->select();
 dump($data);
 $this->display();

3.表达式的方式进行查询

//select 查询
//表达式的方式进行查询 eq neq egt gt lt elt between in like not between
// $where['字段名']=array(表达式,查询条件)
 $where['id']=array('gt',1);
 $data=M('User')->where($where)->select();
 dump($data);
 $this->display();

Php中的表达式定义

eq 等于
neq 不等于
gt 大于
egt 大于等于
lt 小于
elt 小于等于
like LIKE    模糊查询    ('like','ming');

数组查询

$where['user_name']=array('like',array('%ming','xiao%'));
between BETWEEN    ('between','1,8');
notnull IS NUT NULL
null IS NULL

egf 是表示数据库的字段比较,而非字符串比较
例如:
$map['name']  = array('eq','label'); 和
$map['name'] = array('eqf','label');
分别代表 name = 'label' 和 name = label 
同样的道理,gt lt 等其他表达式也可以在后面添加f来表示同样的功能~

4.区间查询

附加   与between 比较类似  是官方里面的区间查询

$where['id']=array(array('gt',1),array('lt',10));

SELECT * FROM `mk_user` WHERE ( `id` > 1 AND `id` < 10 )

And和or的区别  一个要同时满足  一个是满足其中一个关系

5.混合用法   查询 id>10  score>10

//混合用法
$where['id']=array('gt',10);
$where['_string']='score>10';
$data=M('User')->where($where)->select();
dump($data);
$this->display();

用表达式查询和区间查询就能查询就不要用混合方式,也不要用字符串的方式查询

表达式可以使数据库避免注入

6.统计用法

public function index()
{
      //统计用法
    /*
     * count 统计数量
     * max 获取最大值
     * min 最小值
     * avg 平均值
     * sum 求和
      * */
     $data=M('User')->count();
     dump($data);
     $this->display();
}

  1. SELECT COUNT(*) AS tp_count FROM `mk_user` LIMIT 1 [ RunTime:0.1470s ]

$data=M('User')->max(id);

  1. SELECT MAX(id) AS tp_max FROM `mk_user` LIMIT 1 [ RunTime:0.0210s ]

string(1) "9"

查询平均分成绩

$data=M('User')->avg('score');

  1. SELECT AVG(score) AS tp_avg FROM `mk_user` LIMIT 1 [ RunTime:0.0000s ]

3.更新操作

//更新操作
$update['score']=60;
$where['id']=1;
$data=M('User')->where($where)->save($update);
dump($data);
$this->display();

  1. UPDATE `mk_user` SET `score`='60' WHERE `id` = 1 [ RunTime:0.0000s ]

4.删除操作

public function index()
{
    $where['id']=1;
    echo M('User')->where($where)->delete();

$this->display();
}

  1. DELETE FROM `mk_user` WHERE `id` = 1 [ RunTime:0.0000s ]

懒惰删除id

echo  M('User')->delete(2);
$this->display();

ThinkPHP CURD 操作的更多相关文章

  1. thinkphp 连接数据库 & 实例化模型操作 (下接thinkphp CURD 操作)/慕课

    7.1 连接数据库 (06:15) 1 7.2实例化模型 1 1.实例化基础模型 2 2. 实例化用户自定义模型 2 问题 2 3. 实例化公共模型 4 4. 实例化空模型 7    7.1 连接数据 ...

  2. ThinkPHP CURD mysql操作

    ThinkPHP CURD操作 ThinkPHP提供了灵活和方便的数据操作方法,对数据库操作的四个基本操作(CURD):创建.更新.读取和删除的实现是最基本的,也是必须掌握的,在这基础之上才能熟悉更多 ...

  3. thinkphp对mysql的CURD操作

    利用thinkphp(3.2.3)来操作数据库,首先要连接数据库.我们需要对某数据库写一个配置文件,thinkphp会根据该配置文件自动连接上数据库.而model文件就不用自定义,内置的即可解决问题. ...

  4. ThinkPHP CURD返回结果参考

    ThinkPHP CURD返回结果参考: 1)查询$table->find() ##返回一条记录,是一个关联数组,是一维数组.$table->select() ##返回第一维是索引数组,第 ...

  5. ThinkPHP CURD方法盘点:field方法

    ThinkPHP的CURD操作中有很多非常实用的方法,从这篇开始,我们会为大家一一介绍. 首先为大家介绍下field方法的用法.field属于模型的连贯操作方法之一,主要目的是标识要返回或者操作的字段 ...

  6. ThinkPHP 数据库操作(五) : 存储过程、数据集、分布式数据库

    存储过程 5.0支持存储过程,如果我们定义了一个数据库存储过程 sp_query ,可以使用下面的方式调用: $result = Db::query('call sp_query(8)'); 返回的是 ...

  7. ThinkPHP 数据库操作(三) : 查询方法、查询语法、链式操作

    查询方法 条件查询方法 where 方法 可以使用 where 方法进行 AND 条件查询: Db::table('think_user') ->where('name','like','%th ...

  8. ThinkPHP CURD方法中field方法详解

    导读:ThinkPHP CURD方法的field方法属于模型的连贯操作方法之一,主要目的是标识要返回或者操作的字段,可以用于查询和写入操作. 1.用于查询在查询操作中field方法是使用最频繁的.$M ...

  9. TP中CURD操作

    CURD操作 CURD操作也就是模型操作数据表的基本操作.C(Create).U(Update).R(Read).D(Delete)操作就是增删改查操作. 6.1.增加操作 回想一下在mysql中增加 ...

随机推荐

  1. 四川第七届 C Censor (字符串哈希)

    Censor frog is now a editor to censor so-called sensitive words (敏感词). She has a long text pp. Her j ...

  2. linux下面的df命令

    linux中df命令的功能是用来检查linux服务器的文件系统的磁盘空间占用情况.可以利用该命令来获取硬盘被占用了多少空间,目前还剩下多少空间等信息. 1.命令格式: df [选项] [文件] 2.命 ...

  3. 利用DNS进行传输数据

    曾经有这样一道题目,困了我数个小时,最后我尝试利用此方法时我知道真相的时候,眼泪已掉下来. 遇到的是一个流量分析题,分析DNS数据,拿到flag 流量如图所示: 进入linux,提取: [root@s ...

  4. appium python版api

    打印上下文 driver.contexts 打印当前上下文 driver.context driver.current_context 切换上下文 driver.switch_to.context(' ...

  5. centos软件安装目录(amp目录)

    entos安装软件的目录 1. 如果是rpm安装的可以:rpm -ql package-name 2. 可以在根目录上直接find . -name 软件中的某个文件名 不过安装软件一般都在/usr/l ...

  6. C#调用带返回值的存储过程

    ()在SQL Server中建立如下的存储过程: set ANSI_NULLS ON set QUOTED_IDENTIFIER ON GO CREATE PROCEDURE [dbo].[GetNa ...

  7. div的作用

    <div></div>主要是用来设置涵盖一个区块为主,所谓的区块是包含一行以上的数据,所以在<div></div>的开始之前与结束后,浏览都会自动换行, ...

  8. hadoop再次集群搭建(1)-安装系统

    从8月份到现在12月份,中间有四个月的时间没有学习hadoop系统了.其实适应新的环境,到现在一切尘埃落定,就应该静下心来,好好学习一下hadoop以及我之前很想学习的mahout.个人对算法比较感兴 ...

  9. 关于android studio中使用class.forname()方法动态获取类实例报NO CLASS FOUND异常的几种处理方法

    最近在做一个项目的时候需要用到反射来回调子类的方法,但是在反射过程中总是在class.forname()方法抛出NO CLASS FOUND异常,经过几部检查,问题解决,在此总结一下引起该问题的原因 ...

  10. linux下vtune使用

    安装:http://www.cnblogs.com/jiu0821/p/5943533.html 终端输入amplxe-gui,打开vtune界面. 点击new project,进入project p ...