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

thinkphp增删改查简单的操作

CURD增删改查操作,先给出一套代码CURDAction.class.php<?php//测试对于数据库的增删改查操作classCURDActionextendsAction{//index页面publ...

CURD增删改查操作,先给出一套代码CURDAction.class.php

  1.  
  2. //测试对于数据库的增删改查操作 
  3.  
  4. classCURDActionextendsAction 
  5.  
  6.  
  7. //index页面 
  8.  
  9. publicfunctionindex() 
  10.  
  11.  
  12. $this->assign(&#39;title&#39;,&#39;添加数据&#39;);//这里设置了模板变量{$title} 
  13.  
  14. $this->assign(&#39;datetime&#39;,date("Y-m-dH:i:s")); 
  15.  
  16. $this->display(); 
  17.  
  18.  
  19. //INSERT操作 
  20.  
  21. publicfunctioncreate() 
  22.  
  23.  
  24. //初始化操作,建立表think_demo所对应的映射对象(O/RMapping) 
  25.  
  26. $demo=D("Demo"); 
  27.  
  28. if($demo->create()){ 
  29.  
  30. //对字段autotime的赋值操作:以date("Y-m-dH:i:s")的方式获取mysql数据库datetime字段类型所接受的日期格式。 
  31.  
  32. $demo->autotime=date("Y-m-dH:i:s"); 
  33.  
  34. //insert操作 
  35.  
  36. $demo->add(); 
  37.  
  38. //跳转到显示页面 
  39.  
  40. //$this->display("read"); 
  41.  
  42. $this->redirect("read"); 
  43.  
  44. }else
  45.  
  46. header("Content-Type:text/html;charset=utf-8"); 
  47.  
  48. exit($demo->getError().&#39;[返回aaaaaa]&#39;); 
  49.  
  50.  
  51.  
  52. //SELECT操作 
  53.  
  54. publicfunctionread() 
  55.  
  56.  
  57. $demo=D("Demo"); 
  58.  
  59. $data=$demo->order(&#39;iddesc&#39;)->limit(10)->select(); 
  60.  
  61. $this->assign(&#39;data&#39;,$data); 
  62.  
  63. $this->assign(&#39;title&#39;,&#39;添加数据2&#39;); 
  64.  
  65. $this->display(); 
  66.  
  67.  
  68. //UPDATE操作 
  69.  
  70. publicfunctionupdate() 
  71.  
  72.  
  73. $demo=D("Demo"); 
  74.  
  75. //实践时发现,当用户不出发onClick事件的话,create()方法可能不被执行,因为单刷页面的话,数据库没有被更新 
  76.  
  77. //create()方法:从html表单中自动提取数据,注入到Model对象中。 
  78.  
  79. //$demo->create(); 
  80.  
  81. //$demo->save(); 
  82.  
  83. //和上面的代码一样 
  84.  
  85. $date[&#39;title&#39;]=$_POST[&#39;title&#39;]; 
  86.  
  87. $date[&#39;content&#39;]=$_POST[&#39;content&#39;]; 
  88.  
  89. $date[&#39;id&#39;]=$_POST[&#39;id&#39;]; 
  90.  
  91. $demo->save($date); 
  92.  
  93. $this->assign(&#39;title&#39;,&#39;更新数据2&#39;); 
  94.  
  95. $this->display(); 
  96.  
  97.  
  98. //DELECT操作 
  99.  
  100. publicfunctiondelect() 
  101.  
  102.  
  103. $demo=D("Demo"); 
  104.  
  105. $demo->where(&#39;id=5&#39;)->delete(); 
  106.  
  107. $this->redirect("read"); 
  108.  
  109.  
  110.  
  111. ?> 

理解一下操作,就能理解上面的代码了,因为要下班了,回家后再作详解.

1。$demo=D("Demo");

通过数据库建立一个指定表的映射对象。

2。$demo->create()

通过相同的表单name属性名,自动的把表单里的值加载到映射对象中

3。$demo->add();

插入操作,将不为空的映射对象里的数据插入到数据库内

4。$date[&#39;title&#39;]=$_POST[&#39;title&#39;];

$date[&#39;content&#39;]=$_POST[&#39;content&#39;];
 
$date[&#39;id&#39;]=$_POST[&#39;id&#39;];
 
$demo->save($date);
 
更新操作,这里做的是无条件更新,系统会自动通过主键更新
 
5。$demo->where(&#39;id=5&#39;)->delete();
 

通过设置条件,删除操作。

6。$data=$demo->order(&#39;iddesc&#39;)->limit(10)->select();

$this->assign(&#39;data&#39;,$data);

推荐阅读
  • 在使用如新浪微博和腾讯微博等平台的Python API时,发现了一种将字典转换为函数参数的有效方法,即通过在字典前添加双星号(*)来实现动态变量的传递。这种方法不仅提高了代码的灵活性,也简化了API调用过程。 ... [详细]
  • CentOS系统下设置JDK环境变量的方法
    本文将详细介绍如何在CentOS系统中为root用户配置JDK环境变量。包括JDK的安装路径设定、环境变量的添加及验证方法。 ... [详细]
  • 深度兴趣网络在点击率预测中的应用研究
    本文探讨了一种名为深度兴趣网络(Deep Interest Network, DIN)的新方法,该方法通过捕捉用户的历史行为和当前上下文之间的交互来提高点击率预测的准确性。DIN模型不仅考虑了用户的静态偏好,还动态地调整了对不同商品的兴趣权重,从而实现了更加个性化的推荐。 ... [详细]
  • 本文探讨了一个项目中遇到的挑战,即如何通过技术手段解决不同菜单项触发时,跨域IFrame页面的高度自适应问题。通过创建中介页面和利用JavaScript与Cookie机制,实现无缝的用户体验。 ... [详细]
  • 在 PHP 4, PHP 5 和 PHP 7 中,fstat 函数用于获取已打开文件指针的文件统计信息。此函数与 stat() 类似,但其操作对象为已打开的文件指针而非文件名称。 ... [详细]
  • 本文探讨了在PHP中处理特定类型编码字符串的方法,特别是如何将HTML实体编码的字符串转换为普通文本。 ... [详细]
  • Java 动态代理详解与示例
    本文详细介绍了Java中的动态代理机制,包括如何定义接口、实现类和代理处理器,并通过具体示例演示了动态代理的创建和使用过程。 ... [详细]
  • LeetCode 6057: 计算与子树平均值相等的节点数量——深度优先搜索
    本题要求在给定的二叉树中找到所有符合条件的节点数量,即节点的值等于其所有后代节点(包括自身)值的平均值。这里的平均值是通过将所有后代节点值之和除以后代节点的数量,并向下取整得到。 ... [详细]
  • CSGO
    CSGOTimeLimit:40002000MS(JavaOthers)MemoryLimit:524288524288K(JavaOthers)ProblemDescriptio ... [详细]
  • 本文介绍了如何通过自定义View中的declare-styleable属性创建枚举类型,并在代码中访问这些枚举值的方法。 ... [详细]
  • 本文汇集了使用C#中不同HTTP客户端向Web API上传文件的实例,旨在为开发者提供实用的技术指南。 ... [详细]
  • 本文详细介绍了在PHP中如何创建新文件以及如何使自定义函数在整个项目中全局可用的方法,包括最新的实践技巧。 ... [详细]
  • 解决Android开发中的TextView难题
    探讨了在Android开发过程中遇到的关于TextView组件的常见问题,特别是如何实现多行文字的跑马灯效果,并提供了初步的解决方案和参考资料。 ... [详细]
  • Only2 Labs 是一家专注于视觉设计的工作室,如果您对当前的设计感到不满,或者急需寻找一个可靠的设计合作伙伴,甚至是您的团队项目需要专业指导,Only2 Labs 都将竭诚为您提供帮助。 ... [详细]
  • 解决phpMyAdmin运行错误:mysqli_init(): 属性访问尚未允许
    本文探讨了在使用phpMyAdmin过程中遇到的mysqli_init()函数错误,并提供了有效的解决方案。 ... [详细]
author-avatar
潇湘V烟雨
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有