Кодировать файл XML UTF 8 в базу данных Oracle Oracle (проблема с акцентами) - PullRequest
0 голосов
/ 31 августа 2018

XML-файл кодируется в формате utf-8. Я хотел бы загрузить этот файл в базу данных Oracle, закодированную в ISO: NLS_CHARACTERSET = WE8ISO8859P15.

Мы использовали эту функцию:

declare
   i_aag_id  number := 3878;
   i_dir varchar2(50) := 'EXT_TAB_DIR';
   i_file varchar2(50) := 'PVAG_3878_AR.xml';
   i_type_pjs varchar2(20) := 'PVAR';
   l_clob   CLOB;
   xml_pjs XMLTYPE;
   l_bfile  BFILE := BFILENAME(i_dir, i_file);
begin
   DBMS_LOB.createtemporary (l_clob, TRUE);
   DBMS_LOB.fileopen(l_bfile, DBMS_LOB.file_readonly);
   DBMS_LOB.loadfromfile(l_clob, l_bfile, DBMS_LOB.getlength(l_bfile));
   insert into adb_ag_pjs (aag_id,aag_pjs,aag_pjs_doc,aag_pjs_archive,aag_type_pjs)
   values (1,XMLTYPE.createXML(l_clob),null,1,i_type_pjs);
end;

К сожалению, акценты загружены неправильно:

<?xml version = '1.0' encoding = 'UTF-8'?>
<pjs:Campaign Version="1.0" TrackId="C222_PVAR_3878" Name="C222_PVAR_3878" BreakdownCode="C222" Application="REALESTATE" xmlns:com="http://www.maileva.fr/CommonSchema" xmlns:spec="http://www.maileva.fr/MailevaSpecificSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:pjs="http://www.maileva.fr/MailevaPJSSchema">
<pjs:Requests>
   <pjs:Request MediaType="PAPER" TrackId="C222_PVAR_3878">
     <pjs:Recipients>
        <pjs:Internal>
           <pjs:Recipient TrackId="MLE PARE MARIE THÿ¿Rÿ¿SE" Id="1">
                 [...]

Есть ли у вас идея загрузить xml-файл в кодировке utf-8 в базу данных oracle iso с акцентами? Спасибо

...