ThinkPHP中简单的CURD操作
前言
我们通过一个简答例子来简述CURD的操作。首先看一下数据库的样子,其中id为自增行,其它是varchar
一、查询操作
首先,创建在Controller文件夹下创建一个User控制器,在该控制器下写我们的查询实现方法。
<?php
namespace Home\Controller;
use Think\Controller;
class UserController extends Controller {
public function index(){
$user = M('User');
$result = $user->select();
$this->assign('data', $result);
$this->display();
}
}
在index方法中我们创建了一个Model,这个Model返回的是数据库的User表。在该表上我们调用select()方法来返回表中所有的数据。数据以数组的方式进行存储的。然后把数组传递给视图,在视图中我们显示出这个表的内容。
<!DOCTYPE html>
<html>
<head>
<title>用户表</title>
</head>
<style type="text/css">
table{
border: 1px solid #DCDCDC;
}
table td{
border: 1px solid #DCDCDC;
}
</style>
<body>
<table style="margin: 0 auto;">
<thead>
<tr>
<td>id</td>
<td>用户名</td>
<td>用户密码</td>
</tr>
</thead>
<tbody>
<volist name="data" id="row">
<tr>
<td>{$row.id}</td>
<td>{$row.username}</td>
<td>{$row.userpwd}</td>
</tr>
</volist>
</tbody>
</table>
</body>
</html>
二、删除操作
在控制器中添加删除方法,通过前台返回的id将数据从数据库中删除
<?php
namespace Home\Controller;
use Think\Controller;
class UserController extends Controller {
public function index(){
$user = M('User');
$result = $user->select();
$this->assign('data', $result);
$this->display();
} public function del()
{
$user = M('User');
$id = $_GET['id'];
$count = $user->delete($id);
if($count > 0){
$this->success("数据删除成功");
}else{
$this->error("数据删除失败!");
}
}
}
三、修改操作
public function modify(){
$user = M('User');
$id = $_GET['id'];
$result = $user->find($id);
$this->assign('data', $result);
$this->display();
}
这里直接给出方法,modify的作用就是用户点击了修改按钮后,直接跳转到修改页面。并在修改页面显示出用户需要修改的内容。
- index视图
<!DOCTYPE html>
<html>
<head>
<title>用户表</title>
</head>
<style type="text/css">
table{
border: 1px solid #DCDCDC;
}
table td{
border: 1px solid #DCDCDC;
}
</style>
<body>
<table style="margin: 0 auto;">
<thead>
<tr>
<td>id</td>
<td>用户名</td>
<td>用户密码</td>
<td>操作</td>
</tr>
</thead>
<tbody>
<volist name="data" id="row">
<tr>
<td>{$row.id}</td>
<td>{$row.username}</td>
<td>{$row.userpwd}</td>
<td>
<a href="/CloudCrypt/index.php/Home/User/del?id={$row.id}">删除</a>|
<a href="/CloudCrypt/index.php/Home/User/modify?id={$row.id}">修改</a>
</td>
</tr>
</volist>
</tbody>
</table>
<div style="margin: 0 auto;">
<button type="button" onclick="jump();">添加用户</button>
</div>
</body>
</html>
- modify视图
<!DOCTYPE html>
<html>
<head>
<title>修改</title>
</head>
<body>
<form action="/CloudCrypt/index.php/Home/User/update" method="post">
用户名:<input type="text" value="{$data.username}" name="username"><br>
密 码:<input type="text" name="userpwd" value="{$data.userpwd}"><br>
<input type="hidden" name="id" value="{$data.id}">
<button type="submit">提交</button>
</form>
</body>
</html>
四、添加操作
在添加操作中,直接给出所有的代码
- UserContoller.class.php
<?php
namespace Home\Controller;
use Think\Controller;
class UserController extends Controller {
public function index(){
$user = M('User');
$result = $user->select();
$this->assign('data', $result);
$this->display();
} public function del()
{
$user = M('User');
$id = $_GET['id'];
$count = $user->delete($id);
if($count > 0){
$this->success("数据删除成功");
}else{
$this->error("数据删除失败!");
}
} public function modify(){
$user = M('User');
$id = $_GET['id'];
$result = $user->find($id);
$this->assign('data', $result);
$this->display();
} public function update(){
$data['id']=$_POST['id'];
$data['username'] = $_POST['username'];
$data['userpwd'] = $_POST['userpwd'];
$user = M('User');
$count=$user->save($data);
if($count>0){
$this->success('数据修改成功','index');
}else{
$this->error("数据修改失败!");
}
} public function add(){
$this->display();
} public function create(){
$user = M('User');
$user->username = $_POST['username'];
$user->userpwd = $_POST['userpwd'];
$idNum = $user->add();
if($idNum > 0){
$this->success("数据添加成功", 'index');
}else{
$this->error('数据添加失败', 'index');
}
}
}
- 视图层
- index.html
<!DOCTYPE html>
<html>
<head>
<title>用户表</title>
</head>
<style type="text/css">
table{
border: 1px solid #DCDCDC;
}
table td{
border: 1px solid #DCDCDC;
}
</style>
<body>
<table style="margin: 0 auto;">
<thead>
<tr>
<td>id</td>
<td>用户名</td>
<td>用户密码</td>
<td>操作</td>
</tr>
</thead>
<tbody>
<volist name="data" id="row">
<tr>
<td>{$row.id}</td>
<td>{$row.username}</td>
<td>{$row.userpwd}</td>
<td>
<a href="/CloudCrypt/index.php/Home/User/del?id={$row.id}">删除</a>|
<a href="/CloudCrypt/index.php/Home/User/modify?id={$row.id}">修改</a>
</td>
</tr>
</volist>
</tbody>
</table>
<div style="margin: 0 auto;">
<button type="button" onclick="jump();">添加用户</button>
</div>
<script type="text/javascript">
function jump () {
alert('dd');
window.location = "/CloudCrypt/index.php/Home/User/add";
}
</script>
</body>
</html>
- add.html
<!DOCTYPE html>
<html>
<head>
<title>用户表</title>
</head>
<style type="text/css">
table{
border: 1px solid #DCDCDC;
}
table td{
border: 1px solid #DCDCDC;
}
</style>
<body>
<table style="margin: 0 auto;">
<thead>
<tr>
<td>id</td>
<td>用户名</td>
<td>用户密码</td>
<td>操作</td>
</tr>
</thead>
<tbody>
<volist name="data" id="row">
<tr>
<td>{$row.id}</td>
<td>{$row.username}</td>
<td>{$row.userpwd}</td>
<td>
<a href="/CloudCrypt/index.php/Home/User/del?id={$row.id}">删除</a>|
<a href="/CloudCrypt/index.php/Home/User/modify?id={$row.id}">修改</a>
</td>
</tr>
</volist>
</tbody>
</table>
<div style="margin: 0 auto;">
<button type="button" onclick="jump();">添加用户</button>
</div>
<script type="text/javascript">
function jump () {
alert('dd');
window.location = "/CloudCrypt/index.php/Home/User/add";
}
</script>
</body>
</html>
ThinkPHP中简单的CURD操作的更多相关文章
- Laravel框架中的数据库CURD操作、连贯操作、链式操作的用法
Laravel是一套简洁.优雅的PHP Web开发框架(PHP Web Framework).它可以让你从面条一样杂乱的代码中解脱出来:它可以帮你构建一个完美的网络APP,而且每行代码都可以简洁.富于 ...
- berkerly db 中简单的读写操作(有一些C的 还有一些C++的)
最近在倒腾BDB,才发现自己确实在C++这一块能力很弱,看了一天的api文档,总算是把BDB的一些api之间的关系理清了,希望初学者要理清数据库基本知识中的环境,句柄,游标的基本概念,这样有助于你更好 ...
- thinkphp对mysql的CURD操作
利用thinkphp(3.2.3)来操作数据库,首先要连接数据库.我们需要对某数据库写一个配置文件,thinkphp会根据该配置文件自动连接上数据库.而model文件就不用自定义,内置的即可解决问题. ...
- 使用PHP操作SQL 完成简单的CURD操作
1.从数据库出发,先建立测试数据,这里使用的MYSQL,通过脚本模式创建测试数据. SET NAMES UTF8; DROP DATABASE IF EXISTS disk; CREATE DATAB ...
- thinkphp中的内置操作数据库与mysql中的函数汇总
8.4.4 Model类getModelName() 获取当前Model的名称getTableName() 获取当前Model的数据表名称switchModel(type,vars=array()) ...
- C#中简单的文件操作实例
using System; using System.IO; namespace Demo { class Program { static string tmpPath = @"D:/Lg ...
- thinkphp中简单的控制器使用
1.在路由(route.php)中定义一条路由 Route::rule('new/:name/:id','index/News/read'); 2.在index下的controller控制器中新建一个 ...
- EF简单的CURD操作
/// <summary> /// EF添加数据 /// </summary> /// <param name="sender"></pa ...
- ThinkPHP 中M方法和D方法详解----转载
转载的地址,http://blog.163.com/litianyichuanqi@126/blog/static/115979441201223043452383/ 自己学到这里的时候,不能清除的分 ...
随机推荐
- apache性能测试工具ab使用详解
下面我们对这些参数,进行相关说明.如下:-n在测试会话中所执行的请求个数.默认时,仅执行一个请求.-c一次产生的请求个数.默认是一次一个.-t测试所进行的最大秒数.其内部隐含值是-n 50000,它可 ...
- Reading WebSites
oracle http://www.eygle.com/archives/2006/02/the_sun_repays_industriously.html 蕃茄土豆: https://pomotod ...
- 【温故而知新-CSS】使用CSS设计网站导航栏
body #nav li a { width: auto; } #nav li a:hover { background-color: #ffcc00; color: #fff; border-rig ...
- fullpage.js 结合固定导航栏—实现定位导航栏
开始制作自己的个人简历啦,决定要使用固定导航栏,又打算使用fullpage.js做全屏滚动. 仔细看了fullpage文档之后,发现不用额外写js代码就可以实现以下效果: 1.当滚动翻页时,导航栏也自 ...
- MySQL数据库学习笔记(四)----MySQL聚合函数、控制流程函数(含navicat软件的介绍)
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...
- Android开发配置,消除SDK更新时的“https://dl-ssl.google.com refused”异常
消除SDK更新时的“https://dl-ssl.google.com refused”错误 消除SDK更新时,有可能会出现这样的错误:Download interrupted: hostname i ...
- C#中treeview的问题,如何区分根节点和子节点以及根节点和根节点的兄弟节点?
根节点的Level属性为0,一级子节点Level属性为1,二级子节点Level属性为2,以此类推:同级节点可以用索引.名称.文本来区分.用索引区分根节点时,TreeView.Nodes[0]就是第一个 ...
- cotangent Laplacian
几何网格处理经常用到 cotangent laplacian矩阵.前几天把这个功能整合到我的Maya 转 Matlab插件了. 这里发一个利用cotangent laplacian计算特征向量并显示的 ...
- 1445 送Q币
1445 送Q币 时间限制: 1 s 空间限制: 1000 KB 题目等级 : 钻石 Diamond 题解 查看运行结果 题目描述 Description 一次在玩网络游戏的过程中,在 ...
- Kakfa分布式集群搭建
本位以最新版本kafka_2.11-0.10.1.0版本讲述分布式kafka集群环境的搭建过程.服务器列表: 172.31.10.1 172.31.10.2 172.31.10.3 1.下载kafka ...