首页   注册   登录
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX  ›  Django

django orm

  •  
  •   kingofvir · 90 天前 · 549 次点击
    这是一个创建于 90 天前的主题,其中的信息可能已经有所发展或是发生改变。

    django orm 更新 model 某个字段为该 model 中某个外键 mode 字段的值。

    5 回复  |  直到 2019-02-17 22:15:00 +08:00
        1
    kingofvir   90 天前
    有 model A,model B,A.b = ForeignKey(B), 如优雅地设置 A.author = A.b.name.
        2
    kingofvir   90 天前
    自顶
        3
    mayorbryant   90 天前
    难道 A.author = A.b.name 就不优雅了吗
        4
    kingofvir   87 天前
    @mayorbryant 主要是为了数据更新,这样几万条数据更新需要执行几万个 sql
        5
    banxi1988   66 天前
    根据我的理解给出一个使用纯 SQL 的解法,你可以自行翻译成 Django ORM 的写法
    针对如下表结构:

    ```sql
    CREATE TABLE `author` (
    `id` INTEGER,
    `name` TEXT,
    PRIMARY KEY(`id`)
    );


    CREATE TABLE `book` (
    `id` INTEGER,
    `name` TEXT NOT NULL,
    `author_id` INTEGER,
    `author_name` TEXT,
    PRIMARY KEY(`id`)
    );

    ````

    `book.author_name` 是后面加的,要填充其关联的 author 的名称可以使用如下 SQL 语句更新。

    ```sql
    update book set author_name = (select name from author where id = author_id)
    ```
    经过我使用 SQLite 测试是 OK 的。
    > Query executed successfully: update book set author_name = (select name from author where id = author_id) (took 0ms, 3 rows affected)
    关于   ·   FAQ   ·   API   ·   我们的愿景   ·   广告投放   ·   感谢   ·   实用小工具   ·   4262 人在线   最高记录 5043   ·  
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.3 · 18ms · UTC 02:11 · PVG 10:11 · LAX 19:11 · JFK 22:11
    ♥ Do have faith in what you're doing.
    沪ICP备16043287号-1