Yii2 QueryBuilder 更新与加入

2023-10-16php开发问题
1

本文介绍了Yii2 QueryBuilder 更新与加入的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

我有以下原始 SQL 查询:

I have the following raw SQL query:

UPDATE `pay_audit`
JOIN `invoice_items`
ON `invoice_items`.`mdn` = `pay_audit`.`account_id` 
AND `invoice_items`.`unitprice` = `pay_audit`.`payment`
AND `invoice_items`.`producttype_name` LIKE 'PAYMENT'
AND DATE_FORMAT(`invoice_items`.`created`, '%Y-%m-%d') = '2015-02-21'
SET `pay_audit`.`invoice_item_id` = `invoice_items`.`id`
WHERE `pay_audit`.`report_date` = '2015-02-21'

日期是php中的变量$date.

The date is a variable $date in php.

如何将这个原始 SQL 查询转换"为 Yii2 QueryBuilder?

How can i "convert" this raw SQL query into Yii2 QueryBuilder?

[更新]

正如 Felipe 提到的,查询构建器是不可能的,所以我最终这样做了:

As Felipe mentioned it's not possible with query builder so i ended up doing it like followed:

    $today = date('Y-m-d');
    $sql = "";
    $sql .= "UPDATE `pay_audit` ";
    $sql .= "JOIN `invoice_items` ";
    $sql .= "ON `invoice_items`.`mdn` = `pay_audit`.`account_id` ";
    $sql .= "AND `invoice_items`.`unitprice` = `qpay_audit`.`payment` ";
    $sql .= "AND `invoice_items`.`producttype_name` LIKE 'PAYMENT' ";
    $sql .= "AND DATE_FORMAT(`invoice_items`.`created`, '%Y-%m-%d') = '$today' ";
    $sql .= "SET `pay_audit`.`invoice_item_id` = `invoice_items`.`id` ";
    $sql .= "WHERE `pay_audit`.`report_date` = '$today'";

    $command = Yii::$app->db->createCommand($sql);
    $command->execute();

推荐答案

我很害怕 Yii 2 查询生成器 仅用于选择查询.

对于更新查询,您至少有三个选项:

For update queries you have at least three options:

  • 原始 SQL:

  • Raw SQL:

Yii::$app->db->createCommand('update user set status = 1 where age > 30')->execute();

  • 带有占位符的原始 SQL(防止 SQL 注入)

  • Raw SQL with placeholders (to prevent SQL injection)

    Yii::$app->db->createCommand('update user set status = :status where age > 30')->bindValue(':status','1')->execute();
    

  • update() 方法

  • update() method

    // update user set status = 1 where age > 30
    Yii::$app->db->createCommand()->update('user', ['status' => 1], 'age > 30')->execute();
    

  • 更多信息在这里:

    • Yii DAO

    关于 SO 的另一个问题

    这篇关于Yii2 QueryBuilder 更新与加入的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

    The End

    相关推荐

    PHP实现DeepL翻译API调用
    DeepL的翻译效果还是很强大的,如果我们要用php实现DeepL翻译调用,该怎么办呢?以下是代码示例,希望能够帮到需要的朋友。 在这里需要注意,这个DeepL的账户和api申请比较难,不支持中国大陆申请,需要拥有香港或者海外信用卡才行,没账号的话,目前某宝可以...
    2025-08-20 php开发问题
    168

    PHP通过phpspreadsheet导入Excel日期数据处理方法
    PHP通过phpspreadsheet导入Excel日期,导入系统后,全部变为了4开头的几位数字,这是为什么呢?原因很简单,将Excel的时间设置问文本,我们就能看到该日期本来的数值,上图对应的数值为: 要怎么解决呢?进行数据转换就行,这里可以封装方法,或者用第三方的...
    2024-10-23 php开发问题
    287

    mediatemple - 无法使用 codeigniter 发送电子邮件
    mediatemple - can#39;t send email using codeigniter(mediatemple - 无法使用 codeigniter 发送电子邮件)...
    2024-08-23 php开发问题
    11

    Laravel Gmail 配置错误
    Laravel Gmail Configuration Error(Laravel Gmail 配置错误)...
    2024-08-23 php开发问题
    16

    将 PHPMailer 用于 SMTP 的问题
    Problem with using PHPMailer for SMTP(将 PHPMailer 用于 SMTP 的问题)...
    2024-08-23 php开发问题
    4

    关于如何在 GoDaddy 服务器中使用 PHPMailer 设置 SMTP 的问题
    Issue on how to setup SMTP using PHPMailer in GoDaddy server(关于如何在 GoDaddy 服务器中使用 PHPMailer 设置 SMTP 的问题)...
    2024-08-23 php开发问题
    17