如何在 OPENROW SET 中添加动态 URL
How to add a dynamic URL inside an OPENROW SET
我的文档 table 中有一组数据行,此 table 中的每一行都有一个唯一的列 AbsoluteUri(托管在 Azure 容器中)。我想要做的是在 OPENROWSET 的 BULK 中添加一个动态 url 以实现我的目标,即存储响应 (VARBINARY(MAX))。当我尝试将静态单个 qoute 放入 BULK 时,它可以工作,但是当我尝试通过添加来自 TDM.AbsoluteUri 的数据使其动态时,它会抛出一些语法无效的错误。下面是我试过的
SELECT TR.Id AS TransactionID, TDM.Id AS DocumentID,
(SELECT *
FROM OPENROWSET
(
BULK TDM.AbsoluteUri,
DATA_SOURCE = 'DocumentsUri',
SINGLE_BLOB
) AS blob),
FROM [dbo].[Transaction] AS TR
LEFT JOIN [dbo].[Documents] AS TDM ON TR.Id = TDM.TransactionId
预期的结果应该是从 DocumentsUri 到一个 VARBINARY(MAX) 数据。
文件名必须是字符串文字,表示动态SQL和游标。 EG
declare @images table(name varchar(200), filename varchar(200))
insert into @images (name, filename) values ('Hammer','public/Hammer.jpg')
insert into @images (name, filename) values ('Screwdriver','public/screwdriver.jpg')
declare @localImages table(name varchar(200), image varbinary(max))
declare @name varchar(200), @filename varchar(200)
declare c cursor local for
select * from @images
open c
fetch next from c into @name, @filename
while @@FETCH_STATUS = 0
begin
declare @sql nvarchar(max) = concat(N'
SELECT ''',@name,''' name, BulkColumn Image
FROM OPENROWSET
(
BULK ''',@filename, ''',
DATA_SOURCE = ''BlobStore'',
SINGLE_BLOB
) AS blob;
');
print @sql
insert into @localImages(name,image)
exec (@sql)
fetch next from c into @name, @filename
end
select *
from @localImages
我的文档 table 中有一组数据行,此 table 中的每一行都有一个唯一的列 AbsoluteUri(托管在 Azure 容器中)。我想要做的是在 OPENROWSET 的 BULK 中添加一个动态 url 以实现我的目标,即存储响应 (VARBINARY(MAX))。当我尝试将静态单个 qoute 放入 BULK 时,它可以工作,但是当我尝试通过添加来自 TDM.AbsoluteUri 的数据使其动态时,它会抛出一些语法无效的错误。下面是我试过的
SELECT TR.Id AS TransactionID, TDM.Id AS DocumentID,
(SELECT *
FROM OPENROWSET
(
BULK TDM.AbsoluteUri,
DATA_SOURCE = 'DocumentsUri',
SINGLE_BLOB
) AS blob),
FROM [dbo].[Transaction] AS TR
LEFT JOIN [dbo].[Documents] AS TDM ON TR.Id = TDM.TransactionId
预期的结果应该是从 DocumentsUri 到一个 VARBINARY(MAX) 数据。
文件名必须是字符串文字,表示动态SQL和游标。 EG
declare @images table(name varchar(200), filename varchar(200))
insert into @images (name, filename) values ('Hammer','public/Hammer.jpg')
insert into @images (name, filename) values ('Screwdriver','public/screwdriver.jpg')
declare @localImages table(name varchar(200), image varbinary(max))
declare @name varchar(200), @filename varchar(200)
declare c cursor local for
select * from @images
open c
fetch next from c into @name, @filename
while @@FETCH_STATUS = 0
begin
declare @sql nvarchar(max) = concat(N'
SELECT ''',@name,''' name, BulkColumn Image
FROM OPENROWSET
(
BULK ''',@filename, ''',
DATA_SOURCE = ''BlobStore'',
SINGLE_BLOB
) AS blob;
');
print @sql
insert into @localImages(name,image)
exec (@sql)
fetch next from c into @name, @filename
end
select *
from @localImages