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

django orm

  •  
  •   kingofvir · 2019-01-24 18:11:23 +08:00 · 2535 次点击
    这是一个创建于 2155 天前的主题,其中的信息可能已经有所发展或是发生改变。

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

    5 条回复    2019-02-17 22:15:00 +08:00
    kingofvir
        1
    kingofvir  
    OP
       2019-01-24 18:16:12 +08:00
    有 model A,model B,A.b = ForeignKey(B), 如优雅地设置 A.author = A.b.name.
    kingofvir
        2
    kingofvir  
    OP
       2019-01-25 09:24:08 +08:00
    自顶
    mayorbryant
        3
    mayorbryant  
       2019-01-25 10:07:50 +08:00
    难道 A.author = A.b.name 就不优雅了吗
    kingofvir
        4
    kingofvir  
    OP
       2019-01-28 10:05:29 +08:00
    @mayorbryant 主要是为了数据更新,这样几万条数据更新需要执行几万个 sql
    banxi1988
        5
    banxi1988  
       2019-02-17 22:15:00 +08:00
    根据我的理解给出一个使用纯 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)
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5329 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 27ms · UTC 08:04 · PVG 16:04 · LAX 00:04 · JFK 03:04
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.