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

推荐阅读
  • 本文介绍了lua语言中闭包的特性及其在模式匹配、日期处理、编译和模块化等方面的应用。lua中的闭包是严格遵循词法定界的第一类值,函数可以作为变量自由传递,也可以作为参数传递给其他函数。这些特性使得lua语言具有极大的灵活性,为程序开发带来了便利。 ... [详细]
  • 本文介绍了Python高级网络编程及TCP/IP协议簇的OSI七层模型。首先简单介绍了七层模型的各层及其封装解封装过程。然后讨论了程序开发中涉及到的网络通信内容,主要包括TCP协议、UDP协议和IPV4协议。最后还介绍了socket编程、聊天socket实现、远程执行命令、上传文件、socketserver及其源码分析等相关内容。 ... [详细]
  • 关羽败走麦城时路过马超封地 马超为何没有出手救人
    对当年关羽败走麦城,恰好路过马超的封地,为啥马超不救他?很感兴趣的小伙伴们,趣历史小编带来详细的文章供大家参考。说到英雄好汉,便要提到一本名著了,没错,那就是《三国演义》。书中虽 ... [详细]
  • 本文分享了一个关于在C#中使用异步代码的问题,作者在控制台中运行时代码正常工作,但在Windows窗体中却无法正常工作。作者尝试搜索局域网上的主机,但在窗体中计数器没有减少。文章提供了相关的代码和解决思路。 ... [详细]
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • PHP设置MySQL字符集的方法及使用mysqli_set_charset函数
    本文介绍了PHP设置MySQL字符集的方法,详细介绍了使用mysqli_set_charset函数来规定与数据库服务器进行数据传送时要使用的字符集。通过示例代码演示了如何设置默认客户端字符集。 ... [详细]
  • Java序列化对象传给PHP的方法及原理解析
    本文介绍了Java序列化对象传给PHP的方法及原理,包括Java对象传递的方式、序列化的方式、PHP中的序列化用法介绍、Java是否能反序列化PHP的数据、Java序列化的原理以及解决Java序列化中的问题。同时还解释了序列化的概念和作用,以及代码执行序列化所需要的权限。最后指出,序列化会将对象实例的所有字段都进行序列化,使得数据能够被表示为实例的序列化数据,但只有能够解释该格式的代码才能够确定数据的内容。 ... [详细]
  • 橱窗设计的表现手法及其应用
    本文介绍了橱窗设计的表现手法,包括直接展示、寓意与联想、夸张与幽默等。通过对商品的折、拉、叠、挂、堆等陈列技巧,橱窗设计能够充分展现商品的形态、质地、色彩、样式等特性。同时,寓意与联想可以通过象形形式或抽象几何道具来唤起消费者的联想与共鸣,创造出强烈的时代气息和视觉空间。合理的夸张和贴切的幽默能够明显夸大商品的美的因素,给人以新颖奇特的心理感受,引起人们的笑声和思考。通过这些表现手法,橱窗设计能够有效地传达商品的个性内涵,吸引消费者的注意力。 ... [详细]
  • HDU 2372 El Dorado(DP)的最长上升子序列长度求解方法
    本文介绍了解决HDU 2372 El Dorado问题的一种动态规划方法,通过循环k的方式求解最长上升子序列的长度。具体实现过程包括初始化dp数组、读取数列、计算最长上升子序列长度等步骤。 ... [详细]
  • faceu激萌变老特效的使用方法详解
    本文介绍了faceu激萌变老特效的使用方法,包括打开faceu激萌app、点击贴纸、选择热门贴纸中的变老特效,然后对准人脸进行拍摄,即可给照片添加变老特效。操作简单,适合新用户使用。 ... [详细]
  • Android中高级面试必知必会,积累总结
    本文介绍了Android中高级面试的必知必会内容,并总结了相关经验。文章指出,如今的Android市场对开发人员的要求更高,需要更专业的人才。同时,文章还给出了针对Android岗位的职责和要求,并提供了简历突出的建议。 ... [详细]
  • 大连微软技术社区举办《.net core始于足下》活动,获得微软赛百味和易迪斯的赞助
    九月十五日,大连微软技术社区举办了《.net core始于足下》活动,共有51人报名参加,实际到场人数为43人,还有一位专程从北京赶来的同学。活动得到了微软赛百味和易迪斯的赞助,场地也由易迪斯提供。活动中大家积极交流,取得了非常成功的效果。 ... [详细]
  • 给定一个二叉树,要求随机选择树上的一个节点。解法:遍历树的过程中,随机选择一个节点即可。具体做法参看:从输入 ... [详细]
  • 本文讨论了Alink回归预测的不完善问题,指出目前主要针对Python做案例,对其他语言支持不足。同时介绍了pom.xml文件的基本结构和使用方法,以及Maven的相关知识。最后,对Alink回归预测的未来发展提出了期待。 ... [详细]
  • 本文介绍了在微店中如何修改分销产品的价格以及设置价格的方法。客户在拍下商品后,在1小时内可以进行修改价格的操作,通过进入订单管理,点击未付款子项,可以找到订单信息并进行改价操作。修改价格后,买家会收到改价后的短信通知,在微店订单中进行付款即可。 ... [详细]
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社区 版权所有