query and compare values in a text based column

  • HI There,

    as the heading suggests I am trying to query a text based audit for specific values then compare them values. For example the column should contain and new_ref_no and old_ref_no in the straing. I want to query for those and then compare them to see if they are in fact different. However I am not sure how I would go about doing this.

    any ideas would be greatly appreciated.

    Thanks

  • niall5098 (10/7/2016)


    HI There,

    as the heading suggests I am trying to query a text based audit for specific values then compare them values. For example the column should contain and new_ref_no and old_ref_no in the straing. I want to query for those and then compare them to see if they are in fact different. However I am not sure how I would go about doing this.

    any ideas would be greatly appreciated.

    Thanks

    Please provide some anonymised example data, to help us understand what you are trying to do.

    The absence of evidence is not evidence of absence.
    Martin Rees

    You can lead a horse to water, but a pencil must be lead.
    Stan Laurel

  • The easiest way is to simply put wild card values around the string you're looking for and use LIKE:

    ...WHERE a.Col LIKE '%new_ref_no%' AND a.Col LIKE '%old_ref_no%';

    Performance will be horrible with this, but you can quickly confirm the existence of these two values if that's what you're looking for. It's an odd use case though. Can you detail more what it is that you're attempting to do?

    "The credit belongs to the man who is actually in the arena, whose face is marred by dust and sweat and blood"
    - Theodore Roosevelt

    Author of:
    SQL Server Execution Plans
    SQL Server Query Performance Tuning

  • thanks for the reply.

    the column contain a string of data. within that string I will see the following entries:

    <new_pmetd_refno>4110</new_pmetd_refno>

    <old_rfeco_refno></old_rfeco_refno>

    so I want to do is bring back any rows that contain these values and then only show me rows where they are different.

    I hope I have explained it better this time.

    Thanks

  • niall5098 (10/7/2016)


    thanks for the reply.

    the column contain a string of data. within that string I will see the following entries:

    <new_pmetd_refno>4110</new_pmetd_refno>

    <old_rfeco_refno></old_rfeco_refno>

    so I want to do is bring back any rows that contain these values and then only show me rows where they are different.

    I hope I have explained it better this time.

    Thanks

    If this column is in XML format, there may be quicker ways of performing the check.

    The absence of evidence is not evidence of absence.
    Martin Rees

    You can lead a horse to water, but a pencil must be lead.
    Stan Laurel

  • That's XML. You should be using the built-in XML functionality to shred the XML document. If you provide a more complete sample, we can help you with that.

    Drew

    J. Drew Allen
    Business Intelligence Analyst
    Philadelphia, PA

  • HI There,

    it looks like sql but is actually text

  • If it's not XML, and XML would be a lot easier here, then you'll have to use string manipulation to find the start and stop points using CHARINDEX. Then you can use SUBSTRING to pull the information out between the start & stop points. It's going to be a royal pain to write out.

    "The credit belongs to the man who is actually in the arena, whose face is marred by dust and sweat and blood"
    - Theodore Roosevelt

    Author of:
    SQL Server Execution Plans
    SQL Server Query Performance Tuning

  • thanks, unfortunately I can change the datatype.

  • niall5098 (10/7/2016)


    HI There,

    it looks like sql but is actually text

    XML, not SQL.

    XML is text, but in structured format, with start and end 'tags' around data items.

    The absence of evidence is not evidence of absence.
    Martin Rees

    You can lead a horse to water, but a pencil must be lead.
    Stan Laurel

  • The example looks like either XML or JSON. Do you know where the data is coming from? It's fine that it's stored in a VARCHAR field, but if it's XML stored there, you have additional possibilities for how you can query the data.

    "The credit belongs to the man who is actually in the arena, whose face is marred by dust and sweat and blood"
    - Theodore Roosevelt

    Author of:
    SQL Server Execution Plans
    SQL Server Query Performance Tuning

  • niall5098 (10/7/2016)


    HI There,

    it looks like sql but is actually text

    We said it was XML, not SQL, and XML IS text, but in a very specific format. Even if it's not XML, it contains XML and you can trick SQL into treating it as XML, which is going to be a lot easier than any other method. We would still need a sample of the data.

    Drew

    J. Drew Allen
    Business Intelligence Analyst
    Philadelphia, PA

  • Grant Fritchey (10/7/2016)


    The example looks like either XML or JSON. Do you know where the data is coming from? It's fine that it's stored in a VARCHAR field, but if it's XML stored there, you have additional possibilities for how you can query the data.

    JSON uses curly brackets, so I don't think that's likely. XML is the front-runner here 🙂

    The absence of evidence is not evidence of absence.
    Martin Rees

    You can lead a horse to water, but a pencil must be lead.
    Stan Laurel

  • apoligies, yes , XML . That was a type

  • Hi There,

    please see example of data below:

    <AUDITS>

    <Admin>

    </Admin>

    <provider_spells>

    <Refno>123456</Refno>

    <Action>UPDATE</Action>

    <Fields>

    <old_pmetd_refno></old_pmetd_refno>

    <new_pmetd_refno>4110</new_pmetd_refno>

    </Fields>

    </AUDITS>

Viewing 15 posts - 1 through 15 (of 25 total)

You must be logged in to reply to this topic. Login to reply