如何查看SQLite索引是否唯一? (使用SQL)

我想通过SQL查询了解索引是否为UNIQUE.我正在使用SQLite 3.

 

我试过两种方法:

 

SELECT * FROM sqlite_master WHERE name = 'sqlite_autoindex_user_1'

这将返回有关索引的信息(“type”,“name”,“tbl_name”,“rootpage”和“sql”).请注意,当SQLite自动创建索引时,sql列为空.

 

PRAGMA index_info(sqlite_autoindex_user_1);

这将返回索引中的列(“seqno”,“cid”和“name”).

任何其他建议?

编辑:上面的例子是一个自动生成的索引,但是我的问题是一般的索引.例如,我可以使用“CREATE UNIQUE INDEX index1 ON visit(user,date)”创建一个索引.如果我的新索引是UNIQUE,似乎没有显示SQL命令.

PRAGMA INDEX_LIST('table_name');

返回一个包含3列的表:

> seq索引的唯一数字ID
> name索引的名称
>唯一的唯一性标志(非零,如果UNIQUE索引.)

然后,循环遍历结果行,直到看到要查询的索引的名称(不幸的是,在PRAGMA语句中不能有WHERE子句).

posted @   胡鹏飞  阅读(382)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
点击右上角即可分享
微信分享提示