Solved

Replace NULL value with Blank space in Xquery

Posted on 2010-08-24
7
1,541 Views
Last Modified: 2013-11-11
DECLARE @xml XML
      ,@aValue VARCHAR(10)
      ,@bValue VARCHAR(10)
      ,@cValue VARCHAR(10)
      ,@dValue VARCHAR(10)
      ,@eValue VARCHAR(10)
      ,@fValue VARCHAR(10)

SET @xml =
'<Test>
      <Test1>
            <a>NA</a>
            <b>NA</b>
      </Test1>
      <Test1>
            <a>NA</a>
            <b>NA</b>
      </Test1>
      <Test1>
            <a>NA</a>
            <b>NA</b>
      </Test1>
</Test>'
                  
SELECT
      @aValue = COALESCE(NULL,'')
      ,@bValue = COALESCE(25,'')
      ,@cValue = COALESCE(NULL,'')
      ,@dValue = COALESCE(50,'')
      ,@eValue = COALESCE(NULL,'')
      ,@fValue = COALESCE(100,'')
      
SET @xml.modify('replace value of (//Test/Test1/a/text())[1]
            with sql:variable("@aValue")')            

SET @xml.modify('replace value of (//Test/Test1/b/text())[1]
            with sql:variable("@bValue")')

SET @xml.modify('replace value of (//Test/Test1/a/text())[2]
            with sql:variable("@cValue")')            

SET @xml.modify('replace value of (//Test/Test1/b/text())[2]
            with sql:variable("@dValue")')

SET @xml.modify('replace value of (//Test/Test1/a/text())[3]
            with sql:variable("@eValue")')            

SET @xml.modify('replace value of (//Test/Test1/b/text())[3]
            with sql:variable("@fValue")')

SELECT @xml

I need to replace the NULL value with empty space. But '' works as the escape character and hence NA is not replaced at node level 2 (@cValue). Please suggest.
0
Comment
Question by:sureshbabukrish
  • 4
7 Comments
 
LVL 4

Assisted Solution

by:MSSystems
MSSystems earned 100 total points
ID: 33518531
Maybe you can try this from:
http://www.w3schools.com/Xpath/xpath_functions.asp

fn:replace(string,pattern,replace) 



Returns a string that is created by replacing the given pattern with the replace argument

Example: replace("Bella Italia", "l", "*")

Result: 'Be**a Ita*ia'



Example: replace("Bella Italia", "l", "")

Result: 'Bea Itaia' 

Open in new window

0
 
LVL 58

Expert Comment

by:cyberkiwi
ID: 33518594
Because you are running it sequentially, what is happening is that when it reaches

SET @xml.modify('replace value of (//Test/Test1/a/text())[2] with sql:variable("@cValue")')

a/text()[2] is actually hitting the <a id="3"> node.

By the time it gets to

 (//Test/Test1/a/text())[3] with sql:variable("@eValue")

There is no "3rd" element of a/text().
DECLARE @xml XML

      ,@aValue VARCHAR(10)

      ,@bValue VARCHAR(10)

      ,@cValue VARCHAR(10)

      ,@dValue VARCHAR(10)

      ,@eValue VARCHAR(10)

      ,@fValue VARCHAR(10)

SET @xml =

'<Test>

      <Test1>

            <a id="1">NA</a>

            <b>NA</b>

      </Test1>

      <Test1>

            <a id="2">NA</a>

            <b>NA</b>

      </Test1>

      <Test1>

            <a id="3">NA</a>

            <b>NA</b>

      </Test1>

</Test>'

                  

SELECT

      @aValue = COALESCE(NULL,'')

      ,@bValue = COALESCE(25,'')

      ,@cValue = COALESCE(NULL,'')

      ,@dValue = COALESCE(50,'')

      ,@eValue = COALESCE(NULL,'')

      ,@fValue = COALESCE(100,'')

      

SET @xml.modify('replace value of (//Test/Test1/a/text())[1] with sql:variable("@aValue")')            



SET @xml.modify('replace value of (//Test/Test1/b/text())[1] with sql:variable("@bValue")')



select 'There are only two NAs', @xml.query('(//Test/Test1/a/text())')

SET @xml.modify('replace value of (//Test/Test1/a/text())[2] with sql:variable("@cValue")')



SET @xml.modify('replace value of (//Test/Test1/b/text())[2] with sql:variable("@dValue")')



SET @xml.modify('replace value of (//Test/Test1/a/text())[3] with sql:variable("@eValue")')            



SET @xml.modify('replace value of (//Test/Test1/b/text())[3] with sql:variable("@fValue")')



SELECT @xml

Open in new window

0
 
LVL 58

Accepted Solution

by:
cyberkiwi earned 400 total points
ID: 33518620
This targetting is more accurate
DECLARE @xml XML

      ,@aValue VARCHAR(10)

      ,@bValue VARCHAR(10)

      ,@cValue VARCHAR(10)

      ,@dValue VARCHAR(10)

      ,@eValue VARCHAR(10)

      ,@fValue VARCHAR(10)

SET @xml =

'<Test>

      <Test1>

            <a id="1">NA</a>

            <b>NA</b>

      </Test1>

      <Test1>

            <a id="2">NA</a>

            <b>NA</b>

      </Test1>

      <Test1>

            <a id="3">NA</a>

            <b>NA</b>

      </Test1>

</Test>'

                  

SELECT

      @aValue = COALESCE(NULL,'')

      ,@bValue = COALESCE(25,'')

      ,@cValue = COALESCE(NULL,'')

      ,@dValue = COALESCE(50,'')

      ,@eValue = COALESCE(NULL,'')

      ,@fValue = COALESCE(100,'')

      

SET @xml.modify('replace value of ((//Test/Test1/a)[1]/text())[1] with sql:variable("@aValue")')            



SET @xml.modify('replace value of (//Test/Test1/b/text())[1] with sql:variable("@bValue")')



SET @xml.modify('replace value of ((//Test/Test1/a)[2]/text())[1] with sql:variable("@cValue")')



SET @xml.modify('replace value of (//Test/Test1/b/text())[2] with sql:variable("@dValue")')



SET @xml.modify('replace value of ((//Test/Test1/a)[3]/text())[1] with sql:variable("@eValue")')            



SET @xml.modify('replace value of (//Test/Test1/b/text())[3] with sql:variable("@fValue")')



SELECT @xml

Open in new window

0
Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

 
LVL 58

Expert Comment

by:cyberkiwi
ID: 33632784
Solution was provided which is valid and solves the question - useful for PAQ database.
0
 
LVL 58

Expert Comment

by:cyberkiwi
ID: 33634005
http:#a33518594 describes the problem and why sequential updating won't work, especially with a path-positional based approach like XQuery XPath.

http:#a33632784 provides a solution to perform the required updates.

Split between the two.
0
 
LVL 9

Author Closing Comment

by:sureshbabukrish
ID: 33634044
the answers were  useful
0

Featured Post

Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

The Problem How to write an Xquery that works like a SQL outer join, providing placeholders for absent data on the outer side?  I give a bit more background at the end. The situation expressed as relational data Let’s work through this.  I’ve …
I was working on a PowerPoint add-in the other day and a client asked me "can you implement a feature which processes a chart when it's pasted into a slide from another deck?". It got me wondering how to hook into built-in ribbon events in Office.
I designed this idea while studying technology in the classroom.  This is a semester long project.  Students are asked to take photographs on a specific topic which they find meaningful, it can be a place or situation such as travel or homelessness.…
This is a video that shows how the OnPage alerts system integrates into ConnectWise, how a trigger is set, how a page is sent via the trigger, and how the SENT, DELIVERED, READ & REPLIED receipts get entered into the internal tab of the ConnectWise …

947 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

20 Experts available now in Live!

Get 1:1 Help Now