在将测试数据播种到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';