Provide import and export functions for popular data formats like JSON, XML (limited), PHP, ...
for Connector/C and MariaDB Server (which use same code base for dynamic columns)
Tasks:
Dynamic column library (includes MariaDB Server and Connector/C).
1) Add support for arrays with ordinal indexes (currently dynamic columns are limited to use string indexes only)
2) Provide a library for importing/exporting data to and from Dynamic columns.
The following data formats should be supported:
JSON
XML (limited to unique keys only)
PHP,
...
MariaDB Server:
3) Provide user defined function (UDF) based on library (task 2) for importing and exporting data
MariaDB Connector/C:
3) Provide a plugin interface based on library (task 2) for importing and exporting data
Examples of usage:
1) MariaDB Server
SET @a:='{"menu": {
"id": "file",
"value": "File",
"popup": {
"menuitem": [
{"value": "New", "onclick": "CreateNewDoc()"},
{"value": "Open", "onclick": "OpenDoc()"},
{"value": "Close", "onclick": "CloseDoc()"}
]
}
}}';
INSERT INTO my_table (dyncol) VALUES (COLUMN_IMPORT("JSON", @a))
Iam interested in this proposal. I have some experience in C. Also I have done similar works before using Java for data management in JSON and XML and some PHP wrappers for REST services using JSON as data format too.
Alberto M EsmorÃs Pena
added a comment - Iam interested in this proposal. I have some experience in C. Also I have done similar works before using Java for data management in JSON and XML and some PHP wrappers for REST services using JSON as data format too.
I have to say that JSON/XML & Co is not the biggest part of the project.
As I can see it (the task) one should take old dynamic column format (numeric keys) and expand type to modern types supported by dynamic columns everything else is simple. So task is stand alone and do not require deep knowledge of the server and client.
Oleksandr Byelkin
added a comment - I have to say that JSON/XML & Co is not the biggest part of the project.
As I can see it (the task) one should take old dynamic column format (numeric keys) and expand type to modern types supported by dynamic columns everything else is simple. So task is stand alone and do not require deep knowledge of the server and client.
This proposal caught my attention.I am really interested in this idea.From my understanding,we can use libxml2 and Jansson for the import/export purpose and Lucy for indexing purpose.Kindly enlighten me more on this area.
Tushar Bihany
added a comment - This proposal caught my attention.I am really interested in this idea.From my understanding,we can use libxml2 and Jansson for the import/export purpose and Lucy for indexing purpose.Kindly enlighten me more on this area.
I think we better not use third party libraries because:
1) maintaining compatibility and dependencies
2) licence sometimes problem
3) formats are simple to parse and print data in them is not a task at all (and we do not need something else)
Oleksandr Byelkin
added a comment - I think we better not use third party libraries because:
1) maintaining compatibility and dependencies
2) licence sometimes problem
3) formats are simple to parse and print data in them is not a task at all (and we do not need something else)
Hi am Arlene Flavie and i am interested in this task.
concerning 1: adding support for arrays . Does this mean the dynamic column should hold an array instead of a string such that the array indices become the indexed values when manipulating the column. something like
If thats the case i get it as it will greatly increase performance as queries will be of O(1) if array indices are used.
Arlene Flavie
added a comment - - edited Hi am Arlene Flavie and i am interested in this task.
concerning 1: adding support for arrays . Does this mean the dynamic column should hold an array instead of a string such that the array indices become the indexed values when manipulating the column. something like
INSERT INTO tb_dycol (friends) VALUES( ARRAY ['serg', 'Byelkin', 'elenst', 'holyfoot', 'monty', 'knielson', 'danblack'] );
If thats the case i get it as it will greatly increase performance as queries will be of O(1) if array indices are used.
1) Now dynamic columns support other dynamic column as a value (new format support it).
2) old format of dynamic columns uses numbers as a keys so they can be interpreted as an array, but old format do not support all types (including embedded dynamic columns) because have only 3 bits to represent type.
Taking into account above I think that simplest way to support arrays is add new 'old' format in addition to that 2 we have. But we are open to any other better solutions.
Oleksandr Byelkin
added a comment - 1) Now dynamic columns support other dynamic column as a value (new format support it).
2) old format of dynamic columns uses numbers as a keys so they can be interpreted as an array, but old format do not support all types (including embedded dynamic columns) because have only 3 bits to represent type.
Taking into account above I think that simplest way to support arrays is add new 'old' format in addition to that 2 we have. But we are open to any other better solutions.
People
Georg Richter
Georg Richter
Votes:
1Vote for this issue
Watchers:
6Start watching this issue
Dates
Created:
Updated:
Git Integration
Error rendering 'com.xiplink.jira.git.jira_git_plugin:git-issue-webpanel'. Please contact your Jira administrators.
{"report":{"fcp":1445.6000003814697,"ttfb":228.2000002861023,"pageVisibility":"visible","entityId":50316,"key":"jira.project.issue.view-issue","isInitial":true,"threshold":1000,"elementTimings":{},"userDeviceMemory":8,"userDeviceProcessors":64,"apdex":0.5,"journeyId":"fdcf749f-2d10-40ca-b624-747c226c0b51","navigationType":0,"readyForUser":1517.2000002861023,"redirectCount":0,"resourceLoadedEnd":1826.5,"resourceLoadedStart":233.60000038146973,"resourceTiming":[{"duration":718.8999996185303,"initiatorType":"link","name":"https://jira.mariadb.org/s/2c21342762a6a02add1c328bed317ffd-CDN/lu2cib/820016/12ta74/0a8bac35585be7fc6c9cc5a0464cd4cf/_/download/contextbatch/css/_super/batch.css","startTime":233.60000038146973,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":233.60000038146973,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":952.5,"responseStart":0,"secureConnectionStart":0},{"duration":719,"initiatorType":"link","name":"https://jira.mariadb.org/s/7ebd35e77e471bc30ff0eba799ebc151-CDN/lu2cib/820016/12ta74/494e4c556ecbb29f90a3d3b4f09cb99c/_/download/contextbatch/css/jira.browse.project,project.issue.navigator,jira.view.issue,jira.general,jira.global,atl.general,-_super/batch.css?agile_global_admin_condition=true&jag=true&jira.create.linked.issue=true&slack-enabled=true&whisper-enabled=true","startTime":233.90000009536743,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":233.90000009536743,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":952.9000000953674,"responseStart":0,"secureConnectionStart":0},{"duration":748,"initiatorType":"script","name":"https://jira.mariadb.org/s/0917945aaa57108d00c5076fea35e069-CDN/lu2cib/820016/12ta74/0a8bac35585be7fc6c9cc5a0464cd4cf/_/download/contextbatch/js/_super/batch.js?locale=en","startTime":234.10000038146973,"connectEnd":234.10000038146973,"connectStart":234.10000038146973,"domainLookupEnd":234.10000038146973,"domainLookupStart":234.10000038146973,"fetchStart":234.10000038146973,"redirectEnd":0,"redirectStart":0,"requestStart":234.10000038146973,"responseEnd":982.1000003814697,"responseStart":982.1000003814697,"secureConnectionStart":234.10000038146973},{"duration":857.3000001907349,"initiatorType":"script","name":"https://jira.mariadb.org/s/2d8175ec2fa4c816e8023260bd8c1786-CDN/lu2cib/820016/12ta74/494e4c556ecbb29f90a3d3b4f09cb99c/_/download/contextbatch/js/jira.browse.project,project.issue.navigator,jira.view.issue,jira.general,jira.global,atl.general,-_super/batch.js?agile_global_admin_condition=true&jag=true&jira.create.linked.issue=true&locale=en&slack-enabled=true&whisper-enabled=true","startTime":234.30000019073486,"connectEnd":234.30000019073486,"connectStart":234.30000019073486,"domainLookupEnd":234.30000019073486,"domainLookupStart":234.30000019073486,"fetchStart":234.30000019073486,"redirectEnd":0,"redirectStart":0,"requestStart":234.30000019073486,"responseEnd":1091.6000003814697,"responseStart":1091.6000003814697,"secureConnectionStart":234.30000019073486},{"duration":861.3000001907349,"initiatorType":"script","name":"https://jira.mariadb.org/s/a9324d6758d385eb45c462685ad88f1d-CDN/lu2cib/820016/12ta74/c92c0caa9a024ae85b0ebdbed7fb4bd7/_/download/contextbatch/js/atl.global,-_super/batch.js?locale=en","startTime":234.40000009536743,"connectEnd":234.40000009536743,"connectStart":234.40000009536743,"domainLookupEnd":234.40000009536743,"domainLookupStart":234.40000009536743,"fetchStart":234.40000009536743,"redirectEnd":0,"redirectStart":0,"requestStart":234.40000009536743,"responseEnd":1095.7000002861023,"responseStart":1095.7000002861023,"secureConnectionStart":234.40000009536743},{"duration":861.7999997138977,"initiatorType":"script","name":"https://jira.mariadb.org/s/d41d8cd98f00b204e9800998ecf8427e-CDN/lu2cib/820016/12ta74/1.0/_/download/batch/jira.webresources:calendar-en/jira.webresources:calendar-en.js","startTime":234.7000002861023,"connectEnd":234.7000002861023,"connectStart":234.7000002861023,"domainLookupEnd":234.7000002861023,"domainLookupStart":234.7000002861023,"fetchStart":234.7000002861023,"redirectEnd":0,"redirectStart":0,"requestStart":234.7000002861023,"responseEnd":1096.5,"responseStart":1096.5,"secureConnectionStart":234.7000002861023},{"duration":862.4000000953674,"initiatorType":"script","name":"https://jira.mariadb.org/s/d41d8cd98f00b204e9800998ecf8427e-CDN/lu2cib/820016/12ta74/1.0/_/download/batch/jira.webresources:calendar-localisation-moment/jira.webresources:calendar-localisation-moment.js","startTime":234.80000019073486,"connectEnd":234.80000019073486,"connectStart":234.80000019073486,"domainLookupEnd":234.80000019073486,"domainLookupStart":234.80000019073486,"fetchStart":234.80000019073486,"redirectEnd":0,"redirectStart":0,"requestStart":234.80000019073486,"responseEnd":1097.2000002861023,"responseStart":1097.2000002861023,"secureConnectionStart":234.80000019073486},{"duration":899.1000003814697,"initiatorType":"link","name":"https://jira.mariadb.org/s/b04b06a02d1959df322d9cded3aeecc1-CDN/lu2cib/820016/12ta74/a2ff6aa845ffc9a1d22fe23d9ee791fc/_/download/contextbatch/css/jira.global.look-and-feel,-_super/batch.css","startTime":235,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":235,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":1134.1000003814697,"responseStart":0,"secureConnectionStart":0},{"duration":862.2999997138977,"initiatorType":"script","name":"https://jira.mariadb.org/rest/api/1.0/shortcuts/820016/47140b6e0a9bc2e4913da06536125810/shortcuts.js?context=issuenavigation&context=issueaction","startTime":235.2000002861023,"connectEnd":235.2000002861023,"connectStart":235.2000002861023,"domainLookupEnd":235.2000002861023,"domainLookupStart":235.2000002861023,"fetchStart":235.2000002861023,"redirectEnd":0,"redirectStart":0,"requestStart":235.2000002861023,"responseEnd":1097.5,"responseStart":1097.5,"secureConnectionStart":235.2000002861023},{"duration":898.9000000953674,"initiatorType":"link","name":"https://jira.mariadb.org/s/3ac36323ba5e4eb0af2aa7ac7211b4bb-CDN/lu2cib/820016/12ta74/d176f0986478cc64f24226b3d20c140d/_/download/contextbatch/css/com.atlassian.jira.projects.sidebar.init,-_super,-project.issue.navigator,-jira.view.issue/batch.css?jira.create.linked.issue=true","startTime":235.30000019073486,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":235.30000019073486,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":1134.2000002861023,"responseStart":0,"secureConnectionStart":0},{"duration":862.7000002861023,"initiatorType":"script","name":"https://jira.mariadb.org/s/5d5e8fe91fbc506585e83ea3b62ccc4b-CDN/lu2cib/820016/12ta74/d176f0986478cc64f24226b3d20c140d/_/download/contextbatch/js/com.atlassian.jira.projects.sidebar.init,-_super,-project.issue.navigator,-jira.view.issue/batch.js?jira.create.linked.issue=true&locale=en","startTime":235.40000009536743,"connectEnd":235.40000009536743,"connectStart":235.40000009536743,"domainLookupEnd":235.40000009536743,"domainLookupStart":235.40000009536743,"fetchStart":235.40000009536743,"redirectEnd":0,"redirectStart":0,"requestStart":235.40000009536743,"responseEnd":1098.1000003814697,"responseStart":1098.1000003814697,"secureConnectionStart":235.40000009536743},{"duration":1445.5,"initiatorType":"script","name":"https://jira.mariadb.org/s/d41d8cd98f00b204e9800998ecf8427e-CDN/lu2cib/820016/12ta74/1.0/_/download/batch/jira.webresources:bigpipe-js/jira.webresources:bigpipe-js.js","startTime":240.80000019073486,"connectEnd":240.80000019073486,"connectStart":240.80000019073486,"domainLookupEnd":240.80000019073486,"domainLookupStart":240.80000019073486,"fetchStart":240.80000019073486,"redirectEnd":0,"redirectStart":0,"requestStart":240.80000019073486,"responseEnd":1686.3000001907349,"responseStart":1686.3000001907349,"secureConnectionStart":240.80000019073486},{"duration":1583.7999997138977,"initiatorType":"script","name":"https://jira.mariadb.org/s/d41d8cd98f00b204e9800998ecf8427e-CDN/lu2cib/820016/12ta74/1.0/_/download/batch/jira.webresources:bigpipe-init/jira.webresources:bigpipe-init.js","startTime":242.7000002861023,"connectEnd":242.7000002861023,"connectStart":242.7000002861023,"domainLookupEnd":242.7000002861023,"domainLookupStart":242.7000002861023,"fetchStart":242.7000002861023,"redirectEnd":0,"redirectStart":0,"requestStart":242.7000002861023,"responseEnd":1826.5,"responseStart":1826.5,"secureConnectionStart":242.7000002861023},{"duration":540.8999996185303,"initiatorType":"xmlhttprequest","name":"https://jira.mariadb.org/rest/webResources/1.0/resources","startTime":1146.6000003814697,"connectEnd":1146.6000003814697,"connectStart":1146.6000003814697,"domainLookupEnd":1146.6000003814697,"domainLookupStart":1146.6000003814697,"fetchStart":1146.6000003814697,"redirectEnd":0,"redirectStart":0,"requestStart":1146.6000003814697,"responseEnd":1687.5,"responseStart":1687.5,"secureConnectionStart":1146.6000003814697},{"duration":457.09999990463257,"initiatorType":"script","name":"https://www.google-analytics.com/analytics.js","startTime":1438.9000000953674,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":1438.9000000953674,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":1896,"responseStart":0,"secureConnectionStart":0}],"fetchStart":0,"domainLookupStart":0,"domainLookupEnd":0,"connectStart":0,"connectEnd":0,"requestStart":74,"responseStart":228,"responseEnd":243,"domLoading":232,"domInteractive":1850,"domContentLoadedEventStart":1850,"domContentLoadedEventEnd":1893,"domComplete":2551,"loadEventStart":2551,"loadEventEnd":2551,"userAgent":"Mozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; ClaudeBot/1.0; +claudebot@anthropic.com)","marks":[{"name":"bigPipe.sidebar-id.start","time":1828},{"name":"bigPipe.sidebar-id.end","time":1829},{"name":"bigPipe.activity-panel-pipe-id.start","time":1829.1000003814697},{"name":"bigPipe.activity-panel-pipe-id.end","time":1831},{"name":"activityTabFullyLoaded","time":1909.1000003814697}],"measures":[],"correlationId":"b82647d2d7c1ab","effectiveType":"4g","downlink":9.4,"rtt":0,"serverDuration":97,"dbReadsTimeInMs":12,"dbConnsTimeInMs":20,"applicationHash":"9d11dbea5f4be3d4cc21f03a88dd11d8c8687422","experiments":[]}}
Iam interested in this proposal. I have some experience in C. Also I have done similar works before using Java for data management in JSON and XML and some PHP wrappers for REST services using JSON as data format too.