May 5, 2008 at 4:10 pm
Hi everyone,
I have a task in which we get feed files in form of xml files and we have to investigate them for bugs. So, I created a sql server table XMLImportTest and inserted the file in the column xml_data.
CREATE TABLE XmlImportTest
(
xmlFileName VARCHAR(300),
xml_data xml
)
GO
DECLARE @xmlFileName VARCHAR(300)
SELECT @xmlFileName = 'C:\\XMLFiles\stats.xml'
EXEC('
INSERT INTO XmlImportTest(xmlFileName, xml_data)
SELECT ''' + @xmlFileName + ''', xmlData
FROM
(
SELECT *
FROM OPENROWSET (BULK ''' + @xmlFileName + ''' , SINGLE_BLOB) AS XMLDATA
) AS FileImport (XMLDATA)
')
GO
Now, I have to query this data for some specific string values.
select xml_data.query('for $so in //indicator
where $so/canonicalIndicator = "power use"
or $so/displayIndicator = "power use"
or $so/alt = "power use"
return $so')
from dbo.XmlImportTest
For a file of size 478,601 KB, this query took 7:33 min to execute. Why is this query so slow? Is there anyway to get results faster?
Also when I execute
select * from dbo.XmlImportTest
I get an error
βAn error occurred while executing batch. Error message is: Exception of type 'System.OutOfMemoryException' was thrown.β
My machine is running Windows xp professional SP2 and has 2 GB of RAM.
Please let me know, what the problem is. Also, for the above type of task, is there a better way to perform it?
Thanks in advance.
May 5, 2008 at 4:44 pm
Please don't cross post. Answered here: http://www.sqlservercentral.com/Forums/Topic495330-338-1.aspx
May 6, 2008 at 8:54 am
I do not see any answer to my question at http://www.sqlservercentral.com/Forums/Topic495330-338-1.aspx.
Any help would be greatly appreciated.
Thanks
Viewing 3 posts - 1 through 2 (of 2 total)
You must be logged in to reply to this topic. Login to reply