【问题标题】:SQLite - No such column when column existsSQLite - 当列存在时没有这样的列
【发布时间】:2018-04-05 16:21:54
【问题描述】:

我的数据库中有一个表 (trackedinfo),其中包含以下列(通过运行 PRAGMA table_info(trackedinfo); 获得的列)

问题在于,即使sendok 列存在,但在使用该字段对数据库运行查询时,它会引发错误。

查询示例:

SELECT * FROM trackedinfo WHERE sendok IS NULL;
SELECT sendok FROM trackedinfo;

错误:

SQLITE_ERROR: SQL error or missing database (no such column: sendok)

但是,如果我运行一个选择所有字段的查询,它会给我带来关于 sendok 的信息:

这里是数据库的CREATE命令:

CREATE TABLE trackedinfo
(
    id INTEGER PRIMARY KEY,
    date_time_start TEXT,
    date_time_end TEXT,
    tracked_name TEXT,
    tracked_origin TEXT,
    tracked_maker TEXT,
    tracked_version TEXT,
    tracked_type TEXT,
    sendok TEXT,
    tracked_id TEXT
);

编辑

tracked_id 列也会发生这种情况

编辑 2

我通过执行.schema trackedinfo得到的信息

CREATE TABLE IF NOT EXISTS "trackedinfo" ("id" INTEGER PRIMARY KEY, "date_time_start" TEXT, "date_time_end" TEXT, "tracked_name" TEXT, "tracked_origin" TEXT, "tracked_maker" TEXT, "tracked_version" TEXT, "tracked_type" TEXT, "sendok " TEXT, "tracked_id " TEXT);

【问题讨论】:

    标签: sql select sqlite


    【解决方案1】:

    问题是我在列名的末尾有一个空格,通过删除这些空格解决了这个问题。

    之前:

    CREATE TABLE IF NOT EXISTS "trackedinfo" ("id" INTEGER PRIMARY KEY, "date_time_start" TEXT, "date_time_end" TEXT, "tracked_name" TEXT, "tracked_origin" TEXT, "tracked_maker" TEXT, "tracked_version" TEXT, "tracked_type" TEXT, "sendok " TEXT, "tracked_id " TEXT);
    

    之后:

    CREATE TABLE IF NOT EXISTS "trackedinfo" ("id" INTEGER PRIMARY KEY, "date_time_start" TEXT, "date_time_end" TEXT, "tracked_name" TEXT, "tracked_origin" TEXT, "tracked_maker" TEXT, "tracked_version" TEXT, "tracked_type" TEXT, "sendok" TEXT, "tracked_id" TEXT);
    

    【讨论】:

      猜你喜欢
      • 2020-11-23
      • 1970-01-01
      • 2022-01-05
      • 2020-06-02
      • 2020-08-16
      • 2017-02-09
      • 2015-09-07
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多