【问题标题】:Update a row with a specific id更新具有特定 id 的行
【发布时间】:2018-02-28 16:11:35
【问题描述】:

id 是我的 Sqlite 表的第一列。

row 是具有更新内容的列表或元组,其列的顺序与数据库中的顺序相同。

如何执行更新命令:

c.execute('update mytable set * = ? where id = ?', row)

不对所有列名进行硬编码?(我正处于原型设计阶段,这经常会发生变化,这就是我现在不想硬编码列名的原因)。 p>

  • 显然* = ? 可能不正确,如何修改?

  • 另外,where id = ?在查询的末尾应该期望id作为row最后一个元素row 的第一个元素(因为,row 元素仍然使用与数据库本身相同的列顺序,而id 是第一列)。

【问题讨论】:

    标签: python sql sqlite sql-update


    【解决方案1】:

    您可以使用 table_info PRAGMA 提取列名。这将按顺序排列列名。然后,您可以分部分构建语句,最后将它们组合起来。

    例如对于用 :-

    定义的表
    CREATE TABLE "DATA" ("idx" TEXT,"status" INTEGER,"unit_val" TEXT DEFAULT (null) );
    

    然后

    PRAGMA table_info (data);
    

    返回:-

    即您要提取名称列。

    您可能感兴趣 - PRAGMA Statements

    另一种方法是从 sqlite_master 中提取 create sql。但是,这需要更复杂的代码来提取列名。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2021-06-11
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2022-01-04
      相关资源
      最近更新 更多