7

>PG バージョン 9.2のように標識を表示するにはどうすればよいですか? として表示したくありません>

postgreSQL でのクエリ

SELECT 
XPATH ('/BehaviorReportingRanges/BehaviorReportingRange/Range/text()', 
xmlparse(content 
'<BehaviorReportingRanges> 
  <BehaviorReportingRange> 
   <Range>> 3</Range> 
  </BehaviorReportingRange> 
</BehaviorReportingRanges>')) 

バージョン 9.1 での結果:

{"> 3"} -- desired result 

バージョン 9.2.3 になります。

"{"&gt; 3"}" -- not desired result 

何かポインタをください?

どうもありがとう !

4

1 に答える 1

3

さて、あなたなら CREATE LANGUAGE plpythonu;、次のことができます:

create or replace function unescape(x varchar)
    returns varchar language plpythonu as $$
from xml.sax.saxutils import unescape
return unescape(x)
$$;

次に、クエリは次のようになります。

SELECT unescape( concat( (
XPATH ('/BehaviorReportingRanges/BehaviorReportingRange/Range/text()', 
xmlparse(content 
'<BehaviorReportingRanges> 
  <BehaviorReportingRange> 
   <Range>> 3</Range> 
  </BehaviorReportingRange> 
</BehaviorReportingRanges>')) )[1]
 ) );

xpathの配列結果から要素を選択するためにインデックスを追加する必要があり、concatはxmlからstringデータ型に変換することです。

unescape 関数を直接適用することもできますが、結果の文字列はフォーマットされた xml 配列になります。

于 2013-05-30T02:26:22.073 に答える