Posteado por: toniogago | 26 abril 2013

SET IDENTITY_INSERT


Para poder hacer inserciones masivas en una tabla de SQL, si esta tabla tiene un campo de identidad (autonumérico), no nos dejará hacer el Insert.


La solución es utilizar la función SET IDENTITY_INSERT. El problema que podemos tener es que el INSERT INTO FROM necesita la lista de los campos y no vale con un * (asterisco).


Un ejemplo sería:

SET IDENTITY_INSERT intu ON

INSERT INTO intu (intustamp, nome, grupo, obs, ajuda, ehtml, inactivo, 
	ecran, showauto, showins, showalt, showdel, showact, xbase, xbaseprog, 
	intuid, tacesso, userno, usernm, acesso, tabela, pfcod, pfnm, ousrinis, 
	ousrdata, ousrhora, usrinis, usrdata, usrhora, marcada)
SELECT intustamp, nome, grupo, obs, ajuda, ehtml, inactivo, 
	ecran, showauto, showins, showalt, showdel, showact, xbase, xbaseprog, 
	intuid, tacesso, userno, usernm, acesso, tabela, pfcod, pfnm, ousrinis, 
	ousrdata, ousrhora, usrinis, usrdata, usrhora, marcada
 FROM sistemas..intu
 
SET IDENTITY_INSERT intu OFF

Al terminar de insertar no estaría de más utilizar un RESEED.

Anuncios

Responder

Introduce tus datos o haz clic en un icono para iniciar sesión:

Logo de WordPress.com

Estás comentando usando tu cuenta de WordPress.com. Cerrar sesión / Cambiar )

Imagen de Twitter

Estás comentando usando tu cuenta de Twitter. Cerrar sesión / Cambiar )

Foto de Facebook

Estás comentando usando tu cuenta de Facebook. Cerrar sesión / Cambiar )

Google+ photo

Estás comentando usando tu cuenta de Google+. Cerrar sesión / Cambiar )

Conectando a %s

Categorías

A %d blogueros les gusta esto: