前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Oracle 20c 新特性:区块链表提供基于 Oracle 的集中式区块应用

Oracle 20c 新特性:区块链表提供基于 Oracle 的集中式区块应用

作者头像
数据和云
发布2020-02-24 17:54:06
7300
发布2020-02-24 17:54:06
举报
文章被收录于专栏:数据和云数据和云

导读:区块链表是仅插入表(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 的基本约束:

代码语言:javascript
复制

插入区块记录:

代码语言:javascript
复制
SQL> insert into yhem values(,'EYGLE',to_date('2010-08-08','yyyy-mm-dd'));

 row created.

SQL> insert into yhem values(,'KAMUS',to_date('2010-08-08','yyyy-mm-dd'));

 row created.

SQL> insert into yhem values(,'ORA-600',to_date('2010-08-08','yyyy-mm-dd'));

 row created.

SQL> insert into yhem values(,'YANGTINGKUN',to_date('2010-08-08','yyyy-mm-dd'));

 row created.

SQL> commit;

Commit complete.

这个区块链表,除了插入操作,删除、更新,以及DROP 操作,都是禁止的:

代码语言:javascript
复制
SQL> delete yhem where id=;
delete yhem where id=
       *
ERROR at line :
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 :
ORA-05715: operation not allowed on the blockchain table


SQL> drop table yhem;
drop table yhem
           *
ERROR at line :
ORA-05723: drop blockchain table YHEM not allowed

Oracle 还提供了 PACKAGE 去校验数据的一致性:

代码语言:javascript
复制
SQL> set serveroutput on
SQL> DECLARE
             verified_rows NUMBER :=;
    BEGIN
             DBMS_BLOCKCHAIN_TABLE.VERIFY_ROWS('EYGLE','YHEM',number_of_rows_verified=> verified_rows);
             DBMS_OUTPUT.PUT_LINE('Number of rows verified =' || verified_rows);
    END;
    /
Number of rows verified =

PL/SQL procedure successfully completed.

保留周期对于区块链表是最重要的选项,NO DROP UNTIL 30 DAYS IDLE 指定在数据表IDLE多长时间后可以删除,这个设置可以增大,但是不可以减少(天数的最小值是16天):

代码语言:javascript
复制
SQL> ALTER TABLE yhem NO DROP UNTIL  DAYS IDLE;
ALTER TABLE yhem NO DROP UNTIL  DAYS IDLE
*
ERROR at line :
ORA-05732: retention value cannot be lowered


SQL> ALTER TABLE yhem NO DROP UNTIL  DAYS IDLE;

Table altered.


而对于DELETE来说,NO DELETE LOCKED 是指数据不允许删除,对于删除的约束,还可以设置约定天数的保留周期,例如设置20天,当数据超过20天未插入后,可以通过PACKAGE进行删除清理:

代码语言:javascript
复制
SQL> ALTER TABLE yhem NO DELETE UNTIL  DAYS AFTER INSERT LOCKED;
ALTER TABLE ENMOTECH NO DELETE UNTIL  DAYS AFTER INSERT LOCKED
*
ERROR at line :
ORA-05731: blockchain table yhem cannot be altered

Oracle 的区块链表,是对于集中式互信应用,提供了一个选择。 出处:https://www.modb.pro/db/21547

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2020-02-17,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 数据和云 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
区块链
云链聚未来,协同无边界。腾讯云区块链作为中国领先的区块链服务平台和技术提供商,致力于构建技术、数据、价值、产业互联互通的区块链基础设施,引领区块链底层技术及行业应用创新,助力传统产业转型升级,推动实体经济与数字经济深度融合。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档