Re: Escape double-quotes in text[]?

From: David G Johnston <david(dot)g(dot)johnston(at)gmail(dot)com>
To: pgsql-general(at)postgresql(dot)org
Subject: Re: Escape double-quotes in text[]?
Date: 2014-04-30 16:32:22
Message-ID: 1398875542833-5802008.post@n5.nabble.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-general

Raymond O'Donnell wrote
> On 29/04/2014 22:54, David G Johnston wrote:
>> Raymond O'Donnell wrote
>>> Hi all,
>>>
>>> Probably a silly question, but I'm having trouble figuring out the
>>> answer... if I'm constructing an string representation of a value to go
>>> into a text[] column, and one of the text literals includes
>>> double-quotes, do I need to escape the literal?
>>>
>>> For example, can I insert something like this into a text[] column
>>> directly? -
>>>
>>> '{"abc", "de"f"}'
>>>
>>> Or would I need to do this? -
>>>
>>> E'{"abc", "de"f"}'
>>>
>>> ....or something different again? I'm doing this from PHP via the Zend
>>> framework (v.1) if it makes any difference.
>>>
>>> Thanks,
>>>
>>> Ray.
>>
>> The easy way:
>>
>> SELECT ARRAY['ab"c','de"f']::varchar[] => {"ab"c","de"f"}
>>
>> Knowing the above; reverse-engineer the literal input syntax
>>
>> SELECT {"ab"c","de"f"}::varchar[] #Nope "bare {"
>> SELECT '{"ab"c","de"f"}'::varchar[] #Nope "malformed array literal"
>> SELECT '{"ab\"c","de\"f"}'::varchar[] #Yay!
>> SELECT E'{"ab\"c","de\"f"}'::varchar[] #hmmm.....
>> SELECT E'{"ab\\"c","de\\"f"}'::varchar[] #yeah, double-escape (literal
>> first, then array)
>>
>> This is all documented but it does not seem to be centrally summarized;
>> you
>> need to check few different array-related areas to pick up the rules
>> and/or
>> capabilities (namely, use ARRAY[...] syntax if at all possible).
>
> Thanks a million David - that's very helpful.
>
> ARRAY[] doesn't work for me, unfortunately; I'm using parametrised
> queries in Zend framework, and all the parameters get put in as strings,
> so I need to build the array literals before submitting them.

SELECT regexp_split_to_array('val"1|val"2|val"3','\|');

SELECT regexp_split_to_array(?,'\|');

David J.

--
View this message in context: http://postgresql.1045698.n5.nabble.com/Escape-double-quotes-in-text-tp5801913p5802008.html
Sent from the PostgreSQL - general mailing list archive at Nabble.com.

In response to

Responses

Browse pgsql-general by date

  From Date Subject
Next Message Raymond O'Donnell 2014-04-30 16:35:12 Re: Escape double-quotes in text[]?
Previous Message bricklen 2014-04-30 16:30:11 Re: importing a messy text file