php中execute的用法,写操作execute

原生SQL: 写操作(execute方法)

一、TP5原生写操作是通过Query类的execute()方法来实现

学习之前,先简单回顾了写操作常识:

数据表操作包括(增加、删除、修改、查询),即大家常说的:增删改,英文缩写:CURD。

操作语句主要有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 类文件中

d963771a92522fb84cb33e3db62285e9.png

该方法功能是:执行写操作,参数有2个:

执行写操作的SQL语句字符串:$sql;

用数组方式绑定的参数:$bind。

2、Db类直接静态调用execute()方法

静态调用方式(大家先熟悉这种方式)

关于静态调用和SQL语句生成的的基本知识,我们在上一节读操作有详细介绍,这里不再重复。

实例1:在tp5_staff表中添加新员工

目前数据表tp5_staff记录如下:

84513ba7f51797f5c540aa2c7f42ba4a.png

Index.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 '

您已成功的执行了该语句

';

}

}

运行结果如下:

de49b52bd841a9d162c62bbcdebee87d.png

为防止SQL注入,推荐用命名占位符传参方式构造SQL语句

经过改进后的Index.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 '

您已成功的执行了该语句

';

}

}

运行效果与第一方式完全一样,这里不再截图演示了。

下面语句全部采用:命名点位符绑定参数方式

实例2:删除tp5_staff表中id大于1012的记录

Index.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 '

您已成功的执行了该语句

';

}

}

运行效果如下:

45fe284bace688ec0824fd4ab6daf753.png

实例3:更新id = 1012的记录,将姓名改为:楚云飞,部门改为市场部

Index.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 '

您已成功的执行了该语句

';

}

}

运行结果:

b96c7361eadda96cdeae5915e8d95d6b.png

请同学们课后,将所有代码亲自上机调试,不要简单的复制粘贴。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
PHP execute() 是 PDOStatement 对象的一个方法,用于执行一条准备好的 SQL 语句。 PDO(PHP Data Objects)是 PHP 的一个数据库抽象层,可以让我们使用统一的方式来访问不同类型的数据库。PDOStatement 是 PDO 一个非常重要的类,它代表了一条准备好的 SQL 语句,并提供了执行、绑定参数、获取结果等方法。 当我们使用 PDO 准备好了一条 SQL 语句后,我们可以通过调用 PDOStatement 的 execute() 方法来执行这条语句。在执行之前,我们可以通过 bindParam() 或 bindValue() 方法来绑定参数,将参数传递给 SQL 语句。执行成功后,execute() 方法会返回一个布尔值,代表执行是否成功。 下面是一个使用 PDO 执行 SQL 语句的例子: ``` // 连接数据库 $dsn = 'mysql:host=localhost;dbname=test'; $username = 'root'; $password = '123456'; $options = array(PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION); $dbh = new PDO($dsn, $username, $password, $options); // 准备 SQL 语句 $stmt = $dbh->prepare('SELECT * FROM users WHERE id = :id'); // 绑定参数 $id = 1; $stmt->bindParam(':id', $id, PDO::PARAM_INT); // 执行 SQL 语句 $stmt->execute(); // 获取结果 $result = $stmt->fetchAll(PDO::FETCH_ASSOC); print_r($result); ``` 在上面的例子,我们首先使用 PDO 连接到数据库,然后使用 prepare() 方法准备一条 SQL 语句。接着,我们使用 bindParam() 方法将参数绑定到 SQL 语句,并设置参数的类型为整数。最后,我们调用 execute() 方法执行 SQL 语句,并使用 fetchAll() 方法获取执行结果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值