首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    对于Oracle兼容,我们手拿把掐

    Oracle兼容性是一个系统性的工作,不能满足于简单的SQL语法/语义兼容,主要有引擎、生态工具两个方面。...PL/SQL语法兼容 PL/SQL语法兼容Oracle 存储过程、函数的创建,如:以IS作为PLSQL块定义开始、可以用/作为定义结束 存储过程、函数支持COMMIT、ROLLBACK事务控制 兼容游标属性支持...PL/SQL - 语法 Oracle存储过程/函数语法特点: 以IS作为代码块的起始定义 使用/作为结束定义结束 使用END procname作为函数代码块结束、等 PostgreSQL存储过程/函数语法特点...PL/SQL - 自治事务 自治事务: 自治事务由主事务启动;自治事务运行时,主事务挂起 自治事务与启动它的主事务相互独立 自治事务可以用在存储过程、函数、匿名块以及触发器中 如果自治事务与主事务产生锁冲突...JDBC实现兼容 1) 适配Oracle数据库的Date、CLOB、BLOB、VARCHAR2、NVARCHAR2、ROWID等类型 2) 适配Oracle数据库方式创建函数、存储过程等操作 3.

    2K20

    Oracle_12C的新特性

    这里我们来领略下Tom眼中的12个特性增强: #1 Even better PL/SQL from SQL, 直接在SQL中嵌入PL/SQL对象并运行,猜测可能优化了SQL engine 和 PL/SQL...32k,和其在PL/SQL中的变量类型一样了,当然过长可能导致像LOB那样OUT OF LINE存放 #4 Easy Top-N and pagination queries ,更易用的Top-N和页码查询...临时UNDO撤销,临时表的UNDO数据可以放到TEMP中,有助于减少 UNDO表空间中的undo数据,进一步减少redo的产生, 从而使得Active Data Guard中的临时表允许做DML 设置方法为...用户连接到Pluggable Databases时看到的是一个单一数据库和从前一样 新的管理模式 数据库管理员DBA可以连接到Pluggable Database并仅仅管理该数据库 超级DBA可以连接到容器数据库并如同管理单系统镜像那样管理...加速现有数据库打补丁和升级的速度 从原有的DBA的职责中分离部分责任到应用管理员 集中式管理多个数据库 提升RAC的扩展性和故障隔离 与Oracle SQL Developer 和Oracle Enterprise

    90590

    Oracle 20c 新特性详解:SQL Macro 宏 SCALAR TABLE 模式带来的敏捷和便利

    墨墨导读:在 Oracle 20c 中,SQL的宏支持 - SQL Macro 为 SQL 开发带来了进一步的敏捷和便利,在这篇文章中,我们来详细了解一下 SQL Macro 的特性用法。...在 20c 中引入的 SQL Macro 支持两种宏类型,Scalar 和 Table 类型。...–在PL / SQL和SQL之间没有上下文切换; –在与外部查询相同的快照下执行 PL / SQL 函数内部的查询; –使用标量宏的WHERE子句谓词可被下推到Exadata中的存储侧谓词评估– 这对PL...–对于给定的表,返回一个查询,该查询会跳过给定名称或数据类型的列 –传递通用谓词(例如rownum <n), –为现有语法提供功能语法 ?...最后总结一下 SQL Macro 的意义: • SQL宏提供了一个基于SQL的简单框架,用于封装业务/技术逻辑 –无需在查询中调用自定义PL / SQL过程和函数 • 可以在SQL语句内的任何地方使用;

    2.1K20

    Oracle 开放源代码项目

    Oracle 开放源代码项目 这是无数个可扩展、使用以及构建于 Oracle 技术的开放源代码项目中的一个简短的示例。...包括 PL/SQL 调试程序、突出语法主题的 SQL 工作表、数据库浏览器以及一整套数据库管理员工具。...完全实施 ORACLE BLOB 和 CLOB 字段。可能执行存储过程和部分 PL/SQL 代码。内存中快速而功能强大的表。...SchemaMap Schema Map 是一种 java j2ee war 文件,用于在 oracle 数据库中显示表、列、触发器、约束、索引和序列的元数据。支持 10 种查询缓冲器以及元数据浏览。...颠倒指定的对象列表的工程师 DDL。整理整个表空间。根据您的标准重新调整表/索引。为用户 X 创建用户 Y 的权限,等等。

    3.1K80

    走向云端:Oracle SQL Developer Web 即将上线!

    引言:Oracle SQL Developer 是一款免费的桌面应用,是数据库的图形用户界面,它具有 DBA 的全部功能,能够对 PL/SQL 进行开发,还有命令行开发页面,全世界有近500万用户在...在最近的一次更新中,一个新的尝试:Oracle SQL Developer Web 版本,将要上线了!首先基于Oracle Cloud提供服务,随后将会发布私有版本。...Oracle SQL Developer Web 的功能 运行SQL、SQL+脚本 创建编辑表向导 为数据库对象绘制关系图 实现实时的SQL监控 警报日志的监控、存储信息的收集、基本DB行为的概览 Oracle...SQL Developer Web 工作表 支持将 SQL、PL/SQL 的运行结果以 CSV、JSON、XML 格式输出 计划解释、自动追踪 SQL 历史记录召回 代码联想、错误纠正 Oracle...Oracle SQL Developer Web 的自动历史追踪功能 ? 产生匿名块来运行你的存储过程、函数,共有八种不同的形式来适应各种类型的数据 ? 将多个对象模块在同一个页面中处理 ?

    1K20

    数据库常见面试题及答案(数据库面试常见问题)

    存储过程是一个预编译的SQL语句,优点是允许模块化的设计,就是说只需创建一次,以后在该程序中就可以调用多次。如果某次操作需要执行多次SQL,使用存储过程比单纯SQL语句执行要快。...function 程序头部声明时不需描述返回类型 程序头部声明时要描述返回类型,而且PL/SQL块中至少要包括一个有效的return语句 可以使用in/out/in out 三种模式的参数 可以使用...in/out/in out 三种模式的参数 可作为一个独立的PL/SQL语句来执行 不能独立执行,必须作为表达式的一部分调用 可以通过out/in out 返回零个或多个值 通过return语句返回一个值...在普通SQL语句的使用上增加了编程语言的特点,所以PL/SQL把数据操作和查询语句组织在PL/SQL代码的过程性单元中,通过逻辑判断、循环等操作实现复杂的功能或者计算。...PL/SQL 只有 Oracle 数据库有。 MySQL 目前不支持 PL/SQL 的。 25、序列的作用 Oracle使用序列来生成唯一编号,用来处理一个表中自增字段。

    4.1K10

    游标和触发器

    定义REF CURSOR类型和游标变量 为了在PL/SQL块中定义游标变量,必须首先定义REF CURSOR类型,然后才能定义游标变量。 ​...在ORACLE系统里,触发器类似过程和函数,都有声明,执行和异常处理过程的PL/SQL块。...一个表上最多可有12个触发器,但同一时间、同一事件、同一类型的触发器只能有一个。并各触发器之间不能有矛盾。 3. 在一个表上的触发器越多,对在该表上的DML操作的性能影响就越大。 4....20% -- 加薪比例以现有的sal为标准 技能训练点: 更改游标的当前行 5.触发器的使用 技能训练点: 使用触发器实现自动编号,在SQL SERVER数据库中,如果将字段属性设置为...在表tb_stud_score中创建行级触发器,命名为“tr_stud_score” Ø 本章总结 Ø Oracle游标和触发器 n Oracle游标 n Oracle触发器 巩固练习 一.选择题 1.

    6310

    javaweb-oracle-2-58

    文章目录 视图 视图的作用 索引 单列索引 复合索引 pl/sql编程语言 pl/sql中的if判断 pl/sql中的loop循环 游标 存储过程 存储函数的使用 out类型参数如何使用...视图为多表查询提供了上层封装,可以屏蔽某些字段的查询,可以统一操作各表,防止各表查询等操作不及时,信息不统一 索引 —索引 –索引的概念:索引就是在表的列上构建一个二叉树,相当于一本书的目录 —-达到大幅度提高查询效率的目的...pl/sql编程语言 pl/sql编程语言是对sql语言的扩展,使得sql语言具有过程化编程的特性。 —pl/sql编程语言比一般的过程化编程语言,更加灵活高效。...----------如果存储过程想实现有返回值的业务,我们就必须使用out类型的参数。...----------即便是存储过程使用了out类型的参数,起本质也不是真的有了返回值, ----------而是在存储过程内部给out类型参数赋值,在执行完毕后,我们直接拿到输出类型参数的值。

    96620

    Oracle数据库该如何着手优化一个SQL

    而本文是假设SQL本身合理,从Oracle提供给我们的一些技术手段来简单介绍下Oracle数据库,该如何使用一些现有的技术来优化一个SQL执行的性能。...Tuning 基础概述04 - Oracle 表的类型及介绍 SQL Tuning 基础概述05 - Oracle 索引类型及介绍 SQL Tuning 基础概述06 - 表的关联方式:Nested...SQL Profile SQL Profile是10g中的新特性,作为自动SQL调整过程的一部分。...它的最大优点之一就是在不修改SQL语句和会话执行环境的情况下影响查询优化器的决定。SQL Profile中包含的并非单个执行计划的信息,SQL Profile不会固定一个SQL语句的执行计划。...当表的数据增长或者索引创建、删除,使用同一个SQL Profile的执行计划可能会改变,而存储在SQL Profile中的信息会继续起作用。

    95040

    Oracle 数据库拾遗(一)

    在创建或修改表时,可以通过定义 PRIMARY KEY 约束来创建主键。 一个表只能有一个 PRIMARY KEY 约束,并且 PRIMARY KEY 约束中的列不能接受空值。...唯一性约束即 UNIQUE 约束,在 SQL 基本表中,可以使用 UNIQUE 约束确保在非主键列中不输入重复的值。...在 Oracle PL/SQL 中,DEFAULT 关键字用来指定某个字段的默认值。在 MS T-SQL 中将 DEFAULT 作为约束操作,而 Oracle PL/SQL 将其认为是一个字段值。...需要注意: 并不是所有数据类型的数据值都可以作为默认值。...在SQL 中,DEFAULT 关键字后的值只能为下列三种值中的一种: 常量值 NULL 系统函数 同时,由于 Oracle 中 DEFAULT 不是约束,因此在使用 SELECT 显示表的约束时,默认值不会显示出来

    1.1K20

    ​oracle 笔记

    pl/sql中的if判断 pl/sql中的loop循环 游标 存储过程 测试f_yearsal out类型参数如何使用 测试p_yearsal in和out类型参数的区别是什么?...ORACLE 数据库是目前世界上使用最为广泛的数据 库管理系统,作为一个通用的数据库系统,它具有完整的数据管理功能; 作为一个关系数据库, 它是一个完备关系的产品;作为分布式数据库它实现了分布式处理功能...注:表的数据,是有用户放入某一个表空间的,而这个表空间会随机把这些表数据放到 一个或者多个数据文件中。 由于 oracle的数据库不是普通的概念,oracle是有用户和表空间对数据进行管理和存放的。...但是表不是有表空间去查询的,而是由用户去查的。因为不同用户可以在同一个表空间建立同 一个名字的表!这里区分就是用户了! ? ? 二、 创建表空间 表空间?ORACLE数据库的逻辑单元。...在两张表中我们发现有一个共同的字段是 depno,depno就是两张表的关联的字段,我们可以使用这个字段来做限制条件,两张表的关联查询字段一般是其中一张表的主键,另一张表的 外键。

    89921

    Oracle笔记

    在oracle中,数据     完整性可以用约束、触发器、应用程序(过程、函数)三种方法来实现,在这三种方法     中,因为约束易于维护,并且具有最好的性能,所以作为维护数据完整性的首选。...emp_cursor    (4)当定义例外时,建议用e_作为前缀 e_error 53.pl/sql是以块(block)为基本单位的,编写pl/sql程序实际上就是编写pl/sql块。...要完     成相对简单的应用功能,可能只需要编写一个pl/sql块;但是如果要想实现复杂的功       能,可能需要在一个pl/sql块中嵌套其它的pl/sql块。...可以使用create trigger来建立触发器、 62.pl/sql程序中包括有:    (1)标量类型(scalar)    (2)复合类型(composite):用于存放多个值的变量。...69.常见预定义例外:   (1)case_not_found:在开发pl/sql块中编写case语句时,如果在when子句      中没有包含必须的条件分支,就会出发case_not_found

    1.4K20

    存储过程和函数

    程序包用于将逻辑相关的PL/SQL块或元素组织在一起,作为一个完整的单元存储在数据库中,用名称来标识程序包。程序包具有面向对象的程序设计语言的特点,是对PL/SQL块或元素的封装。...核心技能部分​ 5.1 子程序简介 子程序是指被命名的PL/SQL块,这种块可以带有参数,可以在不同应用中多次调用。PL/SQL有两种类型的子程序:过程和函数。...当指定参数数据类型时,不能指定其长度。RETURN子句用于指定函数返回值的数据类型,is或as用于开始一个PL/SQL块。...以下通过创建用于产生一个随机数的函数为例,说明创建无参函数的方法 函数创建完之后,我么可以通过一个pl/sql块调用 在图4.1.15所示代码中,num用来接收函数的返回值。...Ø 包 (Package)用于组合逻辑相关的 PL/SQL类型 (例如TABLE类型和 RECORD类型)、PL/SQL项 (例如游标和游标变量)和PL/SQL子程序 (例如过程和函数)。

    7410

    Oracle PLSQL基础语法学习15:静态表达式

    Oracle PL/SQL基础语法学习15:静态表达式 Static Expressions(静态表达式)介绍 静态表达式是一个在PL/SQL语言中用于描述一个特定值的表达式。...在PL/SQL中,静态表达式可以使用常量、字面量、枚举类型等,可以使用任意组合来描述目标值。.../SQL代码创建了一个名为my_debug的包,其中包含两个静态常量debug和trace,类型为BOOLEAN,并在其值上分别定义为TRUE,用于控制多个PL/SQL单元中的调试和跟踪。...在存储过程的主体中,使用 EXECUTE IMMEDIATE 语句来执行了一个 SQL 查询,查询的是名为 table1 的表的所有数据。...在存储过程的主体中,使用 EXECUTE IMMEDIATE 语句来执行了一个 SQL 查询,查询的是名为 table1 的表的所有数据。

    19450

    Oracle PLSQL语句基础学习笔记(上)

    PL/SQL 不是一个独立的产品,他是一个整合到ORACLE服务器和ORACLE工具中的技术,可以把PL/SQL看作ORACLE服务器内的一个引擎,sql语句执行者处理单个的sql语句,PL/SQL引擎处理...当PL/SQL程序块在PL/SQL引擎处理时,ORACLE服务器中的SQL语句执行器处理pl/sql程序块中的SQL语句。...PL/SQL支持所有SQL数据类型和所有SQL函数,同时支持所有ORACLE对象类型 PL/SQL块可以被命名和存储在ORACLE服务器中,同时也能被其他的PL/SQL程序或SQL命令调用,任何客户/服务器工具都能访问...可以使用ORACLE数据工具管理存储在服务器中的PL/SQL程序的安全性。可以授权或撤销数据库其他用户访问PL/SQL程序的能力。...LOB数据类型支持任意访问方式,LONG只支持顺序访问方式。LOB存储在一个单独的位置上,同时一个”LOB定位符”(LOB locator)存储在原始的表中,该定位符是一个指向实际数据的指针。

    2.8K10

    Java学习路线

    目标: 掌握mysql,Oracle在各个平台上的安装及使用 Mysql数据库基础 1.mysql概述、优点、运行原理及内存结构 2.mysql数据类型 3.mysqlDDL语句的使用 4.SQL语言的使用...5.DML语句的介绍及使用 6.SQL事务 7.SQL查询机制、查询基础、技巧、查询优化; Mysql数据库高级 1.mysql数据库引擎分类 2.mysql事务 3.mysql表 4.mysql数据类型...5.mysql视图 6.mysql索引 7.mysql分页 8.SQL语句优化技巧 Oracle实战 1.Oracle安装与调试 2.Oracle数据类型 3.Oracle与MySQL对比 4.Oracle...数据结构概述 5.Oracle运行原理 6.Oracle内存结构 7.Oracle表空间 8.用户,表,序列的创建及使用 9.Oracle索引 10.Oracle分区表的创建及使用 PL/SQL实战 1...AOP实现原理【aop编辑思想、aop在spring中的使用、cglib和jdk动态代理】   Transaction事务处理【事务隔离级别】   SpringMVC【DispatcherServlet

    1K20

    Oracle-Soft ParseHard ParseSoft Soft Parse解读

    概述 在Oracle中存在两种类型的SQL语句: 一类为 DDL语句(数据定义语言)CREATE,DROP,ALTER,他们是从来不会共享使用的,也就是每次执行都需要进行硬解析。...---- 语义及权限检查 语法正确的SQL语句在解析的第二个步骤就是判断该SQL语句所访问的表及列是否准确?用户是否有权限访问或更改相应的表或列?...现有数据库中SQL语句的HASH值我们可以通过访问vsql、vsqlarea、v ? 如果SQL语句的HASH值一致,那么ORACLE事实上还需要对SQL语句的语义进行再次检测,以决定是否一致。...当发现有相同的以后解析器就不再对新的Sql在此解析而直接用之前解析好的结果了。这里就节约了解析时间以及解析时候消耗的CPU资源。尤其是在OLTP中运行着的大量的短小Sql,效果就会比较明显了。...该查询只编译一次,随后会把查询计划存储在一个共享池(库缓存)中,以便以后获取和重用这个查询计划。

    2.3K20
    领券