乍一看,确实有些含糊,Oracle中往往小问题蕴含着大智慧,如何破云见日?...前三个均为表数据总量,第四个SQL结果是99999,仅包含非空记录数据量,说明若使用count(允许空值的列),则统计的是非空记录的总数,空值记录不会统计,这可能和业务上的用意不同。...,如果数据表字段多、数据量大,显然主键索引占用的数据块要比数据表占用的数据块少,因此仅索引扫描,而且是全索引快速扫描(多块读),消耗的资源会更少些了。...再看前三个SQL对应的trace,第1个SQL, ? ? 第二个SQL, ? ? 第三个SQL, ? ?...可以看出一个问题,就是这三个SQL经过Oracle转换,执行的SQL其实都是select count(*) from bisal,因此对应的执行计划成本选择,这三个SQL相同, ?
在 Oracle 23c 中,可以将列定义为 DEFAULT ON NULL FOR INSERT AND UPDATE。这会将更新语句中的显式空值替换为默认值。...在 12c 之前的版本中,只有在插入语句中未显式引用具有默认值的列时,才会在插入操作期间应用默认值。...Oracle 23c 为 UPDATE 操作带来了类似的默认值处理。 DEFAULT 最初,只有在插入语句中未显式引用具有默认值的列时,才会在 INSERT 操作期间应用默认值。...> 正如预期的那样,仅当插入语句中省略描述字段时才应用默认值。...23c 中添加了 DEFAULT ON NULL FOR INSERT ONLY 形式,以允许我们显式声明仅插入,但它在功能上与 DEFAULT ON NULL 相同。
第7章 创建计算字段 7.1 计算字段 存储在数据库表中的数据一般不是应用程序所需要的格式,下面举几个例子。 需要显示公司名,同时还需要显示公司的地址,但这两个信息存储在不同的表列中。...字段(field) 基本上与列(column)的意思相同,经常互换使用,不过数据库列一般称为列,而术语字段通常与计算字段一起使用。...从客户端(如应用程序)来看,计算字段的数据与其他列的数据的返回方式相同。 提示:客户端与服务器的格式 在 SQL 语句内可完成的许多转换和格式化工作都可以直接在客户端应用程序内完成。...Access 和 SQL Server 使用+号。 DB2、Oracle、PostgreSQL、SQLite 和 Open Office Base 使用||。...按月份过滤,可以进行相同的处理,使用 AND 操作符可以进行年和月份的比较。 大多数 DBMS 具有比较日期、执行基于日期的运算、选择日期格式等的函数。
关键要点 仅从ACID或非ACID角度考虑问题是不够的,你应知道你的数据库支持何种事务隔离级别。 一些数据库宣称自己具有“最终一致性”,但却可能对重复查询返回不一致的结果。...主索引在大多数数据库中被称为“聚束索引”或“堆”(该术语在各NoSQL数据库中各不相同)。因而当执行插入操作时,需要在每个索引中插入一行。当执行更新操作时,数据库引擎仅需访问指到被改变列的索引。...类似于PostgreSQL,Oracle并不提供未提交读,永不允许脏读。 可重复读并不在Oracle的支持列表中。如果你需要在Oracle中具有该行为,你的事务隔离级别需要被设置为可序列化。...对其它两种事务隔离级别的更多信息,参见Oracle官方文档第13章“数据并发和一致性”。 DB2中的事务隔离级别 DB2具有四种隔离级别,分别称为可重复读、读稳定性、游标稳定性和未提交读。...Cassandra中的事务隔离级别 Cassandra 1.0隔离了甚至是对一行的写入操作。因为字段是被逐一更新的,所以可以终止对旧值和新值混合在一起的记录的读取。
用字段NULL值是没有值的字段。甲NULL值是从零值或包含空格的字段不同。 具有NULL值的字段是在记录创建过程中留为空白的字段。...NOT NULL约束用于确保字段中的值不能为NULL 49.什么是CHECK约束? CHECK约束用于限制一列或多列接受的值。 例如,“年龄”字段应仅包含大于18的值。...SQL中的聚合函数是什么? SQL聚合函数返回单个值,该值是根据列中的值计算得出的。...SQL中的一些汇总函数如下 AVG()–此函数返回平均值 COUNT()–此函数返回行数 MAX()–此函数返回最大值 MIN()–此函数返回最小值 ROUND()–此函数将数字字段舍入为指定的小数位数...这三个功能以相同的方式工作。这些函数用于将NULL值替换为另一个值。Oracle开发人员使用NVL函数,MySQL开发人员使用IFNULL函数,而SQL Server开发人员使用ISNULL函数。
视图名称和表名称遵循相同的命名约定,并对不合格的名称执行相同的架构名称解析。同一模式中的视图和表不能具有相同的名称。可以使用$SYSTEM.SQL.ViewExists()方法确定视图名称是否已存在。...在更新或插入期间,在为基础表的字段计算了所有默认值和触发的计算字段之后,并在常规表验证(必需字段、数据类型验证、约束等)之前,检查WITH CHECK选项条件。...仅当在SELECT中明确指定时才显示:SELECT *,%VID AS ViewID FROM Sample.VSrStaff%VID可用于进一步限制SELECT从视图返回的行数,如以下示例所示:SELECT...WHERE View_Name='VSrStaff'可以使用管理门户网站SQL界面中的“目录详细信息”选项卡为单个视图显示与INFORMATION.SCHEMA.VIEWS相同的信息。...视图的“目录详细信息”包括每个视图字段的定义(数据类型,最大长度,最小值/最大值等),以及INFORMATION.SCHEMA视图类未提供的详细信息。
:Oracle估计的当前操作的返回结果集行数 字节(Bytes):执行该步骤后返回的字节数 耗费(COST)、CPU耗费:Oracle估计的该步骤的执行成本,用于说明SQL执行的代价,理论上越小越好(该值可能与实际有出入...ROWID是由Oracle自动加在表中每行最后的一列伪列,既然是伪列,就说明表中并不会物理存储ROWID的值; 你可以像使用其它列一样使用它,只是不能对该列的值进行增、删、改操作; 一旦一行数据插入后,...不过遗憾的是,由于返回的结果集中包括所有字段,所以通常的执行计划中,即使连接列存在索引,也不会进入到执行计划中,除非进行一些特定列处理(如仅仅只查询有索引的列等)。...Ⅱ:开始读取匹配表(Probed Table)的数据,对其中每行数据的连接操作关联列都使用同上的Hash函数,定位Build Table里使用Hash函数后具有相同值数据所在的Hash Bucket。...Ⅱ:读取匹配表数据并对每行的连接操作关联列使用同上的Hash函数,定位Bitmap上Build Table里使用Hash函数后具有相同值数据所在的Bucket。
如果您需要在一个事务中多次重复相同的读取操作,并且想要合理地确定它总是返回相同的值,则需要在整个持续时间内保持读取锁定。使用“可重复读取”隔离级别时,将自动为您完成此操作。...这些行将被锁定,但是没有什么阻止添加符合条件的新行。术语“幻像”适用于第二次执行查询时出现的行。 为了绝对确保同一事务中的两次读取返回相同的数据,可以使用Serializable隔离级别。...如果上述更新语句是在您加州记录的时间与您阅读德克萨斯州记录的时间之间执行的,则您可以看到客户1253两次;一次使用旧值,一次使用新值。 ? 漏读的发生方式相同。...Oracle中的隔离级别 Oracle仅支持3个事务级别:读已提交,可序列化和只读。在Oracle中,“默认值为读已提交”,它使用快照语义。...Cassandra的隔离级别 在Cassandra 1.0中,甚至没有隔离写入单个行。字段是一一更新的,因此您最终可能会读取包含新旧值的记录。 从1.1版开始,Cassandra提供“行级隔离”。
Oracle兼容性说明数据类型兼容本节主要介绍 HHDB Server与Oracle 数据库中数据类型的详细兼容对比信息。...8.0版本支持,不支持alter语法中字段默认值为sysdateTRUNC(date,fmt)限制支持支持fmt格式,不支持多表函数嵌套转换函数Oracle数据库函数HHDB Server是否支持备注BIN_TO_NUM...使用此功能需开启Oracle语法解析,仅当数据库用户开启了“该用户执行SQL时是否按Oracle语法优先解析”开关,或打开参数“enableOracleFunction”才支持此同义词语法的功能。...此章节列出计算节点支持的INFORMATION_SCHEMA中的表与其特殊处理内容如下:表名称特殊处理character_sets仅返回计算节点支持的字符集与校对集数据collations仅返回计算节点支持的字符集与校对集数据...table_privileges返回空集triggers返回空集user_privileges返回计算节点中所有的数据库用户权限信息,TABLE_CATALOG字段固定值为def, GRANTEE字段值与
共享SQL语句 为了不重复解析相同的SQL语句,在第一次解析之后,ORACLE将SQL语句存放在内存中。...当你向ORACLE 提交一个SQL语句,ORACLE会首先在这块内存中查找相同的语句。...(Column歧义指的是由于SQL中不同的表具有相同的Column名,当SQL语句中出现这个Column时,SQL解析器无法判断这个Column的归属) tiger: 使用别名是个好习惯,应该写到开发规范里面..., 需要注意关联字段是否为null,主查询关联字段值为null时的记录是否需要返回. 19....举例:如果唯一性索引建立在表的A列和B列上,并且表中存在一条记录的A,B值为(123,null) ,ORACLE将不接受下一条具有相同A,B值(123,null)的记录(插入).
编辑手记:在Oracle数据库中,版本变化带来的一大挑战就是SQL执行计划的稳定性,为此Oracle经历了从Outline到Profile的特性演进,本文带大家一起来了解一下Profile的特性和使用。...从上面的数据可以看出: 第2、3条 SQL 的 exact_matching_signature 相同,第7、8、9、10条 SQL 的 exact_matching_signature 相同。...第2、3条 SQL 的 force_matching_signature 相同,第4、5条 SQL 的 force_matching_signature 相同,第7、8、9、10条的 SQL 的 force_matching_signature...只是 SQL Profiles 中的 Hint,没有指定 SQL 使用哪个索引,也没有指定表的连接方法和连接顺序。这里只指定了 T1 表评估返回的行数,与原始的评估返回的行数的放大缩小的倍数。...将 T1 表的统计信息中的表行数改为 500 万,Oracle 就会评估为返回 5000000*5%*0.01161091426=2903 行。
(在给定字段域上的一种固定的范围限制)可以通过大量的数据类型来补偿; 3、MySQL不支持热备份; Oracle的特点 1、兼容性:Oracle产品采用标准SQL,并经过美国u构架标准技术所(NIST)...3、SQL语法的区别 Oracle的SQL语法与MySQL有很大不同。Oracle为称为PL / SQL的编程语言提供了更大的灵活性。...Oracle中临时表的定义与MySQL略有不同,因为临时表一旦创建就会存在,直到它们被显式删除,并且对具有适当权限的所有会话都可见。...; Oracle:没有自动增长,主键一般使用序列,插入记录时将序列号的下一值付给该字段即可,只是ORM框架只是需要native主键生成策略即可。...插入修改记录前一定要做进行非空和长度判断,不能为空的字段值和超出长度值都应该提出警告,返回上次操作。
编辑手记:注重细节,是DBA必要的基本素质要求。 书接上文(参考:空与非空 - 数据库中也有薛定谔的猫?),其实CBO的判断本身是没有问题的,问题在于,为什么一个空值会存在非空约束的字段中。...,导致CBO给出的执行计划返回了错误的结果,但是问题的根源在于,为什么Oracle会允许空值插入到非空约束字段中: SQL> insert into t_def (id, name) values (1...检查表的定义,发现一个特别之处,TYPE列的默认值本身就是NULL,是不是这个导致了Oracle的数据问题呢: SQL> CREATE TABLE T_TEST (ID NUMBER, NAME VARCHAR2...NAME") 显然问题没有那么简单,虽然默认值人为设置为NULL并不常见,但是对于哪些具有NOT NULL约束且没有指定默认值的列,都相当于默认值为NULL。...,DEFAULT为NULL是要禁止的,否则就会导致现有记录的NOT NULL字段出现NULL值。
PLSQL介绍 PLSQL是Oracle对SQL99的一种扩展,基本每一种数据库都会对SQL进行扩展,Oracle对SQL的扩展就叫做PLSQL… SQL99是什么 (1)是操作所有关系型数据库的规则...当定义变量时,该变量的类型与表中某字段的类型相同时,可以使用%type 当定义变量时,该变量与整个表结构完全相同时,可以使用%rowtype,此时通过变量名.字段名,可以取值变量中对应的值 项目中,常用...,职位,月薪,返回多个值,演示out的用法 创建过程:在过程中的参数,默认值是IN,如果是输出的话,那么我们要指定为OUT。..., income OUT NUMBER) --这里指定的是返回值类型 RETURN VARCHAR AS /*查询出来的字段与列名相同,就使用列名相同的类型就行了。...不难发现的是,函数是必定要有一个返回值的,当我们在调用的时候,接受返回值就直接获取就行了。 也就是说 当返回值只有一个参数的时候,那么就使用存储函数!
不论创建表还是约束,与SQL Server基本相同,注:在Oracle中default是一个值,而SQL Server中default是一个约束,因此Oracle的default设置可以在建表的时候创建...其中⑦是唯一约束,表示该列值是唯一的,列中的值不能重复。 Oracle中创建外键约束与SQL Server相同。...② Oracle中的外键约束定义。 注意:表名,字段名要大写!...数据类型 列的特征, 字段名2 数据类型 列的特征(NOT NULL), …… primary key(主键列字段)) (3)利用现有的表创建表 — 注意:仅复制Oracle数据表结构:采用的是子查询方式...特殊的数据表dual dual表实际属于系统用户sys,具有了数据库基本权限的用户,均可查询该表的内容,如下所示: 或者 分析查询结果可知,dual表仅含有一行一列。
) 判断字段是否为空一般是不会应用索引的,因为B树索引是不索引空值的。...用其它相同功能的操作运算代替, a is not null 改为 a>0 或a>''等。 不允许字段为空,而用一个缺省值代替空值,如业扩申请中状态字段不允许为空,缺省为申请。...) , ORACLE 将不接受下一 条具有相同A,B 值(123,null)的记录(插入).然而如果所有的索引列都为空,ORACLE 将认为整个键值为空而空不等于空....因此你可以插入1000 条具有相同键值的记录,当然它们都是空!因为空值不存在于索引列中,所以WHERE 子句中对索引列进行空值比较将使ORACLE 停用该索引....语句的效率, 可以通过将不需要的记录在GROUP BY 之前过滤掉.下面两个 查询返回相同结果但第二个明显就快了许多.
VALUES (value1, value2, value3, ...); 2-如果要为表的所有列添加值,则无需在 SQL 查询中指定列名。但是,请确保值的顺序与表中的列顺序相同。...具有 NULL 值的字段是没有值的字段。...如果表中的字段是可选的,则可以在不向该字段添加值的情况下插入新记录或更新记录。然后,该字段将保存为 NULL 值。 注意: NULL 值不同于零值或包含空格的字段。...具有 NULL 值的字段是在创建记录期间留空的字段! 如何测试 NULL 值? 无法使用比较运算符(例如 =、)测试 NULL 值。...GROUP BY语句 该GROUP BY语句将具有相同值的行分组为汇总行,例如“查找每个国家/地区的客户数量”。
聚合函数是对一组值进行计算并返回单一的值的函数,它经常与 select 语句中的 group by 子句一同使用。 a. avg():返回的是指定组中的平均值,空值被忽略。 b....count():返回的是指定组中的项目个数。 c. max():返回指定数据中的最大值。 d. min():返回指定数据中的最小值。 e....sum():返回指定数据的和,只能用于数字列,空值忽略。 f. group by():对数据进行分组,对执行完 group by 之后的组进行聚合函数的运算,计算每一组的值。...(3)隔离性:隔离状态执行事务,使它们好像是系统在给定时间内执行的唯一操作。如果有两个事务,运行在相同的时间内,执行相同的功能,事务的隔离性将确保每一事务在系统中认为只有该事务在使用系统。...: 1)查询表中的前n条记录: select * from Table where rownum <= n 2)查询第 n 到第 m 条记录: select * from (select 表名.*,
例如,S*返回所有以S S*开头的模式。 Person返回所有以S. *开头的模式中的所有Person项。 Person*返回所有模式中以Person开头的所有项。...生成的SQL映射名称与约束名称相同,并遵循相同的命名约定(下面描述)。...例如,如果FullName具有MyTest表中的第二个未命名的唯一约束(不包括ID字段),则FullName的生成约束名称将是mytest_unique2;如果fullname是MyTest表中指定的主键和第...例如,如果FirstName和LastName具有MyTest表中的第2个未命名的唯一约束(不包括ID字段),则FirstName和LastName的生成约束名称将是MyTestunique2;如果FullName...与命名空间的SQL语句相同的信息。
推荐方案:用其它相同功能的操作运算代替,如:a is not null 改为 a>0 或a>’’等。不允许字段为空,而用一个缺省值代替空值,如申请中状态字段不允许为空,缺省为申请。...,但是从ORACLE共享内存SGA的原理,可以得出ORACLE对每个SQL 都会对其进行一次分析,并且占用共享内存,如果将SQL的字符串及格式写得完全相同,则ORACLE只会分析一次,共享内存也只会留下一次的分析结果...如果至少有一个列不为空,则记录存在于索引中.举例: 如果唯一性索引建立在表的A列和B列上, 并且表中存在一条记录的A,B值为(123,null) , ORACLE将不接受下一条具有相同A,B值(123,...然而如果所有的索引列都为空,ORACLE将认为整个键值为空而空不等于空. 因此你可以插入1000 条具有相同键值的记录,当然它们都是空!...因为空值不存在于索引列中,所以WHERE子句中对索引列进行空值比较将使ORACLE停用该索引.
领取专属 10元无门槛券
手把手带您无忧上云