{"id":267726,"date":"2015-11-08T18:26:03","date_gmt":"2015-11-08T15:26:03","guid":{"rendered":"http:\/\/savepearlharbor.com\/?p=267726"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=267726","title":{"rendered":"Tibero \u0447\u0430\u0441\u0442\u044c 2. \u041f\u0435\u0440\u0435\u0441\u043d\u043e\u0441 \u043f\u0440\u043e\u0435\u043a\u0442\u0430 \u0441 Oracle"},"content":{"rendered":"<p>       \u0414\u043b\u044f \u0442\u0435\u0441\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f \u0441\u043e\u0432\u043c\u0435\u0441\u0442\u0438\u043c\u043e\u0441\u0442\u0438 <b>Tibero<\/b> c <b>Oracle<\/b> \u044f \u0440\u0435\u0448\u0438\u043b \u043f\u0440\u043e\u0432\u0435\u0440\u0438\u0442\u044c, \u0431\u0443\u0434\u0443\u0442 \u043b\u0438 \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u043d\u0430 \u043d\u0435\u043c \u043b\u044e\u0431\u0438\u043c\u044b\u0435 \u043c\u043d\u043e\u044e <b>PL\/SQL<\/b> \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438, \u0430 \u0438\u043c\u0435\u043d\u043d\u043e: <br \/>  <a href=\"https:\/\/github.com\/mortenbra\/alexandria-plsql-utils\/\">https:\/\/github.com\/mortenbra\/alexandria-plsql-utils\/<\/a><br \/>  \u0422\u0435\u0441\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u043d\u0430\u0447\u0430\u043b\u043e\u0441\u044c \u0441 <i>JSON_UTIL_PKG<\/i>. \u041e\u0447\u0435\u043d\u044c \u043f\u043e\u043b\u0435\u0437\u043d\u0430\u044f \u0444\u0443\u043d\u043a\u0446\u0438\u044f \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u044e\u0449\u0430\u044f \u0431\u044b\u0441\u0442\u0440\u043e \u0433\u0435\u043d\u0435\u0440\u0438\u0440\u043e\u0432\u0430\u0442\u044c JSON-\u043e\u0442\u0432\u0435\u0442. <br \/>  <a name=\"habracut\"><\/a><br \/>  \u0438 \u0442\u0430\u043a, \u0434\u0435\u043b\u0430\u0435\u043c   <\/p>\n<pre><code class=\"bash\">wget https:\/\/raw.githubusercontent.com\/mortenbra\/alexandria-plsql-utils\/2213e3df2f24a00322239d442c54bf31039f2588\/setup\/types.sql  wget https:\/\/raw.githubusercontent.com\/mortenbra\/alexandria-plsql-utils\/master\/ora\/json_util_pkg.pks  wget https:\/\/raw.githubusercontent.com\/mortenbra\/alexandria-plsql-utils\/master\/ora\/json_util_pkg.pkb <\/code><\/pre>\n<p>  \u0414\u043b\u044f \u0443\u043f\u0440\u043e\u0449\u0435\u043d\u0438\u044f \u0436\u0438\u0437\u043d\u0438 \u0432 \u043d\u0430\u0447\u0430\u043b\u043e pkb \u0444\u0430\u0439\u043b\u0430 \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c   <\/p>\n<pre><code class=\"bash\">set define off <\/code><\/pre>\n<p>  types.sql \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u043b\u0438\u0441\u044c \u0443\u0434\u0430\u0447\u043d\u043e. <br \/>  \u041f\u0440\u0438 \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0435 \u043f\u0430\u043a\u0435\u0442\u0430 \u043c\u044b \u043d\u0435\u043e\u0436\u0438\u0434\u0430\u043d\u043d\u043e \u043d\u0430\u0442\u044b\u043a\u0430\u0435\u043c\u0441\u044f \u043d\u0430 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u044b. \u0415\u0441\u043b\u0438 \u0432 <b>oracle<\/b> \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0430 \u044d\u0442\u0438\u0445 \u0442\u0440\u0435\u0445 \u0444\u0430\u0439\u043b\u043e\u0432 \u043f\u0440\u043e\u0448\u043b\u0430 \u0433\u043b\u0430\u0434\u043a\u043e \u0441 \u043f\u043e\u043b\u0443\u0447\u0435\u043d\u0438\u0435\u043c \u0441\u043a\u043e\u043c\u043f\u0438\u043b\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e\u0433\u043e \u043f\u0430\u043a\u0435\u0442\u0430, \u0442\u043e \u0432 \u0441\u043b\u0443\u0447\u0430\u0435 \u0441 <b>tibero<\/b> \u043f\u0440\u0438 \u0437\u0430\u043b\u0438\u0432\u043a\u0435 \u0442\u0435\u043b\u0430 \u043f\u0430\u043a\u0435\u0442\u0430 \u044f \u043f\u043e\u043b\u0443\u0447\u0438\u043b \u0442\u0430\u043a\u043e\u0439 \u0432\u044b\u0432\u043e\u0434:  <\/p>\n<pre><code>tbsql sys\/syspass @json_util_pkg.pkb tbSQL 5 SP1 TmaxData Corporation Copyright (c) 2008-. All rights reserved. Connected to Tibero.  Warning: PACKAGE BODY created with compilation errors. File finished. <\/code><\/pre>\n<p>  \u0412\u044b\u0437\u0432\u0430\u0432   <\/p>\n<pre><code class=\"sql\">show errors  <\/code><\/pre>\n<p>  \u041f\u043e\u043b\u0443\u0447\u0430\u044e \u043e\u0448\u0438\u0431\u043a\u0443   <\/p>\n<pre><code>TBR-15046: Identifier is out of scope. at line 251, column 5: \tdbms_xmlgen <\/code><\/pre>\n<p>  \u041f\u043e\u043b\u0443\u0447\u0430\u0435\u0442\u0441\u044f, \u0447\u0442\u043e \u043f\u0430\u043a\u0435\u0442\u0430 <i>dbms_xmlgen<\/i> \u0432 <b>tibero<\/b> \u043d\u0435\u0442. \u0421\u0442\u043e\u043b\u043a\u043d\u0443\u0432\u0448\u0438\u0441\u044c \u0441 \u044d\u0442\u043e\u0439 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u043e\u0439 \u044f \u0440\u0435\u0448\u0438\u043b \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c \u043a\u0430\u043a\u0438\u0435 \u0432\u043e\u043e\u0431\u0449\u0435 \u0435\u0441\u0442\u044c \u043f\u0430\u043a\u0435\u0442\u044b DBMS%. \u0417\u0430\u043f\u0440\u043e\u0441   <\/p>\n<pre><code class=\"sql\">select distinct name from all_source where name like 'DBMS%' order by 1 <\/code><\/pre>\n<p>  \u041f\u043e\u043b\u0443\u0447\u0438\u043b \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0439 \u0441\u043f\u0438\u0441\u043e\u043a:  <\/p>\n<table>\n<tr>\n<td>DBMS_APM<\/td>\n<td>DBMS_APM_INTERNAL<\/td>\n<td>DBMS_APPLICATION_INFO<\/td>\n<td>DBMS_CRYPTO<\/td>\n<\/tr>\n<tr>\n<td>DBMS_DEBUG<\/td>\n<td>DBMS_DEBUG_JDWP<\/td>\n<td>DBMS_ERRLOG<\/td>\n<td>DBMS_EXPRESSION<\/td>\n<\/tr>\n<tr>\n<td>DBMS_FLASHBACK<\/td>\n<td>DBMS_GEOM<\/td>\n<td>DBMS_JAVA<\/td>\n<td>DBMS_JOB<\/td>\n<\/tr>\n<tr>\n<td>DBMS_JOB_WITH_NAME<\/td>\n<td>DBMS_JOB_WITH_NAME_INTERNAL<\/td>\n<td>DBMS_LOB<\/td>\n<td>DBMS_LOCK<\/td>\n<\/tr>\n<tr>\n<td>DBMS_METADATA<\/td>\n<td>DBMS_MVIEW<\/td>\n<td>DBMS_MVIEW_REFRESH_UTIL<\/td>\n<td>DBMS_MVIEW_UTIL<\/td>\n<\/tr>\n<tr>\n<td>DBMS_OBFUSCATION_TOOLKIT<\/td>\n<td>DBMS_OUTPUT<\/td>\n<td>DBMS_PIPE<\/td>\n<td>DBMS_RANDOM<\/td>\n<\/tr>\n<tr>\n<td>DBMS_REDEFINITION<\/td>\n<td>DBMS_REDEFINITION_STATS<\/td>\n<td>DBMS_REPAIR<\/td>\n<td>DBMS_RESULT_CACHE<\/td>\n<\/tr>\n<tr>\n<td>DBMS_ROWID<\/td>\n<td>DBMS_SESSION<\/td>\n<td>DBMS_SPACE<\/td>\n<td>DBMS_SPACE_ADMIN<\/td>\n<\/tr>\n<tr>\n<td>DBMS_SPH<\/td>\n<td>DBMS_SPH_INTERNAL<\/td>\n<td>DBMS_SQL<\/td>\n<td>DBMS_STATS<\/td>\n<\/tr>\n<tr>\n<td>DBMS_STATS_INTERNAL<\/td>\n<td>DBMS_STATS_UTIL<\/td>\n<td>DBMS_SYSTEM<\/td>\n<td>DBMS_TRANSACTION<\/td>\n<\/tr>\n<tr>\n<td>DBMS_TYPES<\/td>\n<td>DBMS_UTILITY<\/td>\n<td>DBMS_VERIFY<\/td>\n<td>DBMS_XMLGEN<\/td>\n<\/tr>\n<tr>\n<td>DBMS_XPLAN<\/td>\n<\/tr>\n<\/table>\n<p>  \u0418\u0442\u043e\u0433\u043e 45 \u043f\u0440\u043e\u0442\u0438\u0432 195 \u0432 \u043c\u043e\u0435\u0439 \u0432\u0435\u0440\u0441\u0438\u0438 <b>oracle<\/b>. \u0412\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u0433\u0440\u0443\u0441\u0442\u043d\u043e. \u0418\u0437 \u0442\u0435\u0445 \u043f\u0430\u043a\u0435\u0442\u043e\u0432, \u0447\u0442\u043e \u043c\u043d\u0435 \u0432 <b>Oracle<\/b> \u043f\u0440\u0438\u0445\u043e\u0434\u0438\u043b\u043e\u0441\u044c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0440\u0430\u0441\u0441\u0442\u0440\u0430\u0438\u0432\u0430\u0435\u0442 \u043e\u0442\u0441\u0443\u0442\u0441\u0442\u0432\u0438\u0435 <i>DBMS_SCHEDULER<\/i>, <i>DBMS_XMLDOM<\/i> \u0438 \u0442.\u0434.. <br \/>  \u042f \u0434\u0443\u043c\u0430\u044e, \u0447\u0442\u043e \u043c\u043d\u043e\u0433\u0438\u0435 \u0432 \u0441\u043f\u0438\u0441\u043a\u0435 150 \u043d\u0435 \u043f\u043e\u043f\u0430\u0432\u0448\u0438\u0445 \u0432 <b>tibero<\/b> <i>dbms<\/i>\u043e\u0432 \u043d\u0430\u0439\u0434\u0443\u0442 \u043d\u0435 \u0445\u0432\u0430\u0442\u0430\u044e\u0449\u0438\u0435 \u0438\u043c \u043f\u0430\u043a\u0435\u0442\u044b.<br \/>  \u041d\u043e \u0447\u0442\u043e \u0441\u0430\u043c\u043e\u0435 \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u043e\u0435: \u043f\u0430\u043a\u0435\u0442 <i>dbms_xmlgen<\/i>, \u0438\u0437-\u0437\u0430 \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u0431\u044b\u043b\u0430 \u043e\u0448\u0438\u0431\u043a\u0430, \u0432 <b>Tibero<\/b> \u043f\u0440\u0438\u0441\u0443\u0442\u0441\u0442\u0432\u0443\u0435\u0442. \u041f\u0440\u043e\u0431\u043b\u0435\u043c\u0430 \u0436\u0435 \u043e\u043a\u0430\u0437\u0430\u043b\u0430\u0441\u044c \u0432 \u0442\u043e\u043c, \u0447\u0442\u043e \u0432 \u043f\u0430\u043a\u0435\u0442\u0435 \u043d\u0435\u0442 \u0444\u0443\u043d\u043a\u0446\u0438\u0438 <i>setmaxrows<\/i>.<br \/>  \u0421\u0434\u0435\u043b\u0430\u0432   <\/p>\n<pre><code class=\"sql\">desc dbms_xmlgen <\/code><\/pre>\n<p>  \u041f\u043e\u043b\u0443\u0447\u0438\u043b \u0442\u0430\u043a\u043e\u0435 \u043d\u0430\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0435 \u043f\u0430\u043a\u0435\u0442\u0430 \u0432 <b>Tibero<\/b>  <\/p>\n<table>\n<tr>\n<td>FUNCTION CONVERT( XMLDATA IN VARCHAR, FLAG IN NUMBER ) RETURNS VARCHAR  <\/td>\n<\/tr>\n<tr>\n<td>FUNCTION CONVERT( XMLDATA IN CLOB, FLAG IN NUMBER ) RETURNS CLOB  <\/td>\n<\/tr>\n<tr>\n<td>FUNCTION NEWCONTEXT( QUERY IN VARCHAR ) RETURNS NUMBER  <\/td>\n<\/tr>\n<tr>\n<td>FUNCTION NEWCONTEXT( QUERY IN REF CURSOR ) RETURNS NUMBER  <\/td>\n<\/tr>\n<tr>\n<td>PROCEDURE SETNULLHANDLING( CTX IN NUMBER, FLAG IN NUMBER )  <\/td>\n<\/tr>\n<tr>\n<td>PROCEDURE CLOSECONTEXT( CTX IN NUMBER )  <\/td>\n<\/tr>\n<tr>\n<td>FUNCTION GETXML( CTX IN NUMBER, DTDORSCHEMA IN NUMBER) RETURNS CLOB  <\/td>\n<\/tr>\n<tr>\n<td>FUNCTION GETXML( SQLQUERY IN VARCHAR, DTDORSCHEMA IN NUMBER ) IN RETURNS CLOB  <\/td>\n<\/tr>\n<tr>\n<td>PROCEDURE GETXML( CTX IN NUMBER, TMPCLOB IN OUT CLOB, DTDORSCHEMA IN NUMBER )   <\/td>\n<\/tr>\n<\/table>\n<p>  \u041a\u0430\u043a \u0438\u0437 \u0432\u044b\u0448\u0435\u0441\u043a\u0430\u0437\u0430\u043d\u043d\u043e\u0433\u043e \u0432\u0438\u0434\u043d\u043e, \u0443 <b>Tibero<\/b> \u043c\u0435\u043d\u044c\u0448\u0435 \u043d\u0435 \u0442\u043e\u043b\u044c\u043a\u043e \u043f\u0430\u043a\u0435\u0442\u043e\u0432, \u043d\u043e \u0438 \u043f\u0440\u043e\u0446\u0435\u0434\u0443\u0440 \u0432\u043d\u0443\u0442\u0440\u0438 \u043d\u0438\u0445. \u041f\u043e\u043b\u0443\u0447\u0430\u0435\u0442\u0441\u044f, \u0447\u0442\u043e \u0441\u043a\u043e\u0440\u0435\u0435 \u0432\u0441\u0435\u0433\u043e \u043c\u0438\u0433\u0440\u0430\u0446\u0438\u044f \u0433\u043e\u0442\u043e\u0432\u043e\u0433\u043e <b>Oracle<\/b> \u043f\u0440\u043e\u0434\u0443\u043a\u0442\u0430 \u043d\u0430 <b>Tibero<\/b> \u0431\u0443\u0434\u0435\u0442 \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u0442\u044f\u0436\u0435\u043b\u043e\u0439, \u0442\u0430\u043a \u043a\u0430\u043a \u0432\u0435\u043b\u0438\u043a \u0448\u0430\u043d\u0441, \u0447\u0442\u043e \u043f\u0430\u043a\u0435\u0442\u044b \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0449\u0438\u0435 \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u044b\u0435 \u043f\u0430\u043a\u0435\u0442\u044b <b>Oracle<\/b> \u043d\u0435 c\u043a\u043e\u043c\u043f\u0438\u043b\u0438\u0440\u0443\u044e\u0442\u0441\u044f \u0438 \u0438\u0445 \u043f\u0440\u0438\u0434\u0435\u0442\u0441\u044f \u043f\u0435\u0440\u0435\u043f\u0438\u0441\u044b\u0432\u0430\u0442\u044c, \u043b\u0438\u0431\u043e \u0441\u0430\u043c\u043e\u0441\u0442\u043e\u044f\u0442\u0435\u043b\u044c\u043d\u043e \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u044b\u0432\u0430\u0442\u044c \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u044b\u0435 <b>Oracle<\/b> \u043f\u0430\u043a\u0435\u0442\u044b.<\/p>\n<p>  \u041f\u043e\u043b\u0443\u0447\u0438\u0432 \u0442\u0430\u043a\u043e\u0439 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u044f \u0440\u0435\u0448\u0438\u043b \u0431\u043e\u043b\u0435\u0435 \u0434\u0435\u0442\u0430\u043b\u044c\u043d\u043e \u0438\u0437\u0443\u0447\u0438\u0442\u044c \u0435\u0449\u0435 \u0434\u0432\u0430 \u043f\u0430\u043a\u0435\u0442\u0430: <i>DBMS_LOB<\/i> \u0438 <i>DBMS_LOCK<\/i>. \u041e\u043d\u0438 \u0431\u044b\u043b\u0438 \u0432\u044b\u0431\u0440\u0430\u043d\u044b \u043f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e \u043e\u043d\u0438 \u043c\u043d\u0435 \u043a\u0430\u0436\u0443\u0442\u0441\u044f \u0441\u0430\u043c\u044b\u043c\u0438 \u043f\u043e\u043f\u0443\u043b\u044f\u0440\u043d\u044b\u043c\u0438 \u0443 <i>PL\/SQL<\/i> \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u043e\u0432.<\/p>\n<p>  <u><i>DBMS_LOB.<\/i><\/u><br \/>  \u0421\u0440\u0430\u0432\u043d\u0435\u043d\u0438\u0435 \u043f\u043e\u043a\u0430\u0437\u0430\u043b\u043e, \u0447\u0442\u043e \u0432\u0441\u0435 \u043e\u0441\u043d\u043e\u0432\u043d\u044b\u0435 \u0444\u0443\u043d\u043a\u0446\u0438\u0438 \u043f\u0440\u0438\u0441\u0443\u0442\u0441\u0442\u0432\u0443\u044e\u0442, \u043d\u043e \u0432 <b>Tibero<\/b> c \u0444\u0440\u0430\u0433\u043c\u0435\u043d\u0442\u0430\u043c\u0438 \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u043d\u0435\u043b\u044c\u0437\u044f, c <i>DBFS_LINK<\/i>\u2019\u0430\u043c\u0438 \u0442\u043e\u0436\u0435, \u0434\u0430 \u0438 \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u0443\u0434\u043e\u0431\u043d\u044b\u0445 \u043c\u0435\u0442\u043e\u0434\u043e\u0432 \u0442\u043e\u0436\u0435 \u043d\u0435\u0442. \u0415\u0441\u043b\u0438 \u0433\u043e\u0432\u043e\u0440\u0438\u0442\u044c \u0441\u0443\u0445\u043e, \u0442\u043e \u043f\u0430\u043a\u0435\u0442 <i>DBMS_LOB<\/i> \u0432<b> tibero <\/b>\u043d\u0435 \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u0442 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0435 \u043c\u0435\u0442\u043e\u0434\u044b:   <\/p>\n<table>\n<tr>\n<td>COPY_DBFS_LINK<\/td>\n<td>COPY_FROM_DBFS_LINK<\/td>\n<td>DBFS_LINK_GENERATE_PATH<\/td>\n<td>FRAGMENT_DELETE<\/td>\n<\/tr>\n<tr>\n<td>FRAGMENT_INSERT<\/td>\n<td>FRAGMENT_MOVE<\/td>\n<td>FRAGMENT_REPLACE<\/td>\n<td>GETCHUNKSIZE<\/td>\n<\/tr>\n<tr>\n<td>GETCONTENTTYPE<\/td>\n<td>GETOPTIONS<\/td>\n<td>GET_DBFS_LINK<\/td>\n<td>GET_DBFS_LINK_STATE<\/td>\n<\/tr>\n<tr>\n<td>GET_DEDUPLICATE_REGIONS<\/td>\n<td>GET_STORAGE_LIMIT<\/td>\n<td>ISSECUREFILE<\/td>\n<td>LOADBLOBFROMFILE<\/td>\n<\/tr>\n<tr>\n<td>LOADCLOBFROMFILE<\/td>\n<td>LOADFROMFILE<\/td>\n<td>MOVE_TO_DBFS_LINK<\/td>\n<td>SETCONTENTTYPE<\/td>\n<\/tr>\n<tr>\n<td>SETOPTIONS<\/td>\n<td>SET_DBFS_LINK<\/td>\n<\/tr>\n<\/table>\n<p>  <i>DBMS_LOCK<\/i> \u0436\u0435 \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u043d \u043f\u043e\u043b\u043d\u043e\u0441\u0442\u044c\u044e.<\/p>\n<p>  \u0421 \u043f\u0430\u043a\u0435\u0442\u0430\u043c\u0438 <i>UTL_%<\/i> \u0441\u0438\u0442\u0443\u0430\u0446\u0438\u044f \u0431\u043b\u0438\u0437\u043a\u0430 \u043a <i> DBMS_%<\/i>. \u0412\u0441\u0435\u0433\u043e \u0432 <b>Tibero<\/b> \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u043b\u0435\u043d\u043e 11 \u043f\u0430\u043a\u0435\u0442\u043e\u0432. \u0418\u0437 \u043a\u043e\u0442\u043e\u0440\u044b\u0445 8 (<i>UTL_ENCODE<\/i>, <i>UTL_FILE<\/i>, <i>UTL_HTTP<\/i>, <i>UTL_I18N<\/i>, <i>UTL_MATCH<\/i>, <i>UTL_RAW<\/i>, <i>UTL_TCP<\/i>, <i>UTL_URL<\/i> ) \u043f\u043e\u0445\u043e\u0436\u0438 \u043d\u0430 \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u044b\u0435 \u043f\u0430\u043a\u0435\u0442\u044b <b>Oracle<\/b>, \u043e\u0441\u0442\u0430\u0432\u0448\u0438\u0435\u0441\u044f \u0442\u0440\u0438 \u2014 \u0441\u0432\u043e\u0438 \u0441\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u0435. \u0423 <b>Oracle<\/b> \u0432 \u0441\u0432\u043e\u044e \u043e\u0447\u0435\u0440\u0435\u0434\u044c \u043f\u0430\u043a\u0435\u0442\u043e\u0432 21, \u0442\u0435\u043c \u0441\u0430\u043c\u044b\u043c \u0432 <b>Tibero<\/b> \u043d\u0435 \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u043d\u044b \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0435 13 \u043f\u0430\u043a\u0435\u0442\u043e\u0432:  <\/p>\n<table>\n<tr>\n<td>UTL_CALL_STACK<\/td>\n<td>UTL_COLL<\/td>\n<td>UTL_COMPRESS<\/td>\n<td>UTL_GDK<\/td>\n<\/tr>\n<tr>\n<td>UTL_IDENT<\/td>\n<td>UTL_INADDR<\/td>\n<td>UTL_LMS<\/td>\n<td>UTL_NLA<\/td>\n<\/tr>\n<tr>\n<td>UTL_RECOMP<\/td>\n<td>UTL_REF<\/td>\n<td>UTL_SMTP<\/td>\n<td>UTL_SYS_COMPRESS<\/td>\n<\/tr>\n<tr>\n<td>UTL_XML<\/td>\n<\/tr>\n<\/table>\n<p>  \u0418\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u043e, \u043f\u043e\u0447\u0435\u043c\u0443 <b>Tibero<\/b> \u0442\u0430\u043a \u043d\u0435 \u043b\u044e\u0431\u0438\u0442 <b>XML<\/b>\u2026<\/p>\n<p>  \u0421\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a \u043d\u0435 \u043e\u0447\u0435\u043d\u044c \u043e\u043f\u0442\u0438\u043c\u0438\u0441\u0442\u0438\u0447\u043d\u043e\u0435. \u041d\u043e \u043d\u0435 \u0432\u0441\u0435\u0433\u0434\u0430 \u0436\u0435 \u043c\u044b \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c <i>DBMS<\/i> \u0438 <i>UTL<\/i> \u043f\u0430\u043a\u0435\u0442\u044b! \u0418\u043d\u043e\u0433\u0434\u0430 \u0445\u0432\u0430\u0442\u0430\u0435\u0442 \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u044b\u0445 \u0444\u0443\u043d\u043a\u0446\u0438\u0439, \u0430 \u0441 \u043d\u0438\u043c\u0438 \u0432\u0441\u0435 \u0431\u043e\u043b\u0435\u0435-\u043c\u0435\u043d\u0435\u0435 \u043e\u043f\u0442\u0438\u043c\u0438\u0441\u0442\u0438\u0447\u043d\u043e. <b>TMax<\/b> \u0430\u043a\u0442\u0438\u0432\u043d\u043e \u0440\u0430\u0441\u0448\u0438\u0440\u044f\u0435\u0442 \u0441\u043f\u0438\u0441\u043e\u043a \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0435\u043c\u044b\u0445 \u0444\u0443\u043d\u043a\u0446\u0438\u0439 \u0438 \u0441\u0435\u0439\u0447\u0430\u0441 \u0441\u0442\u0430\u0431\u0438\u043b\u044c\u043d\u043e \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0435\u0442 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0439 \u0441\u043f\u0438\u0441\u043e\u043a \u043c\u0435\u0442\u043e\u0434\u043e\u0432:<br \/>  <u>\u041c\u0430\u0442\u0435\u043c\u0430\u0442\u0438\u043a\u0430<\/u>  <\/p>\n<table>\n<tr>\n<td>ABS<\/td>\n<td>ACOS<\/td>\n<td>ASIN<\/td>\n<td>ATAN<\/td>\n<td>ATAN2<\/td>\n<\/tr>\n<tr>\n<td>AVG<\/td>\n<td>BITAND<\/td>\n<td>CEIL<\/td>\n<td>COS<\/td>\n<td>COSH<\/td>\n<\/tr>\n<tr>\n<td>COUNT<\/td>\n<td>EXP<\/td>\n<td>FLOOR<\/td>\n<td>LN<\/td>\n<td>LOG(M,N)<\/td>\n<\/tr>\n<tr>\n<td>MOD<\/td>\n<td>POWER<\/td>\n<td>ROUND<\/td>\n<td>SIGN<\/td>\n<td>SIN<\/td>\n<\/tr>\n<tr>\n<td>SINH<\/td>\n<td>SQRT<\/td>\n<td>TAN<\/td>\n<td>TANH<\/td>\n<td>TRUNC<\/td>\n<\/tr>\n<\/table>\n<p>  <u>\u0421\u0442\u0440\u043e\u043a\u0438<\/u>  <\/p>\n<table>\n<tr>\n<td>CONCAT<\/td>\n<td>CHR<\/td>\n<td>LOWER<\/td>\n<td>UPPER<\/td>\n<td>LPAD<\/td>\n<\/tr>\n<tr>\n<td>LTRIM<\/td>\n<td>RTRIM<\/td>\n<td>RPAD<\/td>\n<td>SUBSTR<\/td>\n<td>REPLACE<\/td>\n<\/tr>\n<tr>\n<td>INITCAP<\/td>\n<td>NLS_INITCAP<\/td>\n<td>NLS_SORT<\/td>\n<td>TRANSLATE<\/td>\n<td>TO_CHAR<\/td>\n<\/tr>\n<tr>\n<td>ASCII<\/td>\n<td>INSTR<\/td>\n<td>LENGTH<\/td>\n<td>LENGTHB<\/td>\n<\/tr>\n<\/table>\n<p>  <u>\u0414\u0430\u0442\u044b<\/u>  <\/p>\n<table>\n<tr>\n<td>+integer<\/td>\n<td>-date<\/td>\n<td>ADD_MONTHS<\/td>\n<td>CURRENT_DATE<\/td>\n<\/tr>\n<tr>\n<td>CURRENT_TIME<\/td>\n<td>CURRENT_TIMESTAMP<\/td>\n<td>LAST_DAY<\/td>\n<td>NEW_TIME<\/td>\n<\/tr>\n<tr>\n<td>NEXT_DAY<\/td>\n<td>ROUND<\/td>\n<td>TRUNC<\/td>\n<td>EXTRACT<\/td>\n<\/tr>\n<tr>\n<td>SYSTIMESTAMP<\/td>\n<td>MONTHS_BETWEEN<\/td>\n<td>TO_CHAR<\/td>\n<td>TO_NUMBER<\/td>\n<\/tr>\n<tr>\n<td>TO_DATE<\/td>\n<td>TO_DSINTERVAL<\/td>\n<td>SYSDATE<\/td>\n<\/tr>\n<\/table>\n<p>  <u>\u0421\u043b\u0443\u0436\u0435\u0431\u043d\u044b\u0435<\/u>  <\/p>\n<table>\n<tr>\n<td>GREATEST<\/td>\n<td>LEAST<\/td>\n<td>CAST<\/td>\n<td>CONVERT<\/td>\n<\/tr>\n<tr>\n<td>HEXTOCHAR<\/td>\n<td>ROWIDTOCHAR<\/td>\n<td>TO_CLOB<\/td>\n<td>TO_LOB<\/td>\n<\/tr>\n<tr>\n<td>DECODE<\/td>\n<td>DUMP<\/td>\n<td>VSIZE<\/td>\n<td>COALEASE<\/td>\n<\/tr>\n<tr>\n<td>LNNVL<\/td>\n<td>NULLIF<\/td>\n<td>NVL<\/td>\n<td>NVL2<\/td>\n<\/tr>\n<\/table>\n<p>  \u0415\u0441\u043b\u0438 \u043c\u044b \u0441\u0434\u0435\u043b\u0430\u0435\u043c \u0437\u0430\u043f\u0440\u043e\u0441 \u0432 <i>all_procedures<\/i>, \u0442\u043e \u0443\u0432\u0438\u0434\u0438\u043c \u0435\u0449\u0435 \u0444\u0443\u043d\u043a\u0446\u0438\u0438, \u043d\u043e \u0432 \u043e\u0444\u0438\u0446\u0438\u0430\u043b\u044c\u043d\u043e\u0439 \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u0438 \u043e\u043d\u0438 \u043d\u0435 \u0443\u043f\u043e\u043c\u0438\u043d\u0430\u044e\u0442\u0441\u044f. <\/p>\n<p>  \u041f\u043e\u0441\u043b\u0435 \u043f\u043e\u043b\u0443\u0447\u0435\u043d\u043d\u044b\u0445 \u0432\u044b\u0448\u0435 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u043e\u0432 \u044f \u0440\u0435\u0448\u0438\u043b, \u0447\u0442\u043e \u0437\u0430\u0433\u0440\u0443\u0436\u0430\u0442\u044c \u0441\u043b\u043e\u0436\u043d\u044b\u0435 \u043f\u0430\u043a\u0435\u0442\u044b \u043d\u0435 \u0438\u043c\u0435\u0435\u0442 \u0441\u043c\u044b\u0441\u043b\u0430: \u0441\u043a\u043e\u0440\u0435\u0435 \u0432\u0441\u0435\u0433\u043e \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u044b \u0431\u0443\u0434\u0443\u0442 \u043f\u043e\u0445\u043e\u0436\u0438\u043c\u0438 \u0438 \u0431\u0443\u0434\u0443\u0442 \u0443\u043f\u0438\u0440\u0430\u0442\u044c\u0441\u044f \u0432 \u043d\u0435\u0445\u0432\u0430\u0442\u043a\u0443 \u0442\u0435\u0445 \u0438\u043b\u0438 \u0438\u043d\u044b\u0445 \u043f\u0430\u043a\u0435\u0442\u043e\u0432. \u041d\u043e \u0431\u044b\u0432\u0430\u044e\u0442 \u0436\u0435 \u0438 \u043f\u0440\u043e\u0441\u0442\u044b\u0435 \u0441\u0438\u0441\u0442\u0435\u043c\u044b, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043b\u0435\u0433\u043a\u043e \u043e\u0431\u0445\u043e\u0434\u044f\u0442\u0441\u044f \u0431\u0435\u0437 <i>DBMS<\/i> \u043f\u0430\u043a\u0435\u0442\u043e\u0432 \u0438 \u0441\u043b\u043e\u0436\u043d\u044b\u0445 \u0444\u0443\u043d\u043a\u0446\u0438\u0439 \u042f \u0440\u0435\u0448\u0438\u043b \u043f\u043e\u043f\u0440\u043e\u0431\u043e\u0432\u0430\u0442\u044c \u043e\u0446\u0435\u043d\u0438\u0442\u044c \u0441 \u043a\u0430\u043a\u0438\u043c\u0438 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0430\u043c\u0438 \u043c\u043e\u0436\u043d\u043e \u0441\u0442\u043e\u043b\u043a\u043d\u0443\u0442\u044c\u0441\u044f \u043f\u0440\u0438 \u043f\u0435\u0440\u0435\u043d\u043e\u0441\u0435 \u0442\u0430\u043a\u0438\u0445 \u0441\u0438\u0441\u0442\u0435\u043c. \u0414\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u044f \u0432\u0437\u044f\u043b Example \u0441\u0445\u0435\u043c\u0443 HR. <br \/>  \u041e\u043d\u0430 \u0431\u044b\u043b\u0430 \u0432\u0437\u044f\u0442\u0430 \u043e\u0442\u0441\u044e\u0434\u0430:<br \/>  <a href=\"http:\/\/www.oracle.com\/technetwork\/developer-tools\/datamodeler\/hr-30-ddl-246035.zip\">http:\/\/www.oracle.com\/technetwork\/developer-tools\/datamodeler\/hr-30-ddl-246035.zip<\/a><br \/>  \u0418\u0441\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0435 \u044d\u0442\u043e\u0433\u043e \u0441\u043a\u0440\u0438\u043f\u0442\u0430 \u0432\u044b\u044f\u0432\u0438\u043b\u043e \u043d\u0435 \u043f\u043e\u043b\u043d\u0443\u044e \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0443 <i>ddl<\/i> \u043e\u0442 <b>Oracle<\/b>.<\/p>\n<p>  <u>\u041f\u0440\u043e\u0431\u043b\u0435\u043c\u0430 \u21161<\/u>  <\/p>\n<pre><code class=\"sql\">ALTER TABLE JOB_HISTORY      ADD CONSTRAINT JHIST_DATE_CHECK      CHECK (end_date &gt; start_date)         INITIALLY IMMEDIATE          ENABLE          VALIDATE  ; <\/code><\/pre>\n<p>  \u0412\u044b\u0434\u0430\u0435\u0442 \u043e\u0448\u0438\u0431\u043a\u0443:  <\/p>\n<pre><code>TBR-7001: General syntax error.    at line 4, column 9:         INITIALLY IMMEDIATE  <\/code><\/pre>\n<p>  \u0412 \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u0438 \u043f\u043e\u0434\u0440\u043e\u0431\u043d\u043e\u0441\u0442\u0435\u0439, \u043a\u0430\u043a \u043c\u043e\u0436\u043d\u043e \u044d\u0442\u043e \u0437\u0430\u0434\u0430\u0442\u044c \u044f \u043d\u0435 \u043d\u0430\u0448\u0435\u043b. \u041d\u043e \u0441\u0443\u0434\u044f \u043f\u043e \u0442\u0435\u0441\u0442\u0430\u043c \u043e\u043d\u043e \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0432 \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0438\u0438 \u0441 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435\u043c <i>DEFERRABLE<\/i>. \u041d\u043e \u0438 \u0441 \u043d\u0438\u043c \u043d\u044e\u0430\u043d\u0441\u044b ( \u0441\u043c. \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0443 2 )<\/p>\n<p>  <u>\u041f\u0440\u043e\u0431\u043b\u0435\u043c\u0430 \u21162<\/u>  <\/p>\n<pre><code class=\"sql\">ALTER TABLE COUNTRIES      ADD CONSTRAINT COUNTR_REG_FK FOREIGN KEY      (       REGION_ID     )      REFERENCES REGIONS      (       REGION_ID     )      NOT DEFERRABLE  ; <\/code><\/pre>\n<p>  \u0412\u044b\u0434\u0430\u0435\u0442 \u043e\u0448\u0438\u0431\u043a\u0443:  <\/p>\n<pre><code>TBR-7001: General syntax error.    at line 10, column 5:     NOT DEFERRABLE <\/code><\/pre>\n<p>  \u041e\u043f\u044f\u0442\u044c \u0442\u0430\u043a\u0438 \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u0438 \u043f\u043e \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044e <i>constraint<\/i>&#8216;\u043e\u0432 \u044f \u043d\u0435 \u043d\u0430\u0448\u0435\u043b, \u043d\u043e \u043d\u0430 \u043f\u0440\u0430\u043a\u0442\u0438\u043a\u0435, \u0435\u0441\u043b\u0438 \u043c\u044b \u0445\u043e\u0442\u0438\u043c \u043e\u0442\u043b\u043e\u0436\u0435\u043d\u043d\u044b\u0435 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u044f, \u0442\u043e \u043c\u044b \u043f\u0438\u0448\u0435\u043c <i>DEFERRABLE<\/i>, \u0435\u0441\u043b\u0438 \u0436\u0435 \u043c\u044b \u0445\u043e\u0442\u0438\u043c \u0432\u0441\u0435\u0433\u0434\u0430 \u043f\u0440\u043e\u0432\u0435\u0440\u044f\u0442\u044c \u044d\u0442\u043e \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0435, \u0442\u043e \u043d\u0435 \u0443\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u043c \u043d\u0438\u0447\u0435\u0433\u043e (\u044d\u0442\u043e \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e).<\/p>\n<p>  \u0421\u0445\u0435\u043c\u0430 \u0441\u043e\u0437\u0434\u0430\u043d\u0430, \u0442\u0435\u043f\u0435\u0440\u044c \u043c\u043e\u0436\u043d\u043e \u0438 \u043f\u0440\u043e\u0433\u043d\u0430\u0442\u044c \u0441\u043a\u0440\u0438\u043f\u0442\u044b \u0434\u043b\u044f \u0442\u0435\u0441\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u0435\u0439 \u0421\u0423\u0411\u0414. \u0421\u043a\u0440\u0438\u043f\u0442\u044b \u044f \u0432\u0437\u044f\u043b \u043e\u0442 \u0441\u044e\u0434\u0430:<br \/>  <a href=\"http:\/\/www.srikanthtechnologies.com\/oracle\/dec9\/hrqueries.html\">http:\/\/www.srikanthtechnologies.com\/oracle\/dec9\/hrqueries.html<\/a><\/p>\n<p>  <u>\u041f\u0440\u043e\u0431\u043b\u0435\u043c\u0430 \u21163<\/u><br \/>  \u0417\u0430\u043f\u0440\u043e\u0441:  <\/p>\n<pre><code class=\"sql\">SELECT SYSDATE - to_date('01-jan-2011') FROM DUAL <\/code><\/pre>\n<p>  \u0414\u0430\u0435\u0442 \u043e\u0448\u0438\u0431\u043a\u0443:  <\/p>\n<pre><code>TBR-5113: Invalid month value 'jan-2011'. (01-jan-2011)    <\/code><\/pre>\n<p>  \u041a\u043e\u0440\u0440\u0435\u043a\u0442\u043d\u044b\u043c \u0434\u043b\u044f Tibero \u0431\u044b\u043b \u0442\u0430\u043a\u043e\u0439 \u0437\u0430\u043f\u0440\u043e\u0441:  <\/p>\n<pre><code class=\"sql\">SELECT SYSDATE - to_date('20110101') from dual    <\/code><\/pre>\n<p>  \u0414\u0440\u0443\u0433\u0438\u0445 \u043e\u0448\u0438\u0431\u043e\u043a \u0438\u0437 \u044d\u0442\u0438\u0445 \u0441\u043a\u0440\u0438\u043f\u0442\u043e\u0432 \u043c\u043d\u0435 \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u044c \u043d\u0435 \u0443\u0434\u0430\u043b\u043e\u0441\u044c. \u041e\u0442\u0434\u0435\u043b\u044c\u043d\u043e \u043f\u0440\u043e\u0432\u0435\u0440\u0438\u043b pivot, \u0440\u0430\u0437\u043b\u0438\u0447\u043d\u044b\u0435 \u043d\u043e\u0442\u0430\u0446\u0438\u0438 join, \u0438\u0435\u0440\u0430\u0440\u0445\u0438\u0447\u0435\u0441\u043a\u0438\u0435 \u0437\u0430\u043f\u0440\u043e\u0441\u044b: \u0432\u0441\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442, \u0441\u0442\u0440\u0430\u043d\u043d\u043e \u0440\u0430\u0431\u043e\u0442\u0430\u044e\u0442 <i>pipeline<\/i> \u0444\u0443\u043d\u043a\u0446\u0438\u0438 \u0438 \u0432\u0441\u0435, \u0447\u0442\u043e \u0441 \u043d\u0438\u043c\u0438 \u0441\u0432\u044f\u0437\u0430\u043d\u043e. \u0412\u043e\u0442, \u043f\u0440\u043e\u0441\u0442\u043e\u0439 \u043f\u0440\u0438\u043c\u0435\u0440:<\/p>\n<p>  <u>\u041f\u0440\u043e\u0431\u043b\u0435\u043c\u0430 \u21164<\/u><br \/>  \u0421\u043e\u0437\u0434\u0430\u044e \u0442\u0438\u043f\u044b  <\/p>\n<pre><code class=\"sql\">CREATE OR REPLACE TYPE TEST_TYPE IS OBJECT( TESTYPE NUMBER ); CREATE OR REPLACE TYPE TEST_TYPE_TABLE IS TABLE OF TEST_TYPE; <\/code><\/pre>\n<p>  \u0421\u043e\u0437\u0434\u0430\u044e \u0444\u0443\u043d\u043a\u0446\u0438\u044e \u0432\u044b\u0434\u0430\u044e\u0449\u0443\u044e \u0442\u0430\u0431\u043b\u0438\u0446\u0443  <\/p>\n<pre><code class=\"sql\">CREATE OR REPLACE FUNCTION TEST_FUNCTION(PARAM IN NUMBER) RETURN TEST_TYPE_TABLE IS \tRSLT TEST_TYPE_TABLE; BEGIN \tRSLT := TEST_TYPE_TABLE(); \tRSLT.EXTEND; \tRSLT(RSLT.LAST) := TEST_TYPE(PARAM); \tRETURN RSLT; END; <\/code><\/pre>\n<p>  \u0414\u0435\u043b\u0430\u044e \u0437\u0430\u043f\u0440\u043e\u0441:  <\/p>\n<pre><code class=\"sql\">SELECT * FROM TABLE( test_function( 2 )  ) <\/code><\/pre>\n<p>  \u041f\u043e\u043b\u0443\u0447\u0438\u043b:  <\/p>\n<pre><code>TBR-8051: User-defined functions are not permitted in the expression. at line 1, column 23: select * from table( test_function(2) ) <\/code><\/pre>\n<p>  \u041f\u043e\u043f\u044b\u0442\u0430\u043b\u0441\u044f \u0438\u0441\u043f\u0440\u0430\u0432\u0438\u0442\u044c \u043f\u043e\u043b\u043e\u0436\u0435\u043d\u0438\u0435:  <\/p>\n<pre><code class=\"sql\">select * from table( cast(test_function(2) as test_type_table) ) <\/code><\/pre>\n<p>  \u0420\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u0435\u0449\u0435 \u0445\u0443\u0436\u0435:  <\/p>\n<pre><code>TBR-8021: Invalid table name.  at line 1, column 47: select * from table( cast(test_function(2) as test_type_table) ) <\/code><\/pre>\n<p>  \u041d\u043e \u044d\u0442\u043e \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c \u0431\u043e\u0436\u0438\u0442\u0441\u044f \u0432\u043e\u0442-\u0432\u043e\u0442 \u0438\u0441\u043f\u0440\u0430\u0432\u0438\u0442\u044c, \u043d\u043e \u043f\u043e\u043a\u0430 \u0438\u043c\u0435\u0435\u043c \u0442\u043e, \u0447\u0442\u043e \u0438\u043c\u0435\u0435\u043c.<\/p>\n<p>  <u>\u041f\u0440\u043e\u0431\u043b\u0435\u043c\u0430 \u21165<\/u><br \/>  \u041f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435 \u043c\u0435\u043d\u0435\u0434\u0436\u0435\u0440\u043e\u0432 \u0431\u0430\u0437\u044b \u0434\u0430\u043d\u043d\u044b\u0445. \u042d\u0442\u043e \u0446\u0435\u043b\u0430\u044f \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0430 \u0438 \u043f\u043b\u044f\u0441\u043a\u0438 \u0441 \u0431\u0443\u0431\u043d\u0430\u043c\u0438. \u0411\u043e\u043b\u044c\u0448\u0438\u043d\u0441\u0442\u0432\u043e \u043e\u0431\u0449\u0430\u0442\u044c\u0441\u044f \u0441 \u0431\u0430\u0437\u043e\u0439 \u043d\u0435 \u0445\u043e\u0447\u0435\u0442 \u0438\u043b\u0438 \u0436\u0435 \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0430 \u043a\u0440\u0430\u0439\u043d\u0435 \u043d\u0435 \u043e\u0447\u0435\u0432\u0438\u0434\u043d\u0430\u044f. \u041f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c \u043e\u0431\u0435\u0449\u0430\u0435\u0442 \u0432\u043e\u0442-\u0432\u043e\u0442 \u0431\u0443\u0434\u0435\u0442 <i>tbrliboci.dll<\/i>, \u043d\u043e \u043f\u043e\u043a\u0430 \u0435\u0433\u043e \u043d\u0435\u0442.<\/p>\n<p>  <u>\u041f\u0440\u043e\u0431\u043b\u0435\u043c\u0430 \u21166<\/u><br \/>  \u041f\u043e\u043f\u044b\u0442\u0430\u043b\u0441\u044f <b>Oracle Forms<\/b> 9 \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0438\u0442\u044c \u043a <b>Tibero<\/b>. \u041f\u043e\u043b\u0443\u0447\u0438\u043b \u043e\u0448\u0438\u0431\u043a\u0443 \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u044c\u043d\u043e\u0439 \u0441\u0443\u043c\u043c\u044b \u043f\u0440\u0438 \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0438. \u0414\u0430\u043b\u044c\u0448\u0435 \u043f\u0440\u043e\u0434\u0432\u0438\u043d\u0443\u0442\u044c\u0441\u044f \u043d\u0435 \u0443\u0434\u0430\u043b\u043e\u0441\u044c.<\/p>\n<p>  <u>\u041f\u0440\u043e\u0431\u043b\u0435\u043c\u0430 \u21167<\/u><br \/>  \u041c\u043d\u0435 \u043e\u043a\u0430\u0437\u0430\u043b\u043e\u0441\u044c \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u043c\u0443\u0447\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c\u0441\u044f Explain Plan \u0431\u0435\u0437 <i>dbms_xplan.display <\/i>.<\/p>\n<p>  \u041f\u043e \u0438\u0442\u043e\u0433\u0430\u043c \u0442\u0435\u0441\u0442\u043e\u0432, \u0437\u0430\u0433\u0440\u0443\u0437\u043a\u0438 \u0433\u043e\u0442\u043e\u0432\u044b\u0445 \u043f\u0430\u043a\u0435\u0442\u043e\u0432 \u0438 \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u0433\u043e\u0442\u043e\u0432\u044b\u0445 <i>PL\/SQL<\/i> \u0441\u0438\u0441\u0442\u0435\u043c \u043c\u043e\u0433\u0443 \u0441\u043a\u0430\u0437\u0430\u0442\u044c, \u0447\u0442\u043e \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u043f\u0440\u043e\u0441\u0442\u044b\u0435 \u0438 \u043b\u0435\u0433\u043a\u0438\u0435 \u0441\u0438\u0441\u0442\u0435\u043c\u044b \u043f\u0435\u0440\u0435\u043d\u043e\u0441\u044f\u0442\u0441\u044f \u0445\u043e\u0440\u043e\u0448\u043e. \u0412\u0441\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442, \u043d\u0438\u043a\u0430\u043a\u0438\u0445 \u043f\u0440\u043e\u0431\u043b\u0435\u043c \u043d\u0435 \u0432\u043e\u0437\u043d\u0438\u043a\u0430\u0435\u0442. \u041f\u0438\u0441\u0430\u0442\u044c \u043d\u0430 \u043d\u0435\u0439 \u0441 0 \u043c\u043e\u0436\u043d\u043e \u0438, \u043d\u0430\u0432\u0435\u0440\u043d\u043e\u0435, \u0432\u043f\u043e\u043b\u043d\u0435 \u0443\u0441\u043f\u0435\u0448\u043d\u043e. \u0415\u0441\u043b\u0438, \u043a\u043e\u043d\u0435\u0447\u043d\u043e \u0437\u043d\u0430\u0435\u0448\u044c \u0430\u043d\u0433\u043b\u0438\u0439\u0441\u043a\u0438\u0439 \u0438 \u0433\u043e\u0442\u043e\u0432 \u0442\u0435\u0440\u043f\u0435\u0442\u044c, \u0447\u0442\u043e \u0447\u0442\u043e-\u0442\u043e \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u043d\u0430 \u0442\u0430\u043a \u043a\u0430\u043a \u0432 <b>Oracle<\/b>. \u0412 \u0441\u043b\u0443\u0447\u0430\u0435 \u0436\u0435 \u0431\u043e\u043b\u044c\u0448\u0438\u0445 \u0441\u0438\u0441\u0442\u0435\u043c, \u043a\u0430\u043a \u0438\u043d\u0442\u0435\u0440\u043d\u0435\u0442 \u043c\u0430\u0433\u0430\u0437\u0438\u043d, \u0430\u0431\u0441 \u0431\u0430\u043d\u043a\u0430, \u0441\u043a\u043b\u0430\u0434\u0441\u043a\u0438\u0435 \u0441\u0438\u0441\u0442\u0435\u043c\u0443 \u0443\u0447\u0435\u0442\u0430, \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u044b \u043d\u0430\u043b\u0438\u0447\u0438\u044f \u043f\u0430\u043a\u0435\u0442\u043e\u0432, \u043f\u043b\u043e\u0445\u043e\u0439 \u0440\u0430\u0431\u043e\u0442\u044b \u0441 <i>pipeline<\/i> \u0434\u0435\u043b\u0430\u044e\u0442 \u043f\u0440\u043e\u0446\u0435\u0441\u0441 \u043c\u0438\u0433\u0440\u0430\u0446\u0438\u0438 \u043c\u0443\u0447\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u043c \u0438 \u0441\u043e\u043f\u0440\u044f\u0436\u0435\u043d\u043d\u044b\u043c \u0441 \u043f\u0435\u0440\u0435\u043f\u0438\u0441\u044b\u0432\u0430\u043d\u0438\u0435\u043c \u0433\u043e\u0442\u043e\u0432\u043e\u0433\u043e \u043a\u043e\u0434\u0430, \u0447\u0442\u043e \u043d\u0435 \u043e\u0447\u0435\u043d\u044c \u043f\u0440\u0438\u044f\u0442\u043d\u043e \u0438 \u0438\u043d\u043e\u0433\u0434\u0430 \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u0437\u0430\u0442\u0440\u0430\u0442\u043d\u043e.<\/p>\n<p>  \u0412-\u0446\u0435\u043b\u043e\u043c \u043c\u043d\u0435 \u043a\u0430\u0436\u0435\u0442\u0441\u044f, \u0447\u0442\u043e \u0443 \u044d\u0442\u043e\u0433\u043e \u043f\u0440\u043e\u0434\u0443\u043a\u0442\u0430 \u0435\u0441\u0442\u044c \u0448\u0430\u043d\u0441 \u043d\u0430 \u0432\u044b\u0436\u0438\u0432\u0430\u043d\u0438\u0435. \u0418 \u0441\u0435\u0439\u0447\u0430\u0441 \u0443\u0436\u0435, \u043a\u0430\u043a \u044f \u0433\u043e\u0432\u043e\u0440\u0438\u043b \u0432 \u043f\u0435\u0440\u0432\u043e\u0439 \u0447\u0430\u0441\u0442\u0438 \u0435\u0441\u0442\u044c \u0440\u043e\u0441\u0441\u0438\u0439\u0441\u043a\u0438\u0435 \u043a\u043e\u043c\u043f\u0430\u043d\u0438\u0438, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0441 \u043d\u0438\u043c \u0440\u0430\u0431\u043e\u0442\u0430\u044e\u0442. \u0420\u0430\u0431\u043e\u0442\u0430\u044e\u0442 \u0442\u0430\u043c \u043d\u0430\u0448\u0438 \u043f\u0430\u0440\u043d\u0438, \u0430 \u0442\u043e\u043b\u043a\u043e\u0432\u043e\u0439 \u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u0438 \u043d\u0430 \u0440\u0443\u0441\u0441\u043a\u043e\u043c \u044f\u0437\u044b\u043a\u0435 \u043d\u0435\u0442. \u041f\u043e\u044d\u0442\u043e\u043c\u0443 \u043e\u0447\u0435\u043d\u044c \u0445\u043e\u0447\u0435\u0442\u0441\u044f, \u0447\u0442\u043e\u0431\u044b \u0432\u043e\u043a\u0440\u0443\u0433 \u0434\u0430\u043d\u043d\u043e\u0433\u043e \u043f\u0440\u043e\u0434\u0443\u043a\u0442\u0430 \u043d\u0430\u0447\u0430\u043b\u043e \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u0442\u044c\u0441\u044f \u0440\u0443\u0441\u0441\u043a\u043e\u044f\u0437\u044b\u0447\u043d\u043e\u0435 \u0441\u043e\u043e\u0431\u0449\u0435\u0441\u0442\u0432\u043e \u043b\u044e\u0434\u0435\u0439, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043c\u043e\u0433\u0443\u0442 \u043f\u043e\u0434\u0441\u043a\u0430\u0437\u0430\u0442\u044c, \u043f\u043e\u043c\u043e\u0447\u044c \u0438\u043b\u0438 \u043f\u043e\u0434\u0435\u043b\u0438\u0442\u044c\u0441\u044f \u043e\u043f\u044b\u0442\u043e\u043c \u0440\u0430\u0431\u043e\u0442\u044b \u0441 \u044d\u0442\u043e\u0439 \u0441\u0443\u0431\u0434 <b> Tibero<\/b>.               <\/p>\n<div class=\"clear\"><\/div>\n<p> \u0441\u0441\u044b\u043b\u043a\u0430 \u043d\u0430 \u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b \u0441\u0442\u0430\u0442\u044c\u0438 <a href=\"http:\/\/habrahabr.ru\/post\/270395\/\"> http:\/\/habrahabr.ru\/post\/270395\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<p>       \u0414\u043b\u044f \u0442\u0435\u0441\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f \u0441\u043e\u0432\u043c\u0435\u0441\u0442\u0438\u043c\u043e\u0441\u0442\u0438 <b>Tibero<\/b> c <b>Oracle<\/b> \u044f \u0440\u0435\u0448\u0438\u043b \u043f\u0440\u043e\u0432\u0435\u0440\u0438\u0442\u044c, \u0431\u0443\u0434\u0443\u0442 \u043b\u0438 \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c \u043d\u0430 \u043d\u0435\u043c \u043b\u044e\u0431\u0438\u043c\u044b\u0435 \u043c\u043d\u043e\u044e <b>PL\/SQL<\/b> \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438, \u0430 \u0438\u043c\u0435\u043d\u043d\u043e: <br \/>  <a href=\"https:\/\/github.com\/mortenbra\/alexandria-plsql-utils\/\">https:\/\/github.com\/mortenbra\/alexandria-plsql-utils\/<\/a><br \/>  \u0422\u0435\u0441\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u043d\u0430\u0447\u0430\u043b\u043e\u0441\u044c \u0441 <i>JSON_UTIL_PKG<\/i>. \u041e\u0447\u0435\u043d\u044c \u043f\u043e\u043b\u0435\u0437\u043d\u0430\u044f \u0444\u0443\u043d\u043a\u0446\u0438\u044f \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u044e\u0449\u0430\u044f \u0431\u044b\u0441\u0442\u0440\u043e \u0433\u0435\u043d\u0435\u0440\u0438\u0440\u043e\u0432\u0430\u0442\u044c JSON-\u043e\u0442\u0432\u0435\u0442.   <\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[],"tags":[],"class_list":["post-267726","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/267726","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=267726"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/267726\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=267726"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=267726"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=267726"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}