无法创建唯一的部分索引 - Sqlite3

时间:2016-01-14 09:13:10

标签: indexing sqlite unique-index

请考虑下表。

CREATE TABLE IF NOT EXISTS wsfiles
(
  id INTEGER PRIMARY KEY AUTOINCREMENT,
  website_id integer NOT NULL,
  parent_id integer,
  archive_id integer,
  path character varying,
  path_sha character varying NOT NULL,
  target character varying,
  name character varying NOT NULL,
  is_directory boolean
  CONSTRAINT uniq_file_website_backup UNIQUE (archive_id, path_sha) ON CONFLICT REPLACE
);

我需要创建以下唯一的部分索引。

CREATE UNIQUE INDEX IF NOT EXISTS idx_unique_directory ON wsfiles(path_sha) WHERE is_directory = 1;

但是在执行上面的模式时,我在CREATE UNIQUE INDEX查询中的WHERE子句附近遇到语法错误。这在我的本地机器上运行良好,当我在生产机器上执行时出现问题。

Error: near line 98: near "WHERE": syntax error

生产机器sqlite3版本是3.7.17

本地机器sqlite3版本是3.8.5

1 个答案:

答案 0 :(得分:1)

documentation说:

  

自版本3.8.0起,SQLite支持部分索引。