当前位置: 首页 > 面试题库 >

SQLite重置主键字段

慕朝明
2023-03-14
问题内容

我在SQLite中有一些表,我试图弄清楚如何重设自动递增的数据库字段。

我读到DELETE FROM tablename应该删除所有内容,并将auto-incrementment字段重置为0,但是这样做时,它只会删除数据。插入新记录后,自动增量将从删除前的中断处开始提取。

我的ident字段属性如下:

  • 栏位类型:integer
  • 字段标志:PRIMARY KEY,AUTOINCREMENT,UNIQUE
  • 我在SQLite Maestro中建立表并在SQLite Maestro中执行DELETE语句也有关系吗?

任何帮助将是巨大的。


问题答案:

试试这个:

delete from your_table;    
delete from sqlite_sequence where name='your_table';

SQLite自动增量

SQLite使用特殊SQLITE_SEQUENCE表跟踪表曾经拥有的最大ROWID 。SQLITE_SEQUENCE每当创建包含AUTOINCREMENT列的普通表时,都会自动创建并初始化该 表。可以使用普通的UPDATE,INSERT和DELETE语句修改SQLITE_SEQUENCE表的内容。但是对此表进行修改可能会干扰AUTOINCREMENT密钥生成算法。进行此类更改之前,请确保您知道自己在做什么。



 类似资料:
  • 问题内容: 创建一个名为“ sqlite_autoindex_mytable_1”的索引。我在“ SQlite Expert”中看到了它。在“要索引的字段”框中,它同时显示col1和col2。 在这篇文章中:https : //dba.stackexchange.com/a/14260 它说如果我想在没有col1的JOIN查询中使用col2,则必须为col2创建单独的索引。 因此,我需要添加: 如

  • 主要内容:语法,实例SQLite 的 DISTINCT 关键字与 SELECT 语句一起使用,来消除所有重复的记录,并只获取唯一一次记录。 有可能出现一种情况,在一个表中有多个重复的记录。当提取这样的记录时,DISTINCT 关键字就显得特别有意义,它只获取唯一一次记录,而不是获取重复记录。 语法 用于消除重复记录的 DISTINCT 关键字的基本语法如下: 实例 假设 COMPANY 表有以下记录: 首先,让我们来

  • 问题内容: 在我的桌子上,我有100条记录。然后,我删除了所有记录,现在我想重新开始输入数据,我看到我的主键不是从1开始,而是从101开始, 有什么办法可以重置主键? 我正在使用MySQL管理员帐户。 问题答案:

  • 问题内容: 我正在尝试学习Hibernate的工作方式,并且几乎陷入了无法接受的学习曲线。我看不到如何使Hibernate尊重我的对象的auto_increment策略。而是使用现有ID(从1开始)覆盖数据库中的条目。 我有一个简单的对象,由定义如下的MySQL表支持: 我已经确认使用SQL()手动插入多个Foo对象是正确的。 我的Java类具有使用如下注释来指定的ID: 然后,我执行一些测试代码

  • 问题内容: 我有一个带有自动递增主键的MySQL表。我删除了表中间的一些行。例如,现在在ID列中有类似的内容:12、13、14、19、20。我删除了15、16、17和18行。 我想重新分配/重置/重新排序主键,以便保持连续性,即将19设为15,将20设为16,依此类推。 我该怎么做? 问题答案: 您可以删除主键列并重新创建它。然后应按顺序重新分配所有ID。 但是,在大多数情况下,这可能不是一个好主

  • 问题内容: MySQL有这样的东西: 据我所知,SQLite中不存在此功能,我想知道的是,是否有任何方法可以实现相同的效果而不必执行两个查询。另外,如果这不可能,那么您更喜欢什么: SELECT +(插入或更新) 或 UPDATE( 如果UPDATE失败,则 + INSERT ) 问题答案: 由于3.24.0 SQLite还支持upsert ,因此现在您可以简单地编写以下内容