热门标签 | 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);      

推荐阅读
  • 深入理解OAuth认证机制
    本文介绍了OAuth认证协议的核心概念及其工作原理。OAuth是一种开放标准,旨在为第三方应用提供安全的用户资源访问授权,同时确保用户的账户信息(如用户名和密码)不会暴露给第三方。 ... [详细]
  • 2023 ARM嵌入式系统全国技术巡讲旨在分享ARM公司在半导体知识产权(IP)领域的最新进展。作为全球领先的IP提供商,ARM在嵌入式处理器市场占据主导地位,其产品广泛应用于90%以上的嵌入式设备中。此次巡讲将邀请来自ARM、飞思卡尔以及华清远见教育集团的行业专家,共同探讨当前嵌入式系统的前沿技术和应用。 ... [详细]
  • 程序员妻子吐槽:丈夫北漂8年终薪3万,存款情况令人意外
    一位程序员的妻子在网上分享了她丈夫在北京工作八年的经历,月薪仅3万元,存款情况却出乎意料。本文探讨了高学历人才在大城市的职场现状及生活压力。 ... [详细]
  • 国内BI工具迎战国际巨头Tableau,稳步崛起
    尽管商业智能(BI)工具在中国的普及程度尚不及国际市场,但近年来,随着本土企业的持续创新和市场推广,国内主流BI工具正逐渐崭露头角。面对国际品牌如Tableau的强大竞争,国内BI工具通过不断优化产品和技术,赢得了越来越多用户的认可。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 深入理解 Oracle 存储函数:计算员工年收入
    本文介绍如何使用 Oracle 存储函数查询特定员工的年收入。我们将详细解释存储函数的创建过程,并提供完整的代码示例。 ... [详细]
  • 在 Windows 10 中,F1 至 F12 键默认设置为快捷功能键。本文将介绍几种有效方法来禁用这些快捷键,并恢复其标准功能键的作用。请注意,部分笔记本电脑的快捷键可能无法完全关闭。 ... [详细]
  • 本文总结了2018年的关键成就,包括职业变动、购车、考取驾照等重要事件,并分享了读书、工作、家庭和朋友方面的感悟。同时,展望2019年,制定了健康、软实力提升和技术学习的具体目标。 ... [详细]
  • 在计算机技术的学习道路上,51CTO学院以其专业性和专注度给我留下了深刻印象。从2012年接触计算机到2014年开始系统学习网络技术和安全领域,51CTO学院始终是我信赖的学习平台。 ... [详细]
  • Linux 系统启动故障排除指南:MBR 和 GRUB 问题
    本文详细介绍了 Linux 系统启动过程中常见的 MBR 扇区和 GRUB 引导程序故障及其解决方案,涵盖从备份、模拟故障到恢复的具体步骤。 ... [详细]
  • 探讨如何高效使用FastJSON进行JSON数据解析,特别是从复杂嵌套结构中提取特定字段值的方法。 ... [详细]
  • 本文介绍了如何使用jQuery根据元素的类型(如复选框)和标签名(如段落)来获取DOM对象。这有助于更高效地操作网页中的特定元素。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • PHP 5.2.5 安装与配置指南
    本文详细介绍了 PHP 5.2.5 的安装和配置步骤,帮助开发者解决常见的环境配置问题,特别是上传图片时遇到的错误。通过本教程,您可以顺利搭建并优化 PHP 运行环境。 ... [详细]
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社区 版权所有