Как вставить массив значений в SQL Server 2005?
-
03-07-2019 - |
Вопрос
Как мне написать код SQL для INSERT (или UPDATE) массива значений (возможно с массивом имен полей или с ними обоими) без простой итерации?
Решение
Я создаю список в виде строки xml и передаю его хранимым процессам. В SQL 2005 были расширены функции XML для анализа XML и массовой вставки.
проверьте этот пост: Передача списков в SQL Server 2005 с параметрами XML
Другие советы
Простой способ объединить значения в список и передать его в sp.
В sp используйте dbo.Split udf для преобразования обратно в набор результатов (таблица).
Создать эту функцию:
CREATE FUNCTION dbo.Split(@String nvarchar(4000), @Delimiter char(1))
returns @Results TABLE (Items nvarchar(4000))
as
begin
declare @index int
declare @slice nvarchar(4000)
select @index = 1
if @String is null return
while @index != 0
begin
select @index = charindex(@Delimiter,@String)
if @index !=0
select @slice = left(@String,@index - 1)
else
select @slice = @String
insert into @Results(Items) values(@slice)
select @String = right(@String,len(@String) - @index)
if len(@String) = 0 break
end return
end
, а затем попробуйте:
select * from dbo.split('a,b,c,d,e,f,g,h,i,j,k,l', ',')
Если ваши данные уже находятся в базе данных, вы можете использовать синтаксис INSERT SELECT
. Это немного отличается от ВСТАВИТЬ ЗНАЧЕНИЯ один ...
INSERT recipient_table (field1, field2)
SELECT field1_from, field2_from
FROM donor_table
WHERE field1_from = 'condition'
Я понимаю, что вы говорите о написании хранимой процедуры для приема массива значений
В SQL Server 2005 вам потребуется использовать переменную XML
SQL 2008 добавляет поддержку табличной переменной в качестве параметров
Здесь вы можете найти хорошие примеры передачи таблицы в хранимую процедуру в виде XML и как табличная переменная (SQL Server 2008)