首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在Xamarin/sqlite-net-pcl Nuget pkg中重置AutoIncrement序列号

在Xamarin/sqlite-net-pcl Nuget pkg中重置AutoIncrement序列号
EN

Stack Overflow用户
提问于 2018-03-22 13:06:06
回答 1查看 424关注 0票数 1

当我清空我的表时,我还希望重置自动增量的rowid数字。我找到了几篇推荐这段代码的文章:

代码语言:javascript
复制
DeleteAll<mytable>();
Execute("update sqlite_sequence set seq = 0 where name = 'mytable';");

当我运行它时,我没有得到任何类型的错误,但是rowid没有被重置。我也尝试过:

代码语言:javascript
复制
Execute("delete from sqlite_sequence where name = 'mytable';");

..。结果是一样的。sqlite-net-pcl有没有一个怪癖让它不能工作?还是我错过了什么?

表定义如下所示:

代码语言:javascript
复制
public partial class mytable : IHasId
{
    [PrimaryKey, AutoIncrement]
    public int Id { get; set; }
    <other stuff deleted>
}

IHasId是:

代码语言:javascript
复制
public interface IHasId
{
    int Id { get; set; }
}

(别杀我,当我可以吃芝士汉堡的时候,我写了这篇文章。我当时觉得很有趣。而且,表实际上并没有命名为mytable。)

任何帮助都将不胜感激。谢谢!

EN

回答 1

Stack Overflow用户

发布于 2018-05-22 07:06:34

我找到了!我很高兴地报告这是一件愚蠢的事情。在我们的另一个(非常旧的、基于C++的)数据库应用程序中,我们的表是复数,而索引是单数。例如,"Customers“表包含具有名为"customer”的索引列的记录。因此,本着这种精神,对于我的"Customer“对象,我让数据库打开了一个名为"Custs.db3”的文件。

因为示例使用了"table“,所以我这样做:

代码语言:javascript
复制
Execute("delete from sqlite_sequence where name = 'Custs';");

我需要的是:

代码语言:javascript
复制
Execute("delete from sqlite_sequence where name = 'Customer';");

所以..。索引不是通过"table“名称存储的,它们是通过"object”类名称存储的。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/49420927

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档