默認情況下,IDENTITY_INSER就是off 這種情況下,你寫insert 語句時,identity欄位,不要寫值,系統會自動幫你寫入。 舉例說明:
create table #aa(id int identity(1,1),dt datetime,pay int) go insert into #aa(dt,pay)values('2012-4-12',100) --不能向 id欄位寫值,系統會自動寫 go insert into #aa(id,dt,pay)values(100,'2012-4-14',200) --如果像這樣寫了,就會報錯 go
如果你需要寫,可以把off改成on。 如:
set IDENTITY_INSERT #aa on insert into #aa(id,dt,pay)values(100,'2012-4-14',200) --這樣就不會報錯了。
實際應用,應該不會要這樣,一般設為 identity,就是要利用系統自動寫入的功能,保證不重復。
在mapper.xml的插入代碼加上
set IDENTITY_INSERT #aa on