网站首页 > 技术文章 正文
导读:区块链表是仅插入表(Only-Insert),将行组织成许多链。通过使用加密哈希将链中除第一行之外的每一行链接到链中的前一行。
在2020年2月14日,Oracle 正式宣布在 Oracle Cloud 发布 Database 20c 的预览版,同时发布了所有的官方文档。
为了和大家及时分享关于 Oracle 20c 引人瞩目的新特性,我们特别邀请了 杨廷琨 老师,将于2月18日,进行关于 20c 新特性的在线直播,报名地址:
https://www.modb.pro/event/103
另外,我将20c的官方文档转存了一份到百度云,如果你下载官网缓慢,在公众号后台回复:20cDoc 你能找到下载链接。
本文介绍Oracle 20c 新特性之区块链表提供基于 Oracle 的集中式区块应用。以下为正文:
区块链表中的行是防篡改的。每行包含一个密码哈希值,该值基于该行中的数据和链中上一行的哈希值。如果某行被篡改,则该行的哈希值会更改,这会导致链中下一行的哈希值发生更改。为了增强欺诈保护,可以将可选的用户签名添加到行中。如果您在区块链表行上签名,则必须使用数字证书。在验证区块链表中的链时,数据库需要证书来验证行签名。
下图是区块链表的示意图:
可以对区块链表进行索引和分区。您可以通过建表时的选项控制是否以及何时从区块链表中删除行。您还可以控制是否可以删除区块链表。区块链表可与事务和查询中的(常规)表一起使用。
区块链表用于实施集中式区块链应用程序,其中中央权限是Oracle数据库。集中式区块链为组织提供了更大的可定制性和控制力,因为他们可以决定谁可以加入网络。参与者是不同的数据库用户,他们信任Oracle数据库来维护交易的防篡改区块链。所有参与者都必须具有将数据插入到区块链表中的特权。区块链的内容由应用程序定义和管理。与分散式区块链相比,集中式区块链在与基于共识的分布式区块链相比首选更高吞吐量和更低交易延迟的场景中很有用。
以下测试,展示了区块链表的基本用法。
首先创建一个区块链表,指定不可DROP,不可 DELETE 的基本约束:
SQL> select banner from v$version;
BANNER
--------------------------------------------------------------------------------
Oracle Database 20c Enterprise Edition Release 20.0.0.0.0 - Production
SQL> create blockchain table yhem
2 (
3 id number primary key,
4 name varchar2(20),
5 join_date date)
6 NO DROP UNTIL 30 DAYS IDLE
7 NO DELETE LOCKED
8 HASHING USING "SHA2_512" VERSION "v1";
Table created.
插入区块记录:
SQL> insert into yhem values(1,'EYGLE',to_date('2010-08-08','yyyy-mm-dd'));
1 row created.
SQL> insert into yhem values(2,'KAMUS',to_date('2010-08-08','yyyy-mm-dd'));
1 row created.
SQL> insert into yhem values(3,'ORA-600',to_date('2010-08-08','yyyy-mm-dd'));
1 row created.
SQL> insert into yhem values(4,'YANGTINGKUN',to_date('2010-08-08','yyyy-mm-dd'));
1 row created.
SQL> commit;
Commit complete.
这个区块链表,除了插入操作,删除、更新,以及DROP 操作,都是禁止的:
SQL> delete yhem where id=1;
delete yhem where id=1
*
ERROR at line 1:
ORA-05715: operation not allowed on the blockchain table
SQL> update yhem set name='Guoqiang,Gai' where id=1;
update yhem set name='Guoqiang,Gai' where id=1
*
ERROR at line 1:
ORA-05715: operation not allowed on the blockchain table
SQL> drop table yhem;
drop table yhem
*
ERROR at line 1:
ORA-05723: drop blockchain table YHEM not allowed
Oracle 还提供了 PACKAGE 去校验数据的一致性:
SQL> set serveroutput on
SQL> DECLARE
2 verified_rows NUMBER :=0;
3 BEGIN
4 DBMS_BLOCKCHAIN_TABLE.VERIFY_ROWS('EYGLE','YHEM',number_of_rows_verified=> verified_rows);
5 DBMS_OUTPUT.PUT_LINE('Number of rows verified =' || verified_rows);
6 END;
7 /
Number of rows verified =4
PL/SQL procedure successfully completed.
保留周期对于区块链表是最重要的选项,NO DROP UNTIL 30 DAYS IDLE 指定在数据表IDLE多长时间后可以删除,这个设置可以增大,但是不可以减少(天数的最小值是16天):
SQL> ALTER TABLE yhem NO DROP UNTIL 18 DAYS IDLE;
ALTER TABLE yhem NO DROP UNTIL 18 DAYS IDLE
*
ERROR at line 1:
ORA-05732: retention value cannot be lowered
SQL> ALTER TABLE yhem NO DROP UNTIL 31 DAYS IDLE;
Table altered.
而对于DELETE来说,NO DELETE LOCKED 是指数据不允许删除,对于删除的约束,还可以设置约定天数的保留周期,例如设置20天,当数据超过20天未插入后,可以通过PACKAGE进行删除清理:
SQL> ALTER TABLE yhem NO DELETE UNTIL 20 DAYS AFTER INSERT LOCKED;
ALTER TABLE ENMOTECH NO DELETE UNTIL 20 DAYS AFTER INSERT LOCKED
*
ERROR at line 1:
ORA-05731: blockchain table yhem cannot be altered
Oracle 的区块链表,是对于集中式互信应用,提供了一个选择。
出处:https://www.modb.pro/db/21547(点击左下角“阅读原文”或者复制链接到浏览器中可打开)
想了解更多关于数据库、云技术的内容吗?
快来关注“数据和云"、"云和恩墨,"公众号及"云和恩墨"官方网站,我们期待大家一同学习与进步!
小程序”DBASK“在线问答,随时解惑,欢迎了解和关注!
- 上一篇: 企业权限管理系统——项目需求分析&环境搭建
- 下一篇: 关于系统后台的用户权限设计与思考
猜你喜欢
- 2024-11-16 ORA-01950 对表空间无权限(oracle对表空间无权限)
- 2024-11-16 关于系统后台的用户权限设计与思考
- 2024-11-16 企业权限管理系统——项目需求分析&环境搭建
- 2024-11-16 Oracle高级数据库特性揭秘:存储过程、触发器与权限管理
你 发表评论:
欢迎- 610℃几个Oracle空值处理函数 oracle处理null值的函数
- 602℃Oracle分析函数之Lag和Lead()使用
- 590℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 588℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 582℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 575℃【数据统计分析】详解Oracle分组函数之CUBE
- 564℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 556℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- 前端获取当前时间 (50)
- Oracle RAC (76)
- oracle恢复 (77)
- oracle 删除表 (52)
- oracle 用户名 (80)
- oracle 工具 (55)
- oracle 内存 (55)
- oracle 导出表 (62)
- oracle约束 (54)
- oracle 中文 (51)
- oracle链接 (54)
- oracle的函数 (58)
- 前端调试 (52)
本文暂时没有评论,来添加一个吧(●'◡'●)