我正在尝试从 DB Oracle12g 中选择 XML。XML 存储在表中(XMLType 存储为二进制 XML),我无法使用 where 条件创建 Select 查询。我的问题是查询不返回任何记录。我正在使用 Oracle SQL Developer 4.1.0.19。
我的查询示例
SELECT OBJECT_VALUE
FROM A_STUDENT_BIN
WHERE existsNode(object_value,'//Student[@RodneCislo="123"]') = 1;
SELECT OBJECT_VALUE
FROM A_STUDENT_BIN
WHERE extract(OBJECT_VALUE, '//Student[@RodneCislo="123"]') IS NOT NULL;
表结构:
CREATE TABLE a_student_bin OF XMLTYPE XMLTYPE STORE AS BINARY XML;
插入的 XML
<?xml version="1.0" encoding="windows-1250" ?>
<Vystup>
<Student RodneCislo="123">
<Jmeno>Pepa</Jmeno>
<Prijmeni>Omacka</Prijmeni>
<TitulPred>Ing.</TitulPred>
<TitulZa></TitulZa>
</Student>
</Vystup>
XML 通过查询插入到 db 中:
insert into A_STUDENT_BIN
values (XmlType( bfilename('MYDIR','student.xml'),
nls_charset_id('EE8MSWIN1250') );