## 原生SQL: 写操作(execute方法)
#### 一、TP5原生写操作是通过Query类的execute()方法来实现
#### 学习之前,先简单回顾了写操作常识:
* <span style="color:forestgreen">数据表操作包括(增加、删除、修改、查询),即大家常说的:增删改,英文缩写:CURD。</span>
* 操作语句主要有4个,他们的语法和说明:
| 序号 |名称|关键字 | 语法 | 举例 |
| --- | --- | ---|--- | --- |
| 1 | 新增 | INSERT | INSERT 表名 (字段列表) VALUES (值列表) | INSERT staff (name,salary) VALUES ('周军',4500); |
| 2 | 删除 | DELETE | DELETE FROM 表名 WHERE 条件 | DELETE FROM staff WHERE id = 1005; |
| 3| 更新 | UPDATE | UPDATE 表名 SET 字段 = 新值 WHERE 条件 | UPDATE staff SET salary = salary + 200 WHERE id = 1005; |
| 4 | 查询 | SELECT | SELECT 字段列表 FROM 表名 WHERE 条件 | SELECT name,salary FROM staff WHERE id > 1005; |
#### 前三个是写操作(即执行后,表中记录发生了变化)
#### 现在回到TP 5
* execute()方法定义在:db/Query.php 类文件中
![](https://box.kancloud.cn/f1b5db2ffe80cd13846e535e41b295f0_1220x744.png)
* 该方法功能是:执行写操作,参数有2个:
* 执行写操作的SQL语句字符串:$sql;
* 用数组方式绑定的参数:$bind。
* * * * *
#### 2、Db类直接静态调用execute()方法
* 静态调用方式(大家先熟悉这种方式)
>[info]关于静态调用和SQL语句生成的的基本知识,我们在上一节读操作有详细介绍,这里不再重复。
#### 实例1:在tp5_staff表中添加新员工
* 目前数据表tp5_staff记录如下:
![](https://box.kancloud.cn/1a71b495fb924ed5d13e69f88e60040b_493x219.png)
* Index.php 控制器代码如下:
~~~
<?php
namespace app\index\controller;
use think\Controller;
use think\Db;
class Index extends Controller {
public function index(){
//创建SQL语句字符串
$sql = "INSERT tp5_staff (name,sex,age,salary,dept,hiredate) VALUES ('李云龙',1,39,4800,'开发部','2011-09-12');";
//执行插入操作
$affected = Db::execute($sql);
//判断是否执行成功
if ($affected){
$this->success('插入成功!',url('ok'));
}else{
$this->error('插入失败');
}
}
//定义操作成功的方法
public function ok(){
echo '<h2>您已成功的执行了该语句</h2>';
}
}
~~~
* 运行结果如下:
![](https://box.kancloud.cn/7023b3744b823d0d041c508b2f6cb20a_1552x925.png)
* * * * *
#### 为防止SQL注入,推荐用命名占位符传参方式构造SQL语句
* 经过改进后的Index.php控制器代码如下:
~~~
<?php
namespace app\index\controller;
use think\Controller;
use think\Db;
class Index extends Controller {
public function index(){
//创建SQL语句字符串
$sql = "INSERT tp5_staff (name,sex,age,salary,dept,hiredate) VALUES (:name,:sex,:age,:salary,:dept,:hiredate);";
//执行插入操作
$affected = Db::execute($sql,['name'=>'李云龙','sex'=>1,'age'=>30,'salary'=>4800,'dept'=>'开发部','hiredate'=>'2011-09-12']);
//判断是否执行成功
if ($affected){
$this->success('插入成功!',url('ok'),10);
}else{
$this->error('插入失败');
}
}
//定义操作成功的方法
public function ok(){
echo '<h2>您已成功的执行了该语句</h2>';
}
}
~~~
* 运行效果与第一方式完全一样,这里不再截图演示了。
* * * * *
><font color="red"> 下面语句全部采用:命名点位符绑定参数方式</font>
#### 实例2:删除tp5_staff表中id大于1012的记录
* Index.php控制器代码如下:
~~~
<?php
namespace app\index\controller;
use think\Controller;
use think\Db;
class Index extends Controller {
public function index(){
//创建SQL语句字符串
$sql = "DELETE FROM tp5_staff WHERE id > :id;";
//执行插入操作
$affected = Db::execute($sql,['id'=>'1012']);
//判断是否执行成功
if ($affected){
//延时10秒,是为了方便截图,默认为3秒
$this->success('删除成功!',url('ok'),'',10);
}else{
$this->error('删除失败');
}
}
//定义操作成功的方法
public function ok(){
echo '<h2>您已成功的执行了该语句</h2>';
}
}
~~~
* 运行效果如下:
![](https://box.kancloud.cn/7b9be5881fce0a399468cf645a1d5f32_1552x925.png)
* * * * *
#### 实例3:更新id = 1012的记录,将姓名改为:楚云飞,部门改为市场部
* Index.php 控制器类代码:
~~~
<?php
namespace app\index\controller;
use think\Controller;
use think\Db;
class Index extends Controller {
public function index(){
//创建SQL语句字符串
$sql = "UPDATE tp5_staff SET name = :name , dept = :dept WHERE id = :id;";
//执行插入操作
$affected = Db::execute($sql,['name'=>'楚云飞','dept'=>'市场部','id'=>'1012']);
//判断是否执行成功
if ($affected){
$this->success('更新成功!',url('ok'),'',10);
}else{
$this->error('更新失败');
}
}
//定义操作成功的方法
public function ok(){
echo '<h2>您已成功的执行了该语句</h2>';
}
}
~~~
* 运行结果:
![](https://box.kancloud.cn/64eddd2c1d2f4e8f243c3c3b05541e58_1552x925.png)
* * * * *
### 请同学们课后,将所有代码亲自上机调试,不要简单的复制粘贴。
- 前言[随时更新]
- ThinkPHP 5数据库重构
- 开发环境
- 1.ThinkPHP5开发环境(Mac版)
- 2.ThinkPHP5开发环境(Win版)
- MySQL快速复习
- 1.数据库操作
- 2.数据表操作
- 1.创建数据表 (重点)
- 2.添加数据表记录
- 3.查询数据表(重点)
- 4.更新数据表
- 5.编辑数据表结构(重点)
- 6_复制数据表
- 7.删除数据和表
- 连接数据库
- 1.数据库配置文件database.php
- 2.Db类静态方法connect()
- 3.模块中的配置文件config.php
- MySQL原生查询
- 1.读操作query
- 2.写操作execute
- 选择数据表
- 1.table与setTable方法
- 2.name方法
- 3.db助手函数
- 4.alias方法
- 结果集查询
- 1.find方法
- 2.select方法
- 3.fetchSql方法
- 4.value方法
- 5.column方法
- 6.field方法
- 新增数据
- 1.insert_单条添加
- 2.insertAll_批量添加
- 3_db_助手函数添加
- 更新数据
- 1.update方法
- 2.setField更新字段
- 3_自增自减与延时更新
- 删除数据
- 1.delete方法
- 查询方法
- 1.getTableInfo方法
- 2.where方法
- 3.whereOr方法
- 4.混合查询(闭包实现)
- 表达式查询
- 1.表达式查询(重点)
- 2.exp通用查询
- 分组查询
- 1.group方法
- 2.having方法
- 排序分页查询
- 1.order方法
- 2.limit方法
- 3.page方法
- 聚合查询
- 时间查询
- 1.where方法
- 2.whereTime方法
- 高级查询
- 1.快捷查询
- 2.区间查询
- 3.批量查询
- 4.Query对象查询
- 5.混合查询
- 视图查询
- view方法
- 子查询
- 1.select方法
- 2.fetchSql方法
- 3.buildSql方法
- 4.闭包子查询
- 总结/参考
- 1.方法参数类型总结
- 2.查询/子查询/连接查询