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/ 自己学到这里的时候,不能清除的分 ...
随机推荐
- Python基础之函数等等
三元运算 三元运算(三目运算),是对简单的条件语句的缩写. 1 2 3 4 5 # 书写格式 result = 值1 if 条件 else 值2 # 如果条件成立,那么将 "值1&q ...
- Nginx启动、关闭、重新加载脚本
#! /bin/sh # Default-Start: 2 3 4 5 # Default-Stop: 0 1 6 # Short-Description: starts the nginx web ...
- Java中的流
一.Java中流的原理 流是个抽象的概念,是对输入输出设备的抽象,Java程序中,对于数据的输入/输出操作都是以“流”的方式进行.设备可以是文件,网络,内存等. 四种基本流InputStream,Ou ...
- bzoj-2338 2338: [HNOI2011]数矩形(计算几何)
题目链接: 2338: [HNOI2011]数矩形 Time Limit: 20 Sec Memory Limit: 128 MB Description Input Output 题意: 思路 ...
- POJ 2464 Brownie Points II --树状数组
题意: 有点迷.有一些点,Stan先选择某个点,经过这个点画一条竖线,Ollie选择一个经过这条直接的点画一条横线.Stan选这两条直线分成的左下和右上部分的点,Ollie选左上和右下部分的点.Sta ...
- 2014 UESTC 暑前集训队内赛(3) 部分解题报告
B.Battle for Silver 定理:完全图Kn是平面图当且仅当顶点数n<=4. 枚举所有完全图K1,K2,K3,K4,找出最大总权重. 代码: #include <iostrea ...
- Java虚拟机详解01----初识JVM
主要内容如下: JVM的概念 JVM发展历史 JVM种类 Java语言规范 JVM规范 一.JVM的概念: JVM: Java Virtual Machine,意为Java虚拟机. 虚拟机: 指通过软 ...
- poj1144
Network Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 12521 Accepted: 5760 Descript ...
- SilverIight数据绑定实例
前台Code <DataGrid Name="DataGrid1" AutoGenerateColumns="False" IsReadOnly=&quo ...
- Linux 进程与线程二(等待--分离--取消线程)
int pthread_join(pthread_t thr,void **thr_return); pthread_join函数用于挂起当前线程,直至th指定的线程终止为止. 如果另一个线程返回值不 ...