sql – Rails种子:如何截断DB表?

在将测试数据播种到DB表之前,我需要截断表(我需要重置主键),我试着这样做:
ActiveRecord::Base.connection.execute("TruncATE users")

但是当我从DB打印出数据时,我仍然没有看到从1计数主键.

我究竟做错了什么?

编辑:

另外,我已经尝试在终端中手动运行Postgresql数据库

truncate users

但主要数量仍然不是从1开始.

解:

在Postgres中,运行:

ALTER SEQUENCE users_id_seq RESTART WITH 1;

解决方法

MysqL中,TruncATE表;删除所有行并重置自动增量计数器.

在Postgresql中,它不会自动执行此操作.您可以使用TruncATE TABLE表RESTART IDENTITY;.

仅供记录:在sqlite中,没有TruncATE语句,相反,它是

DELETE FROM table;
DELETE FROM sqlite_sequence WHERE name='table';

相关文章

SELECT a.*,b.dp_name,c.pa_name,fm_name=(CASE WHEN a.fm_n...
if not exists(select name from syscolumns where name=&am...
select a.*,pano=a.pa_no,b.pa_name,f.dp_name,e.fw_state_n...
要在 SQL Server 2019 中设置定时自动重启,可以使用 Window...
您收到的错误消息表明数据库 'EastRiver' 的...
首先我需要查询出需要使用SQL Server Profiler跟踪的数据库标...