热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

CURD和关联操作

1、简单查询$userM('user');//查询一条信息,返回一维数组$list$user->find();//查询所有信息,返回二维数组select或者findAll()...

1、简单查询

  1. $user=M('user'); 
  2. //查询一条信息,返回一维数组 
  3. $list=$user->find(); 
  4. //查询所有信息,返回二维数组select或者findAll() 
  5. $list=$user->select(); 

2、查询中的连贯操作

(1)、where方法

  1. $User->where( 'status=1' )->order( 'create_time' )->limit(10)->select(); 
  2.    $User->select(array'order'=>'create_time''where'=>'status=1''limit'=>'10' )); 
  3.    $User->where( 'id=1' )->field( 'id,name,email' )->find();  
  4.    $User->where( 'status=1 and id=1' )->delete(); 
  5.    $list=$user->where('id>1')->limit('5')->order('id desc')->field('id,username')->select();  

(2)、跨表查询$user->table()

  1. $list=$user->table('aoli_user u,aoli_test t')->where('u.id=t.id')->select();  

(3)、$user->data() data方法是可以被替代的,主要在save,add,delete操作的时候使用,保存数据用的

  1. $Model->data($data)->add(); 
  2. $Model->data($data)->where( 'id=3' )->save(); 

Data 方法的参数支持对象和数组,如果是对象会自动转换成数组,如果不定义 data 方法赋值,也可以使用 create 方法或者手动给数据对象赋值的方式.

(4)、$user->field()

指定查询哪些字段字段,参数可以是字符串field('user.id as uid,m.id as mid '),也可以是数组field(array('user.id'=>'uid','m.id'=>'mid'))

(5)、$user->order()

参数也是既可以是字符串order('id desc')也可以是数组order(array('id'=>'desc','username'))

  1. $Model->field( 'id,nickname as name' )->select(); 
  2. $Model->field(array'id','nickname'=>'name' ))->select(); 

(6)、limit()

有两个参数,第一个指起始位置,第二个参数指定查询多少条.

limit('8')  从第1条开始,查8条

limit('3,8')  从第3条开始,查8条

(7)、page()查询分页

(8)、group()分组

$user->group('')->select()

(9)、having方法,主要用于二次过滤。

(10)、join关联查询,常用的有内关联,左关联,右关联,默认为左关联

(11)、distinct 唯一性过滤

select distinct id ,username from ..

过滤掉重复过滤

$user->distinct(true)->select();

(12)、relation方法 关联模型

(13)、lock 查询锁 lock(true)

3、更新数据 save()

  1. $user=M('user'); 
  2. $data['password']='aaaa'
  3. $list=$user->where('id=1')->save($data); 
  4. //或者 
  5. $user=M('user'); 
  6. $data['password']='aaaa'
  7. $data['id']='4'
  8. $list=$user->save($data); 
  9. //或者 
  10. $user=M('user'); 
  11. $data['password']='aaaa'
  12. $data['id']='4'
  13. $list=$user->data($data)->save(); 

create来更新数据

create.html:

  1. <form action="__URL__/addit" method="post"> 
  2.       <input type="text" name="id" /> 
  3.       <input type="text" name="username" /> 
  4.       <input type="password" name="password" /> 
  5.       <input name="id" type="hidden" value="25" /> 
  6.       <input type="submit" name="sub" value="提交" /> 
  7. form> 

UserAction.class.php

  1. function create(){ 
  2.         $this->display(); 
  3.      } 
  4.       
  5.      function addit(){ 
  6.          $user=M(&#39;user&#39;); 
  7.          if($vo=$user->create()){ 
  8.              //$user->password=md5($user->password); 
  9.              if($user->save()){ 
  10.                  $this->success(&#39;更新成功&#39;); 
  11.              }else
  12.                  $this->error(&#39;更新失败&#39;);     
  13.              } 
  14.          } 
  15.      } 

$vo为影响的行数,即更新了多少行,其它方法诸如setInc(通常是数字的字段来进行操作),第一个写字段,第二个写条件,第三个写需要增加整数:

$list=$user->setInc(&#39;price&#39;,&#39;id=1&#39;,3);//表示price的字段加3

setDec就是进行减的操作

$list=$user->setDec(&#39;price&#39;,&#39;id=1&#39;,3);//表示price的字段减3

setField单条记录定向修改

$user->where(&#39;id=1&#39;)->setField(array(&#39;username&#39;,&#39;password&#39;),array(&#39;google&#39;,&#39;baidu&#39;));

4、添加数据 add()

  1. $user=M(&#39;user&#39;); 
  2. $data[&#39;password&#39;]=&#39;aaaa&#39;
  3. $list=$user->data($data)->add();   

$list为插入后的主键值,或者用createg来添加:

  1. function addit(){ 
  2.      $user=M(&#39;user&#39;); 
  3.      $vo=$user->create(); 
  4.      $user->add();         
  5.  } 

表单post过来的值经过create方法以数组的形式压缩到了$vo中

5、删除数据 delete()

  1. function del(){ 
  2.    $user=M(&#39;user&#39;); 
  3.    $list=$user->delete(25); 
  4.    dump($list);      
  5. //或者 
  6. function del(){ 
  7.    $user=M(&#39;user&#39;); 
  8.    $list=$user->where(&#39;id>5&#39;)->delete(); 
  9.    dump($list);      

推荐阅读
  • 在项目部署后,Node.js 进程可能会遇到不可预见的错误并崩溃。为了及时通知开发人员进行问题排查,我们可以利用 nodemailer 插件来发送邮件提醒。本文将详细介绍如何配置和使用 nodemailer 实现这一功能。 ... [详细]
  • 本文探讨了如何利用jQuery在客户端实现页面跳转,并详细介绍了如何确保页面在浏览器的顶层窗口中打开,而不是局限于当前框架内。 ... [详细]
  • 本文详细探讨了JavaScript中的作用域链和闭包机制,解释了它们的工作原理及其在实际编程中的应用。通过具体的代码示例,帮助读者更好地理解和掌握这些概念。 ... [详细]
  • Windows 7 64位系统下Redis的安装与PHP Redis扩展配置
    本文详细介绍了在Windows 7 64位操作系统中安装Redis以及配置PHP Redis扩展的方法,包括下载、安装和基本使用步骤。适合对Redis和PHP集成感兴趣的开发人员参考。 ... [详细]
  • 雨林木风 GHOST XP SP3 经典珍藏版 V2017.11
    雨林木风 GHOST XP SP3 经典珍藏版 V2017.11 ... [详细]
  • Hadoop发行版本选择指南:技术解析与应用实践
    本文详细介绍了Hadoop的不同发行版本及其特点,帮助读者根据实际需求选择最合适的Hadoop版本。内容涵盖Apache Hadoop、Cloudera CDH等主流版本的特性及应用场景。 ... [详细]
  • 采用IKE方式建立IPsec安全隧道
    一、【组网和实验环境】按如上的接口ip先作配置,再作ipsec的相关配置,配置文本见文章最后本文实验采用的交换机是H3C模拟器,下载地址如 ... [详细]
  • 丽江客栈选择问题
    本文介绍了一道经典的算法题,题目涉及在丽江河边的n家特色客栈中选择住宿方案。两位游客希望住在色调相同的两家客栈,并在晚上选择一家最低消费不超过p元的咖啡店小聚。我们将详细探讨如何计算满足条件的住宿方案总数。 ... [详细]
  • 本文详细介绍了在腾讯云服务器上配置 phpMyAdmin 的方法,包括安装、配置和解决常见问题。通过这些步骤,您可以轻松地在腾讯云环境中部署并使用 phpMyAdmin。 ... [详细]
  • Python 内存管理机制详解
    本文深入探讨了Python的内存管理机制,涵盖了垃圾回收、引用计数和内存池机制。通过具体示例和专业解释,帮助读者理解Python如何高效地管理和释放内存资源。 ... [详细]
  • 本文介绍了数据库体系的基础知识,涵盖关系型数据库(如MySQL)和非关系型数据库(如MongoDB)的基本操作及高级功能。通过三个阶段的学习路径——基础、优化和部署,帮助读者全面掌握数据库的使用和管理。 ... [详细]
  • C#设计模式学习笔记:观察者模式解析
    本文将探讨观察者模式的基本概念、应用场景及其在C#中的实现方法。通过借鉴《Head First Design Patterns》和维基百科等资源,详细介绍该模式的工作原理,并提供具体代码示例。 ... [详细]
  • JSOI2010 蔬菜庆典:树结构中的无限大权值问题
    本文探讨了 JSOI2010 的蔬菜庆典问题,主要关注如何处理非根非叶子节点的无限大权值情况。通过分析根节点及其子树的特性,提出了有效的解决方案,并详细解释了算法的实现过程。 ... [详细]
  • 本文详细介绍了如何在预装Ubuntu系统的笔记本电脑上安装Windows 7。针对没有光驱的情况,提供了通过USB安装的具体方法,并解决了分区、驱动器无法识别等问题。 ... [详细]
  • Coursera ML 机器学习
    2019独角兽企业重金招聘Python工程师标准线性回归算法计算过程CostFunction梯度下降算法多变量回归![选择特征](https:static.oschina.n ... [详细]
author-avatar
谭宏景
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有