Discussions
Categories
- 196.8K All Categories
- 2.2K Data
- 239 Big Data Appliance
- 1.9K Data Science
- 450.3K Databases
- 221.7K General Database Discussions
- 3.8K Java and JavaScript in the Database
- 31 Multilingual Engine
- 550 MySQL Community Space
- 478 NoSQL Database
- 7.9K Oracle Database Express Edition (XE)
- 3K ORDS, SODA & JSON in the Database
- 544 SQLcl
- 4K SQL Developer Data Modeler
- 187K SQL & PL/SQL
- 21.3K SQL Developer
- 295.9K Development
- 17 Developer Projects
- 138 Programming Languages
- 292.5K Development Tools
- 107 DevOps
- 3.1K QA/Testing
- 646K Java
- 28 Java Learning Subscription
- 37K Database Connectivity
- 155 Java Community Process
- 105 Java 25
- 22.1K Java APIs
- 138.1K Java Development Tools
- 165.3K Java EE (Java Enterprise Edition)
- 18 Java Essentials
- 160 Java 8 Questions
- 86K Java Programming
- 80 Java Puzzle Ball
- 65.1K New To Java
- 1.7K Training / Learning / Certification
- 13.8K Java HotSpot Virtual Machine
- 94.3K Java SE
- 13.8K Java Security
- 204 Java User Groups
- 24 JavaScript - Nashorn
- Programs
- 439 LiveLabs
- 38 Workshops
- 10.2K Software
- 6.7K Berkeley DB Family
- 3.5K JHeadstart
- 5.7K Other Languages
- 2.3K Chinese
- 171 Deutsche Oracle Community
- 1.1K Español
- 1.9K Japanese
- 232 Portuguese
XML parsing error for invalid character 181 (U+00B5)

I am trying to import large xml files (1GB) into relational database tables. It is throwing error when there is non-ASCII character. In this case it is µ (mu).
ERROR at line 1:
ORA-31011: XML parsing failed
ORA-19213: error occurred in XML processing at lines 37078
LPX-00217: invalid character 181 (U+00B5)
ORA-06512: at "SYS.XMLTYPE", line 296
This is the line it fails:
l_xmlfile := xmltype(bfilename(i_dir,i_file), NLS_CHARSET_ID('AL32UTF8'));
I tried to overcome that with,
l_xmlfile := xmltype(bfilename(i_dir,i_file), NLS_CHARSET_ID('AL32UTF8'), NULL, 1, 1);
But, trying to loop through the xml data fails. I'm passing l_xmlfile into another procedure as i_xml
Here is the FOR LOOP I get the error message again.
FOR c_records IN
(
SELECT *
FROM TABLE(xmlsequence(extract(i_xml, '/masterrec')))
CROSS JOIN xmltable
(
'/masterrec/subreport'
PASSING i_xml
COLUMNS .......
)
)
LOOP
Here are the relevant NLS parameters
NLS_CHARACTERSET AL32UTF8
NLS_DATE_LANGUAGE AMERICAN
NLS_LANGUAGE AMERICAN
NLS_LENGTH_SEMANTICS BYTE
NLS_NCHAR_CHARACTERSET AL16UTF16
NLS_NCHAR_CONV_EXCP FALSE
Is there any workaround/solution to overcome this other than replacing the non-ASCII characters?
Best Answer
-
xmlfile := xmltype(bfilename(i_dir,i_file), NLS_CHARSET_ID('WE8MSWIN1252'));
fixed the problem! No other changes to NLS parameters or other code.
Answers
-
xmlfile := xmltype(bfilename(i_dir,i_file), NLS_CHARSET_ID('WE8MSWIN1252'));
fixed the problem! No other changes to NLS parameters or other code.