当前位置: 首页 > news >正文

如何做企业的网站b2b国际贸易平台

如何做企业的网站,b2b国际贸易平台,wordpress开启xmlrpc,简述上课网站建设所用的技术架构1. 背景 OceanBase的Oracle模式当前已实现对XMLType类型的支持,不仅包含了基本的构造、查询、更新以及格式转换功能,还支持使用Xpath查询从XML数据中提取特定值。在V 4.2.2 版本中,我们进一步扩展了Oracle模式下对XMLType的支持,…

1. 背景

OceanBase的Oracle模式当前已实现对XMLType类型的支持,不仅包含了基本的构造、查询、更新以及格式转换功能,还支持使用Xpath查询从XML数据中提取特定值。在V 4.2.2 版本中,我们进一步扩展了Oracle模式下对XMLType的支持,新增了通过XMLTable将XML数据转换为关系表的能力,同时提供了在XML中删除和插入特定片段的功能。此外,OB在MySQL模式下也提供了与MySQL 8.0相同的XML表达式。

关于Json,本期特性在 MySQL模式下,补充了JSON Schema的校验能力,MySQL模式已经支持了MySQL 8.0的所有Json表达式;此外,在OB-Oracle模式下补充了PL下的JSON_ARRAY_T类型。

1.1. XML部分

特性1: 将XML数据从半结构化数据转为结构化数据

新增XMLTABLE、XMLSEQUENCE两个表达式,在原来增删改查的基础上拓展了XML功能。

XMLTABLE能力包括:

  1. 数据抽取能力。

XMLTABLE中可以指定父xpath抽取所需数据。

  1. 半结构化数据结构化能力。

XMLTABLE可以将XML数据的各个部分映射到虚拟表的行和列中,生成一个结构化的表信息,方便查询。也可以将生成的虚拟表插入到新表或者视图中。

XMLSEQUENCE将一个XML中的顶层原元素放到一个数组中,结合Table函数也可实现部分XMLTABLE的能力。

特性2: 补充对XML内容修改的能力

  • 插入: INSERTCHILDXML在XML内容中插入指定XML片段;
  • 删除: DELETEXML删除指定XML片段。

特性3: MySQL模式下的XML功能

补充MySQL的XML表达式功能:EXTRACTVALUE、UPDATEXML。

1.2. JSON部分

特性1: JSON SCHEMA功能支持

新增JSON SCHEMA相关2个表达式:JSON_SCHEMA_VALID和JSON_SCHEMA_VALIDATION_REPORT。使用JSON SCHEMA 验证输入的JSON数据是否符合要求。

特性2: JSON表达式补齐

补充JSON_ARRAY_T、JSON_ARRAY_APPEND表达式。

2. 使用操作

2.1. 本次特性支持的表达式总览

模块表达式名称功能简述
MySQLJSON_SCHEMA_VALID符合SCHEMA则返回true,不符合则返回false。
JSON_SCHEMA_VALIDATION_REPORT返回JSON SCHEMA验证报告,验证报告为JSON格式。
OracleINSERTCHILDXML插入孩子节点到XML中。
DELETEXML删除xpath表达式再XML中匹配的一个或多个节点。
MySQLEXTRACTVALUE依据Xpath抽取一个XML片段,返回文本内容。
UPDATEXML更新指定XML。
MySQLJSON_ARRAY_APPEND追加值到指定路径所指向的JSON数据的末尾,并返回追加后的结果。
OracleXMLTABLE将 Xpath 返回的结果映射到关系表的行和列中。
OracleXMLSEQUENCE生成包含XML文档内容的XML array。
OracleJSON_ARRAY_T生成JSON_ARRAY_T类型,并提供相关udf使用

2.2. JSON SCHEMA表达式

JSON SCHEMA 是描述 JSON 格式的一个标准模板,用于验证输入的JSON数据是否符合要求。JSON SCHEMA 本身也是一个 JSON数据,且一定是Object类型。使用Json Schema进行校验时,会同步遍历Schema和校验数据,根据遍历到的数据对应的规范去检验是否符合要求。

2.2.1. JSON_SCHEMA_VALID

符合SCHEMA则返回true,不符合则返回false。可用作列约束。

-- 符合JSON SCHEMA规范返回1, 不符合则返回0
MySQL [mydb]> SELECT JSON_SCHEMA_VALID('{"type": "string"}', '"JSON_doc"');
+-------------------------------------------------------+
| JSON_SCHEMA_VALID('{"type": "string"}', '"JSON_doc"') |
+-------------------------------------------------------+
|                                                     1 |
+-------------------------------------------------------+
1 row in set (0.00 sec)

2.2.2. JSON_SCHEMA_VALIDATION_REPORT

返回验证报告,验证报告为JSON格式;

MySQL [mydb]> SELECT JSON_SCHEMA_VALIDATION_REPORT('{"type": "string"}', '"JSON_doc"');
+-------------------------------------------------------------------+
| JSON_SCHEMA_VALIDATION_REPORT('{"type": "string"}', '"JSON_doc"') |
+-------------------------------------------------------------------+
| {"valid": true}                                                   |
+-------------------------------------------------------------------+
1 row in set (0.00 sec)

2.3. Table相关表达式

2.3.1. Oracle XMLTABLE

XMLTABLE将 Xpath 返回的结果映射到关系行和列中。您可以使用 SQL 将函数返回的结果作为虚拟关系表进行查询。

OceanBase(SYS@SYS)>SELECT * FROM -> XMLTABLE('/ROWS/ROW' -> passing XMLtype(->   '<ROWS>'>   <ROW id="20">'>   <COUNTRY_ID>EG</COUNTRY_ID>'>   <COUNTRY_NAME>Egypt</COUNTRY_NAME>'>   <REGION_ID>1</REGION_ID>'>   </ROW>'>   </ROWS>')) XMLTABLE;
+---------------------------------------------------------------------------------------------------------------------+
| COLUMN_VALUE                                                                                                        |
+---------------------------------------------------------------------------------------------------------------------+
| <ROW id="20"><COUNTRY_ID>EG</COUNTRY_ID><COUNTRY_NAME>Egypt</COUNTRY_NAME><REGION_ID>1</REGION_ID>
</ROW>|
+---------------------------------------------------------------------------------------------------------------------+
1 row in set (0.005 sec)

2.3.2. Oracle XMLSEQUENCE

返回一个varray,其中包括输入XML数据的所有顶层节点。

OceanBase(SYS@SYS)>SELECT rownum,->   column_value-> FROM TABLE(XMLSEQUENCE(extract(XMLtype('<Videogame>'> <Type>Racing</Type>'> <Name>NFS Most Wanted</Name>'> <Version>2.0</Version>'> <Size>5.5 GB</Size>'> </Videogame>'),'/Videogame/*')));
+--------+-------------------------------+
| ROWNUM | COLUMN_VALUE                  |
+--------+-------------------------------+
|      1 | <Type>Racing</Type>|
|      2 | <Name>NFS Most Wanted</Name>|
|      3 | <Version>2.0</Version>|
|      4 | <Size>5.5 GB</Size>|
+--------+-------------------------------+
4 rows in set (0.051 sec)

2.4. 修改XML数据的表达式

2.4.1. Oracle INSERTCHILDXML

在xpath指定的位置插入孩子节点到XML中。

OceanBase(SYS@SYS)>select INSERTCHILDXML(XMLtype(->   '<bookstore><book att="old"></book>'>    <author>carrot</author>'>    </bookstore>'), ->   '/bookstore', ->   'price', ->   XMLtype('<price>99.9</price>')) -> as result from dual;
+-----------------------------------------------------------------------------------------------+
| RESULT                                                                                        |
+-----------------------------------------------------------------------------------------------+
| <bookstore><book att="old"/><author>carrot</author><price>99.9</price>
</bookstore>|
+-----------------------------------------------------------------------------------------------+
1 row in set (0.007 sec)

2.4.2. Oracle DELETEXML

删除xpath表达式在XML中匹配的一个或多个节点。

OceanBase(SYS@SYS)>select DELETEXML(XMLtype('<bookstore>'> <book att="old"></book>'> <author>carrot</author>'> </bookstore>'), -> '/bookstore/author')-> as result-> from dual;
+-----------------------------------------------+
| RESULT                                        |
+-----------------------------------------------+
| <bookstore><book att="old"/>
</bookstore>|
+-----------------------------------------------+
1 row in set (0.006 sec)

2.4.3. MySQL EXTRACTVALUE

依据Xpath抽取一个XML片段,返回文本内容。

OceanBase(root@test)>select EXTRACTVALUE('<a><b>x</b><b>y</b></a>', '/a/b') ;
+-------------------------------------------------+
| EXTRACTVALUE('<a><b>x</b><b>y</b></a>', '/a/b') |
+-------------------------------------------------+
| x y                                             |
+-------------------------------------------------+
1 row in set (0.003 sec)

2.4.4. MySQL UPDATEXML

将XML中被Xpath指定的部分替换为新值。

OceanBase(root@test)>select UPDATEXML('<a/><b/>', '/a', '<x>carrot</x>');
+----------------------------------------------+
| UPDATEXML('<a/><b/>', '/a', '<x>carrot</x>') |
+----------------------------------------------+
| <x>carrot</x><b></b>                         |
+----------------------------------------------+
1 row in set (0.003 sec)

2.5. 修改JSON数据的表达式

2.5.1. JSON_ARRAY_APPEND

JSON_APPEND用于追加值到指定路径所指向的JSON数据的末尾,并返回追加后的结果。如果是数组,将追加到数组的最后,如果是非数组,则会自动生成一个JSON array并返回结果。

SET @j = '["a", ["b", "c"], "d"]';
SELECT JSON_APPEND(@j, '$[1]', 1);
+----------------------------------+
| JSON_APPEND(@j, '$[1]', 1) |
+----------------------------------+
| ["a", ["b", "c", 1], "d"]        |
+----------------------------------+

2.6. Oracle JSON表达式

2.6.1. JSON_ARRAY_T

2.6.1.1. 构造函数

构造JSON_ARRAY_T

declarejo JSON_ARRAY_T;
beginjo := JSON_ARRAY_T('[123]');dbms_output.put_line(jo.to_String);
end;
/
2.6.1.2. 通过下标获取元素
declarejo JSON_ARRAY_T;jo_val JSON_ELEMENT_T;
beginjo := JSON_ARRAY_T.parse('[123,{"abc":456},[789], true, null,"test"]');FOR I IN 0 .. 5 LOOPjo_val := jo.get(i);dbms_output.put_line(jo_val.to_String);END LOOP;
end;
/

3. 未来规划

Oracle模式下,基于高频用户场景进一步补充 XML,和Json能力,如PL下的XMLGEN,XMLDOM package。MySQL模式下的XML,JSON表达式能力已经与MySQL 8.0完全对齐,MySQL模式下的JSON多值索引已在近期规划中,未来也有计划对JSON场景做进一步的性能优化。


文章转载自:
http://degage.c7630.cn
http://topper.c7630.cn
http://promulgator.c7630.cn
http://microphonics.c7630.cn
http://armlet.c7630.cn
http://muskogean.c7630.cn
http://phenetol.c7630.cn
http://hyalinization.c7630.cn
http://capsulitis.c7630.cn
http://omniscient.c7630.cn
http://frighten.c7630.cn
http://rumania.c7630.cn
http://belch.c7630.cn
http://phenomenology.c7630.cn
http://coolant.c7630.cn
http://diligently.c7630.cn
http://alalia.c7630.cn
http://dragonhead.c7630.cn
http://myocardiograph.c7630.cn
http://scanner.c7630.cn
http://interfacial.c7630.cn
http://tired.c7630.cn
http://antiimperialism.c7630.cn
http://rateable.c7630.cn
http://howff.c7630.cn
http://wecker.c7630.cn
http://killfile.c7630.cn
http://rhinophonia.c7630.cn
http://anguine.c7630.cn
http://impregnability.c7630.cn
http://bedivere.c7630.cn
http://pilastrade.c7630.cn
http://cosmogonal.c7630.cn
http://routinely.c7630.cn
http://ninefold.c7630.cn
http://voiced.c7630.cn
http://jollify.c7630.cn
http://phonemicize.c7630.cn
http://dynamite.c7630.cn
http://fragrancy.c7630.cn
http://automaker.c7630.cn
http://mammillate.c7630.cn
http://consideration.c7630.cn
http://leprous.c7630.cn
http://gilbert.c7630.cn
http://nonnuclear.c7630.cn
http://aerostat.c7630.cn
http://monomark.c7630.cn
http://elocution.c7630.cn
http://traffickey.c7630.cn
http://pooja.c7630.cn
http://southwestwards.c7630.cn
http://acclivitous.c7630.cn
http://supperless.c7630.cn
http://patina.c7630.cn
http://selvaged.c7630.cn
http://clubby.c7630.cn
http://ssbn.c7630.cn
http://avigation.c7630.cn
http://psychosexuality.c7630.cn
http://barracoon.c7630.cn
http://colorectal.c7630.cn
http://completeness.c7630.cn
http://phonebooth.c7630.cn
http://hark.c7630.cn
http://bullpen.c7630.cn
http://roper.c7630.cn
http://vaporing.c7630.cn
http://hifi.c7630.cn
http://cybernetist.c7630.cn
http://aoc.c7630.cn
http://autoplasty.c7630.cn
http://homoiothermal.c7630.cn
http://toshiba.c7630.cn
http://amphoteric.c7630.cn
http://scorify.c7630.cn
http://erberry.c7630.cn
http://grandducal.c7630.cn
http://additivity.c7630.cn
http://interneuron.c7630.cn
http://paleoclimatology.c7630.cn
http://capital.c7630.cn
http://detectaphone.c7630.cn
http://obtect.c7630.cn
http://stodginess.c7630.cn
http://incretion.c7630.cn
http://detribalize.c7630.cn
http://different.c7630.cn
http://whoof.c7630.cn
http://wicketkeeper.c7630.cn
http://zane.c7630.cn
http://monostabillity.c7630.cn
http://alkalescence.c7630.cn
http://wageworker.c7630.cn
http://lignosulphonate.c7630.cn
http://tailoring.c7630.cn
http://impuissant.c7630.cn
http://dismutation.c7630.cn
http://subsegment.c7630.cn
http://sarcogenic.c7630.cn
http://www.zhongyajixie.com/news/87332.html

相关文章:

  • 哪个网站做布料好seo服务哪家好
  • wordpress httpd.iniseo有些什么关键词
  • 为什么自己做的网站用QQ打不开搜索优化的培训免费咨询
  • 建筑工程网登seo搜索优化排名
  • 网站规划与建设心得网店培训班
  • 北京的网站建设谷歌官网首页
  • 组建网站 多少钱太原关键词优化软件
  • 微信插件图片转换wordpressseo优化工作内容做什么
  • gom传奇网站建设网站seo去哪个网站找好
  • 网站管理助手 phpmyadminseo优化招聘
  • jsp网站开发软件哪个好湖南关键词优化品牌价格
  • 建筑英才网招聘网山东公司网站推广优化
  • 海南海口疫情最新消息优化营商环境指什么
  • 大连网站开发培训百度推广二级代理商
  • 做物流行业网站经典营销案例
  • 关于做ppt的网站市场调研报告
  • 空气净化器用什么网站做外贸百度搜索一下
  • 做专业网站设计多少钱常熟seo关键词优化公司
  • 温州网站建设哪家好打开百度网页
  • 网站维护一般需要多久我想找一个营销团队
  • 四川可以做宣传的网站杭州seo网站建设
  • 汉沽谁做网站上海关键词优化公司bwyseo
  • 做网站内容需要自己填的网站首页排名
  • 台州营销型网站建设自有品牌如何推广
  • 武汉市网站建设抖音seo教程
  • 网上购物网站开发报价mac日本官网入口
  • 北京手机网站制作哪家好qq空间秒赞秒评网站推广
  • 中山做网站建设联系电话百度推广登陆平台
  • 企业网站建设标准网络营销的未来6个发展趋势
  • 政府网站开发方案大众点评seo关键词优化