功能 |
Oracle语法 |
MariaDB语法 |
Oracle执行结果 | MariaDB执行结果 |
|
|---|---|---|---|---|---|
创建存储过程 |
未使用参数和变量 |
CREATE PROCEDURE p1 AS BEGIN NULL; END p1; / |
DELIMITER // CREATE PROCEDURE p1() IS BEGIN NULL; END // DELIMITER ; |
![]() |
![]() |
创建存储过程 |
带有参数和变量 |
CREATE PROCEDURE p1(p_input IN NUMBER, p_output OUT NUMBER) AS v_variable VARCHAR2(100); BEGIN v_variable := 'Hello, World!'; p_output := p_input * 2; END; / |
DELIMITER // CREATE PROCEDURE p1(INOUT p_input INT) BEGIN DECLARE v_variable VARCHAR(100); SET v_variable = 'Hello, World!'; SET p_input = p_input * 2; END // DELIMITER ; |
![]() |
![]() |
创建存储函数 |
CREATE FUNCTION f1(a VARCHAR2) RETURN VARCHAR2 IS v_result VARCHAR2(100); BEGIN `v_result := a |
' appended text'; RETURN v_result; END; /` |
DELIMITER // CREATE FUNCTION f1(a VARCHAR(100)) RETURN VARCHAR(100) IS v_result VARCHAR(100); BEGIN SET v_result = CONCAT(a, ' appended text'); RETURN v_result; END // DELIMITER ; |
||
| 游标 | 带有FOR 循环显式游标 | CREATE TABLE t1 ( a NUMBER, b NUMBER ); INSERT INTO t1 (a, b) VALUES (1, 2); INSERT INTO t1 (a, b) VALUES (3, 4); INSERT INTO t1 (a, b) VALUES (5, 6); CREATE OR REPLACE PROCEDURE p1 AS a_val t1.a%TYPE; b_val t1.b%TYPE; CURSOR cur IS SELECT a, b FROM t1; BEGIN FOR rec IN cur LOOP a_val := rec.a; b_val := rec.b; `DBMS_OUTPUT.PUT_LINE('a: ' |
a_val | ||
| 游标 | 带有 FOR 循环的隐式游标 | CREATE OR REPLACE PROCEDURE p1 IS BEGIN FOR rec IN (SELECT a, b FROM t1) LOOP `DBMS_OUTPUT.PUT_LINE('A = ' |
rec.a | ||
| 游标 | 带有参数和 FOR 循环的游标 | CREATE OR REPLACE PROCEDURE process_cursor(prm_a IN INT, prm_b IN INT) IS CURSOR c IS SELECT a, b FROM t1 WHERE a = prm_a AND b = prm_b; BEGIN FOR rec IN c LOOP `DBMS_OUTPUT.PUT_LINE('A: ' |
rec.a | ||
| 游标 | s %ISOPEN, %ROWCOUNT, %FOUND, %NOTFOUND方式显式游标属性 |
SET SERVEROUTPUT ON; BEGIN DECLARE CURSOR c IS SELECT a, b FROM t1; v_a t1.a%TYPE; v_b t1.b%TYPE; BEGIN OPEN c; IF c%ISOPEN THEN DBMS_OUTPUT.PUT_LINE('Cursor is open.'); ELSE DBMS_OUTPUT.PUT_LINE('Cursor is not open.'); END IF; LOOP FETCH c INTO v_a, v_b; EXIT WHEN c%NOTFOUND; `DBMS_OUTPUT.PUT_LINE('A: ' |
v_a |
MariaDB 设置 sql_mode=Oracle 和 Oracle 对比验证
尚雷55802024-12-22 9:29
相关推荐
刘冲溟3 分钟前
解决 idea 编辑sql文件换行后自动缩进的问题是阿威啊18 分钟前
企业级的RDD、 Spark SQL、DataFrame、Dataset使用场景介绍IvanCodes1 小时前
openGauss 高级特性:优化器、存储引擎与分区管理航Hang*1 小时前
第3章:复习篇——第5-2节:数据库编程2islandzzzz1 小时前
SQL学习应用工作场景(2)--执行优先级+语法顺序+保留2位小数hopsky1 小时前
SQL语义校验方案航Hang*1 小时前
第3章:复习篇——第5-1节:数据库编程1Mr.朱鹏1 小时前
分布式接口幂等性实战指南【完整版】一个天蝎座 白勺 程序猿1 小时前
破局困境:Oracle迁移金仓KingbaseES数据库的深度实践航Hang*1 小时前
第3章:复习篇——第6节:数据库安全管理与日常维护


