Oracle
 sql >> Base de données >  >> RDS >> Oracle

Exporter des données dans un fichier JSON dans Oracle 11g à l'aide de PL/SQL

Dans cet article, je donne un exemple pour exporter des données dans un fichier JSON dans Oracle 11g en utilisant PL/SQL.

Suivez ces étapes pour exporter des données dans un fichier JSON dans Oracle 11g

  1. Tout d'abord, téléchargez le package de l'utilitaire Alexandria PL/SQL depuis GITHUB en utilisant le lien suivant :Télécharger le package alexandria_plsql_utility.
  2. Après avoir téléchargé le fichier zip, extrayez-le et trouvez le JSON_UTIL_PKG dans le répertoire "alexandria-plsql-utils-master\alexandria-plsql-utils-master\ora".
  3. Installez la spécification et le corps du package JSON_UTIL_PKG dans votre schéma
  4. Après cela, téléchargez la procédure PL/SQL "WRITE_CLOB_TO_FILE" à partir du lien suivant :Télécharger Write_Clob_To_File.
  5. Installez également cette procédure dans votre schéma.

Vous pouvez maintenant générer le fichier JSON à partir de la table Oracle à l'aide de PL/SQL, comme indiqué dans l'exemple ci-dessous.

Exemple Oracle 11g SQL vers JSON

Dans l'exemple suivant, nous obtiendrons les données dans la variable CLOB à l'aide de la fonction JSON_UTIL_PKG.SQL_TO_JSON puis nous écrirons que CLOB a des données JSON dans un FILE en utilisant la procédure WRITE_CLOB_TO_FILE . Nous allons transmettre trois paramètres à la procédure WRITE_CLOB_TO_FILE, et ils sont les suivants :un nom de fichier, un nom d'objet de répertoire et la variable CLOB.

DECLARE
c CLOB;
BEGIN
SELECT json_util_pkg.sql_to_json('select EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO from emp2')
INTO c
FROM DUAL;

WRITE_CLOB_TO_FILE ('emp.json', 'JSON_DIR', c);
END;
/

Vous pouvez maintenant vérifier l'emplacement de l'objet de répertoire JSON_DIR, et vous trouverez le fichier JSON comme indiqué dans l'exemple de sortie ci-dessous :

{"ROWSET":[{"EMPNO":7369,"ENAME":"SMITH","JOB":"CLERK","MGR":7902,"HIREDATE":"17-DEC-80","SAL":800,"COMM":null,"DEPTNO":21},{"EMPNO":7499,"ENAME":"ALLEN","JOB":"SALESMAN","MGR":7698,"HIREDATE":"20-FEB-81","SAL":1600,"COMM":300,"DEPTNO":30},{"EMPNO":7521,"ENAME":"WARD","JOB":"SALESMAN","MGR":7698,"HIREDATE":"22-FEB-81","SAL":1250,"COMM":500,"DEPTNO":30},{"EMPNO":7566,"ENAME":"JONES","JOB":"MANAGER","MGR":7839,"HIREDATE":"04-FEB-81","SAL":2975,"COMM":null,"DEPTNO":20},{"EMPNO":7654,"ENAME":"MARTIN","JOB":"SALESMAN","MGR":7698,"HIREDATE":"28-SEP-81","SAL":1250,"COMM":1400,"DEPTNO":30},{"EMPNO":7698,"ENAME":"BLAKE","JOB":"MANAGER","MGR":7839,"HIREDATE":"05-JAN-81","SAL":2850,"COMM":null,"DEPTNO":30},{"EMPNO":7782,"ENAME":"CLARK","JOB":"MANAGER","MGR":7839,"HIREDATE":"06-SEP-81","SAL":2450,"COMM":null,"DEPTNO":10},{"EMPNO":7788,"ENAME":"SCOTT","JOB":"ANALYST","MGR":7566,"HIREDATE":"19-APR-87","SAL":3000,"COMM":null,"DEPTNO":20},{"EMPNO":7839,"ENAME":"KING","JOB":"PRESIDENT","MGR":null,"HIREDATE":"17-NOV-81","SAL":5000,"COMM":null,"DEPTNO":10},{"EMPNO":7844,"ENAME":"TURNER","JOB":"SALESMAN","MGR":7698,"HIREDATE":"09-AUG-81","SAL":1500,"COMM":0,"DEPTNO":30},{"EMPNO":7876,"ENAME":"ADAMS","JOB":"CLERK","MGR":7788,"HIREDATE":"23-MAY-87","SAL":1100,"COMM":null,"DEPTNO":20},{"EMPNO":7900,"ENAME":"JAMES","JOB":"CLERK","MGR":7698,"HIREDATE":"12-MAR-81","SAL":950,"COMM":null,"DEPTNO":30},{"EMPNO":7902,"ENAME":"FORD","JOB":"ANALYST","MGR":7566,"HIREDATE":"12-MAR-81","SAL":3000,"COMM":null,"DEPTNO":20},{"EMPNO":7934,"ENAME":"MILLER","JOB":"CLERK","MGR":7782,"HIREDATE":"23-JAN-82","SAL":1300,"COMM":null,"DEPTNO":10}]}

Voir aussi :

  • Exporter des données vers Excel à l'aide de PLSQL
  • Exporter des données au format CSV à l'aide de PL/SQL