Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
MariaDB
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
MariaDB
Commits
a88bdbdc
Commit
a88bdbdc
authored
Feb 14, 2018
by
Olivier Bertrand
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'ob-10.1' into 10.1
parents
c6e13e3b
46f3e320
Changes
14
Show whitespace changes
Inline
Side-by-side
Showing
14 changed files
with
409 additions
and
281 deletions
+409
-281
storage/connect/connect.cc
storage/connect/connect.cc
+1
-0
storage/connect/mysql-test/connect/r/json_java_2.result
storage/connect/mysql-test/connect/r/json_java_2.result
+3
-1
storage/connect/mysql-test/connect/r/json_java_3.result
storage/connect/mysql-test/connect/r/json_java_3.result
+3
-1
storage/connect/mysql-test/connect/r/json_mongo_c.result
storage/connect/mysql-test/connect/r/json_mongo_c.result
+2
-0
storage/connect/mysql-test/connect/r/mongo_c.result
storage/connect/mysql-test/connect/r/mongo_c.result
+2
-0
storage/connect/mysql-test/connect/r/mongo_java_2.result
storage/connect/mysql-test/connect/r/mongo_java_2.result
+3
-1
storage/connect/mysql-test/connect/r/mongo_java_3.result
storage/connect/mysql-test/connect/r/mongo_java_3.result
+3
-1
storage/connect/mysql-test/connect/r/tbl_thread.result
storage/connect/mysql-test/connect/r/tbl_thread.result
+16
-3
storage/connect/mysql-test/connect/t/mongo.inc
storage/connect/mysql-test/connect/t/mongo.inc
+2
-2
storage/connect/mysql-test/connect/t/mongo_test.inc
storage/connect/mysql-test/connect/t/mongo_test.inc
+6
-2
storage/connect/mysql-test/connect/t/tbl_thread.test
storage/connect/mysql-test/connect/t/tbl_thread.test
+3
-3
storage/connect/tabdos.h
storage/connect/tabdos.h
+1
-0
storage/connect/tabjson.cpp
storage/connect/tabjson.cpp
+321
-266
storage/connect/tabjson.h
storage/connect/tabjson.h
+43
-1
No files found.
storage/connect/connect.cc
View file @
a88bdbdc
...
...
@@ -404,6 +404,7 @@ RCODE EvalColumns(PGLOBAL g, PTDB tdbp, bool reset, bool mrr)
rc
=
RC_FX
;
}
catch
(
const
char
*
msg
)
{
strcpy
(
g
->
Message
,
msg
);
rc
=
RC_NF
;
}
// end catch
return
rc
;
...
...
storage/connect/mysql-test/connect/r/json_java_2.result
View file @
a88bdbdc
SET GLOBAL connect_class_path='C:/MariaDB-10.1/MariaDB/storage/connect/mysql-test/connect/std_data/Mongo2.jar';
SET GLOBAL connect_class_path='C:/MariaDB-10.2/MariaDB/storage/connect/mysql-test/connect/std_data/Mongo2.jar';
set connect_enable_mongo=1;
#
# Test the MONGO table type
#
...
...
@@ -381,3 +382,4 @@ planner 167 41.75
postcard 23 5.75
DROP TABLE t1;
true
set connect_enable_mongo=0;
storage/connect/mysql-test/connect/r/json_java_3.result
View file @
a88bdbdc
SET GLOBAL connect_class_path='C:/MariaDB-10.1/MariaDB/storage/connect/mysql-test/connect/std_data/Mongo3.jar';
SET GLOBAL connect_class_path='C:/MariaDB-10.2/MariaDB/storage/connect/mysql-test/connect/std_data/Mongo3.jar';
set connect_enable_mongo=1;
#
# Test the MONGO table type
#
...
...
@@ -381,3 +382,4 @@ planner 167 41.75
postcard 23 5.75
DROP TABLE t1;
true
set connect_enable_mongo=0;
storage/connect/mysql-test/connect/r/json_mongo_c.result
View file @
a88bdbdc
set connect_enable_mongo=1;
#
# Test the MONGO table type
#
...
...
@@ -380,3 +381,4 @@ planner 167 41.75
postcard 23 5.75
DROP TABLE t1;
true
set connect_enable_mongo=0;
storage/connect/mysql-test/connect/r/mongo_c.result
View file @
a88bdbdc
set connect_enable_mongo=1;
#
# Test the MONGO table type
#
...
...
@@ -376,3 +377,4 @@ planner 167 41.750000
postcard 23 5.750000
DROP TABLE t1;
true
set connect_enable_mongo=0;
storage/connect/mysql-test/connect/r/mongo_java_2.result
View file @
a88bdbdc
SET GLOBAL connect_class_path='C:/MariaDB-10.1/MariaDB/storage/connect/mysql-test/connect/std_data/Mongo2.jar';
SET GLOBAL connect_class_path='C:/MariaDB-10.2/MariaDB/storage/connect/mysql-test/connect/std_data/Mongo2.jar';
set connect_enable_mongo=1;
#
# Test the MONGO table type
#
...
...
@@ -377,3 +378,4 @@ planner 167 41.75
postcard 23 5.75
DROP TABLE t1;
true
set connect_enable_mongo=0;
storage/connect/mysql-test/connect/r/mongo_java_3.result
View file @
a88bdbdc
SET GLOBAL connect_class_path='C:/MariaDB-10.1/MariaDB/storage/connect/mysql-test/connect/std_data/Mongo3.jar';
SET GLOBAL connect_class_path='C:/MariaDB-10.2/MariaDB/storage/connect/mysql-test/connect/std_data/Mongo3.jar';
set connect_enable_mongo=1;
#
# Test the MONGO table type
#
...
...
@@ -377,3 +378,4 @@ planner 167 41.75
postcard 23 5.75
DROP TABLE t1;
true
set connect_enable_mongo=0;
storage/connect/mysql-test/connect/r/tbl_thread.result
View file @
a88bdbdc
connect master,127.0.0.1,root,,test,$MASTER_MYPORT,;
connect slave,127.0.0.1,root,,test,$SLAVE_MYPORT,;
connection master;
CREATE DATABASE connect;
connection slave;
CREATE DATABASE connect;
connection default;
#
# Checking thread TBL tables
#
...
...
@@ -11,6 +16,7 @@ a b
1 test01
2 test02
3 test03
connection master;
CREATE TABLE rt2 (a int, b char(10));
INSERT INTO rt2 VALUES (4,'test04'),(5,'test05'),(6,'test06'),(7,'test07');
SELECT * FROM rt2;
...
...
@@ -19,6 +25,7 @@ a b
5 test05
6 test06
7 test07
connection slave;
USE test;
CREATE TABLE rt3 (a int, b char(10));
INSERT INTO rt3 VALUES (8,'test08'),(9,'test09'),(10,'test10'),(11,'test11');
...
...
@@ -44,6 +51,7 @@ a b
17 test17
18 test18
19 test19
connection default;
CREATE TABLE t2 ENGINE=CONNECT TABLE_TYPE=MYSQL
CONNECTION='mysql://root@127.0.0.1:MASTER_PORT/test/rt2';
SELECT * FROM t2;
...
...
@@ -79,7 +87,7 @@ a b
CREATE TABLE total (a int, b char(10))
ENGINE=CONNECT TABLE_TYPE=TBL TABLE_LIST='t1,t2,t3,t4,t5'
OPTION_LIST='thread=yes,port=PORT';
set connect_xtrace=
1
;
set connect_xtrace=
96
;
SELECT * FROM total order by a desc;
a b
19 test19
...
...
@@ -103,8 +111,11 @@ a b
1 test01
0 test00
set connect_xtrace=0;
connection master;
DROP TABLE rt2;
connection slave;
DROP TABLE rt3,rt4,rt5;
connection default;
DROP TABLE t1,t2,t3,t4,t5,total;
#
# Old thread TBL tables test modified
...
...
@@ -118,7 +129,7 @@ SELECT * FROM t2;
v
22
CREATE TABLE total (v BIGINT(20) UNSIGNED NOT NULL) ENGINE=CONNECT TABLE_TYPE=TBL TABLE_LIST='t1,t2' OPTION_LIST='thread=yes,port=PORT';;
set connect_xtrace=
1
;
set connect_xtrace=
96
;
SELECT * FROM total order by v desc;
v
22
...
...
@@ -137,7 +148,7 @@ SELECT * FROM t2;
v
22
CREATE TABLE total (v BIGINT(20) UNSIGNED NOT NULL) ENGINE=CONNECT TABLE_TYPE=TBL TABLE_LIST='t1,t2' OPTION_LIST='thread=yes,port=PORT';;
set connect_xtrace=
1
;
set connect_xtrace=
96
;
SELECT * FROM total order by v desc;
v
22
...
...
@@ -146,7 +157,9 @@ set connect_xtrace=0;
DROP TABLE total;
DROP TABLE t1;
DROP TABLE t2;
connection master;
DROP TABLE IF EXISTS connect.t1;
DROP DATABASE IF EXISTS connect;
connection slave;
DROP TABLE IF EXISTS connect.t1;
DROP DATABASE IF EXISTS connect;
storage/connect/mysql-test/connect/t/mongo.inc
View file @
a88bdbdc
let
$MONGO
=
C
:/
PROGRA
~
1
/
MongoDB
/
Server
/
3.4
/
bin
/
mongo
;
let
$MONGOIMPORT
=
C
:/
PROGRA
~
1
/
MongoDB
/
Server
/
3.4
/
bin
/
mongoimport
;
let
$MONGO
=
C
:/
Applic
/
MongoDB
/
Server
/
3.6
/
bin
/
mongo
;
let
$MONGOIMPORT
=
C
:/
Applic
/
MongoDB
/
Server
/
3.6
/
bin
/
mongoimport
;
storage/connect/mysql-test/connect/t/mongo_test.inc
View file @
a88bdbdc
#
set connect_enable_mongo=1;
set
connect_enable_mongo
=
1
;
--
echo
#
--
echo
# Test the MONGO table type
...
...
@@ -130,7 +130,9 @@ DROP TABLE t1;
--
echo
#
--
echo
# try CRUD operations
--
echo
#
--
disable_query_log
--
exec
$MONGO
--
eval
"db.testcoll.drop()"
--
quiet
--
enable_query_log
eval
CREATE
TABLE
t1
(
_id
INT
(
4
)
NOT
NULL
,
msg
CHAR
(
64
))
ENGINE
=
CONNECT
TABLE_TYPE
=
$TYPE
TABNAME
=
'testcoll'
OPTION_LIST
=
'Driver=$DRV,Version=$VERS'
$CONN
;
...
...
@@ -147,7 +149,9 @@ DROP TABLE t1;
--
echo
#
--
echo
# List states whose population is equal or more than 10 millions
--
echo
#
--
disable_query_log
--
exec
$MONGO
--
eval
"db.cities.drop()"
--
quiet
--
enable_query_log
--
exec
$MONGOIMPORT
--
quiet
$MTR_SUITE_DIR
/
std_data
/
cities
.
json
eval
CREATE
TABLE
t1
(
_id
char
(
5
)
NOT
NULL
,
...
...
@@ -204,4 +208,4 @@ SELECT * FROM t1;
DROP
TABLE
t1
;
--
exec
$MONGO
--
eval
"db.testcoll.drop()"
--
quiet
#
set connect_enable_mongo=0;
set
connect_enable_mongo
=
0
;
storage/connect/mysql-test/connect/t/tbl_thread.test
View file @
a88bdbdc
...
...
@@ -56,7 +56,7 @@ SELECT * FROM t5;
eval
CREATE
TABLE
total
(
a
int
,
b
char
(
10
))
ENGINE
=
CONNECT
TABLE_TYPE
=
TBL
TABLE_LIST
=
't1,t2,t3,t4,t5'
OPTION_LIST
=
'thread=yes,port=$PORT'
;
set
connect_xtrace
=
1
;
set
connect_xtrace
=
96
;
SELECT
*
FROM
total
order
by
a
desc
;
set
connect_xtrace
=
0
;
...
...
@@ -85,7 +85,7 @@ SELECT * FROM t2;
--
replace_result
$PORT
PORT
--
eval
CREATE
TABLE
total
(
v
BIGINT
(
20
)
UNSIGNED
NOT
NULL
)
ENGINE
=
CONNECT
TABLE_TYPE
=
TBL
TABLE_LIST
=
't1,t2'
OPTION_LIST
=
'thread=yes,port=$PORT'
;
set
connect_xtrace
=
1
;
set
connect_xtrace
=
96
;
SELECT
*
FROM
total
order
by
v
desc
;
set
connect_xtrace
=
0
;
DROP
TABLE
t1
,
t2
,
total
;
...
...
@@ -101,7 +101,7 @@ SELECT * FROM t2;
--
replace_result
$PORT
PORT
--
eval
CREATE
TABLE
total
(
v
BIGINT
(
20
)
UNSIGNED
NOT
NULL
)
ENGINE
=
CONNECT
TABLE_TYPE
=
TBL
TABLE_LIST
=
't1,t2'
OPTION_LIST
=
'thread=yes,port=$PORT'
;
set
connect_xtrace
=
1
;
set
connect_xtrace
=
96
;
SELECT
*
FROM
total
order
by
v
desc
;
set
connect_xtrace
=
0
;
...
...
storage/connect/tabdos.h
View file @
a88bdbdc
...
...
@@ -29,6 +29,7 @@ class DllExport DOSDEF : public TABDEF { /* Logical table description */
friend
class
TXTFAM
;
friend
class
DBFBASE
;
friend
class
UNZIPUTL
;
friend
class
JSONCOL
;
public:
// Constructor
DOSDEF
(
void
);
...
...
storage/connect/tabjson.cpp
View file @
a88bdbdc
...
...
@@ -54,16 +54,16 @@
USETEMP
UseTemp
(
void
);
char
*
GetJsonNull
(
void
);
typedef
struct
_jncol
{
struct
_jncol
*
Next
;
char
*
Name
;
char
*
Fmt
;
int
Type
;
int
Len
;
int
Scale
;
bool
Cbn
;
bool
Found
;
}
JCOL
,
*
PJCL
;
//
typedef struct _jncol {
//
struct _jncol *Next;
//
char *Name;
//
char *Fmt;
//
int Type;
//
int Len;
//
int Scale;
//
bool Cbn;
//
bool Found;
//
} JCOL, *PJCL;
/***********************************************************************/
/* JSONColumns: construct the result blocks containing the description */
...
...
@@ -76,26 +76,13 @@ PQRYRES JSONColumns(PGLOBAL g, PCSZ db, PCSZ dsn, PTOS topt, bool info)
static
XFLD
fldtyp
[]
=
{
FLD_NAME
,
FLD_TYPE
,
FLD_TYPENAME
,
FLD_PREC
,
FLD_LENGTH
,
FLD_SCALE
,
FLD_NULL
,
FLD_FORMAT
};
static
unsigned
int
length
[]
=
{
0
,
6
,
8
,
10
,
10
,
6
,
6
,
0
};
char
*
p
,
colname
[
65
],
fmt
[
129
];
int
i
,
j
,
lvl
,
n
=
0
;
int
i
,
n
=
0
;
int
ncol
=
sizeof
(
buftyp
)
/
sizeof
(
int
);
bool
mgo
=
(
GetTypeID
(
topt
->
type
)
==
TAB_MONGO
);
PCSZ
sep
,
level
;
PVAL
valp
;
JCOL
jcol
;
PJCL
jcp
,
fjcp
=
NULL
,
pjcp
=
NULL
;
PJPR
*
jrp
,
jpp
;
PJSON
jsp
;
PJVAL
jvp
;
PJOB
row
;
PJDEF
tdp
;
TDBJSN
*
tjnp
=
NULL
;
PJTDB
tjsp
=
NULL
;
PJCL
jcp
;
JSONDISC
*
pjdc
=
NULL
;
PQRYRES
qrp
;
PCOLRES
crp
;
jcol
.
Name
=
jcol
.
Fmt
=
NULL
;
if
(
info
)
{
length
[
0
]
=
128
;
length
[
7
]
=
256
;
...
...
@@ -107,10 +94,87 @@ PQRYRES JSONColumns(PGLOBAL g, PCSZ db, PCSZ dsn, PTOS topt, bool info)
return
NULL
;
}
// endif Multiple
pjdc
=
new
(
g
)
JSONDISC
(
g
,
(
int
*
)
length
);
if
(
!
(
n
=
pjdc
->
GetColumns
(
g
,
db
,
dsn
,
topt
)))
return
NULL
;
skipit:
if
(
trace
(
1
))
htrc
(
"JSONColumns: n=%d len=%d
\n
"
,
n
,
length
[
0
]);
/*********************************************************************/
/*
Open the input file.
*/
/*
Allocate the structures used to refer to the result set.
*/
/*********************************************************************/
level
=
GetStringTableOption
(
g
,
topt
,
"Level"
,
NULL
);
qrp
=
PlgAllocResult
(
g
,
ncol
,
n
,
IDS_COLUMNS
+
3
,
buftyp
,
fldtyp
,
length
,
false
,
false
);
crp
=
qrp
->
Colresp
->
Next
->
Next
->
Next
->
Next
->
Next
->
Next
;
crp
->
Name
=
"Nullable"
;
crp
->
Next
->
Name
=
"Jpath"
;
if
(
info
||
!
qrp
)
return
qrp
;
qrp
->
Nblin
=
n
;
/*********************************************************************/
/* Now get the results into blocks. */
/*********************************************************************/
for
(
i
=
0
,
jcp
=
pjdc
->
fjcp
;
jcp
;
i
++
,
jcp
=
jcp
->
Next
)
{
if
(
jcp
->
Type
==
TYPE_UNKNOWN
)
jcp
->
Type
=
TYPE_STRING
;
// Void column
crp
=
qrp
->
Colresp
;
// Column Name
crp
->
Kdata
->
SetValue
(
jcp
->
Name
,
i
);
crp
=
crp
->
Next
;
// Data Type
crp
->
Kdata
->
SetValue
(
jcp
->
Type
,
i
);
crp
=
crp
->
Next
;
// Type Name
crp
->
Kdata
->
SetValue
(
GetTypeName
(
jcp
->
Type
),
i
);
crp
=
crp
->
Next
;
// Precision
crp
->
Kdata
->
SetValue
(
jcp
->
Len
,
i
);
crp
=
crp
->
Next
;
// Length
crp
->
Kdata
->
SetValue
(
jcp
->
Len
,
i
);
crp
=
crp
->
Next
;
// Scale (precision)
crp
->
Kdata
->
SetValue
(
jcp
->
Scale
,
i
);
crp
=
crp
->
Next
;
// Nullable
crp
->
Kdata
->
SetValue
(
jcp
->
Cbn
?
1
:
0
,
i
);
crp
=
crp
->
Next
;
// Field format
if
(
crp
->
Kdata
)
crp
->
Kdata
->
SetValue
(
jcp
->
Fmt
,
i
);
}
// endfor i
/*********************************************************************/
/* Return the result pointer. */
/*********************************************************************/
return
qrp
;
}
// end of JSONColumns
/* -------------------------- Class JSONDISC ------------------------- */
/***********************************************************************/
/* Class used to get the columns of a JSON table. */
/***********************************************************************/
JSONDISC
::
JSONDISC
(
PGLOBAL
g
,
int
*
lg
)
{
length
=
lg
;
jcp
=
fjcp
=
pjcp
=
NULL
;
tjnp
=
NULL
;
jpp
=
NULL
;
tjsp
=
NULL
;
jsp
=
NULL
;
row
=
NULL
;
sep
=
NULL
;
i
=
n
=
bf
=
ncol
=
lvl
=
0
;
all
=
false
;
}
// end of JSONDISC constructor
int
JSONDISC
::
GetColumns
(
PGLOBAL
g
,
PCSZ
db
,
PCSZ
dsn
,
PTOS
topt
)
{
bool
mgo
=
(
GetTypeID
(
topt
->
type
)
==
TAB_MONGO
);
PCSZ
level
=
GetStringTableOption
(
g
,
topt
,
"Level"
,
NULL
);
if
(
level
)
{
lvl
=
atoi
(
level
);
...
...
@@ -120,6 +184,9 @@ PQRYRES JSONColumns(PGLOBAL g, PCSZ db, PCSZ dsn, PTOS topt, bool info)
sep
=
GetStringTableOption
(
g
,
topt
,
"Separator"
,
"."
);
/*********************************************************************/
/* Open the input file. */
/*********************************************************************/
tdp
=
new
(
g
)
JSONDEF
;
#if defined(ZIP_SUPPORT)
tdp
->
Entry
=
GetStringTableOption
(
g
,
topt
,
"Entry"
,
NULL
);
...
...
@@ -139,7 +206,7 @@ PQRYRES JSONColumns(PGLOBAL g, PCSZ db, PCSZ dsn, PTOS topt, bool info)
if
(
!
tdp
->
Fn
&&
!
tdp
->
Uri
)
{
strcpy
(
g
->
Message
,
MSG
(
MISSING_FNAME
));
return
NULL
;
return
0
;
}
// endif Fn
if
(
trace
(
1
))
...
...
@@ -160,7 +227,7 @@ PQRYRES JSONColumns(PGLOBAL g, PCSZ db, PCSZ dsn, PTOS topt, bool info)
tdp
->
Pretty
=
0
;
#else // !MONGO_SUPPORT
sprintf
(
g
->
Message
,
MSG
(
NO_FEAT_SUPPORT
),
"MONGO"
);
return
NULL
;
return
0
;
#endif // !MONGO_SUPPORT
}
// endif Uri
...
...
@@ -170,7 +237,7 @@ PQRYRES JSONColumns(PGLOBAL g, PCSZ db, PCSZ dsn, PTOS topt, bool info)
tjsp
=
new
(
g
)
TDBJSON
(
tdp
,
new
(
g
)
UNZFAM
(
tdp
));
#else // !ZIP_SUPPORT
sprintf
(
g
->
Message
,
MSG
(
NO_FEAT_SUPPORT
),
"ZIP"
);
return
NULL
;
return
0
;
#endif // !ZIP_SUPPORT
}
else
tjsp
=
new
(
g
)
TDBJSON
(
tdp
,
new
(
g
)
MAPFAM
(
tdp
));
...
...
@@ -255,35 +322,76 @@ PQRYRES JSONColumns(PGLOBAL g, PCSZ db, PCSZ dsn, PTOS topt, bool info)
goto
err
;
}
// endif row
all
=
GetBooleanTableOption
(
g
,
topt
,
"Fullarray"
,
false
);
jcol
.
Name
=
jcol
.
Fmt
=
NULL
;
jcol
.
Next
=
NULL
;
jcol
.
Found
=
true
;
colname
[
64
]
=
0
;
fmt
[
128
]
=
0
;
colname
[
0
]
=
0
;
if
(
!
tdp
->
Uri
)
{
*
fmt
=
'$'
;
fmt
[
0
]
=
'$'
;
fmt
[
1
]
=
'.'
;
p
=
fmt
+
2
;
}
else
p
=
fmt
;
jrp
=
(
PJPR
*
)
PlugSubAlloc
(
g
,
NULL
,
sizeof
(
PJPR
)
*
MY_MAX
(
lvl
,
0
));
bf
=
2
;
}
// endif Uri
/*********************************************************************/
/* Analyse the JSON tree and define columns. */
/*********************************************************************/
for
(
i
=
1
;
;
i
++
)
{
for
(
jpp
=
row
->
GetFirst
();
jpp
;
jpp
=
jpp
->
GetNext
())
{
for
(
j
=
0
;
j
<
lvl
;
j
++
)
jrp
[
j
]
=
NULL
;
more:
strncpy
(
colname
,
jpp
->
GetKey
(),
64
);
*
p
=
0
;
j
=
0
;
jvp
=
jpp
->
GetVal
();
fmt
[
bf
]
=
0
;
if
(
Find
(
g
,
jpp
->
GetVal
(),
MY_MIN
(
lvl
,
0
)))
goto
err
;
}
// endfor jpp
// Missing column can be null
for
(
jcp
=
fjcp
;
jcp
;
jcp
=
jcp
->
Next
)
{
jcp
->
Cbn
|=
!
jcp
->
Found
;
jcp
->
Found
=
false
;
}
// endfor jcp
if
(
tdp
->
Pretty
!=
2
)
{
// Read next record
switch
(
tjnp
->
ReadDB
(
g
))
{
case
RC_EF
:
jsp
=
NULL
;
break
;
case
RC_FX
:
goto
err
;
default:
jsp
=
tjnp
->
GetRow
();
}
// endswitch ReadDB
}
else
jsp
=
tjsp
->
GetDoc
()
->
GetValue
(
i
);
if
(
!
(
row
=
(
jsp
)
?
jsp
->
GetObject
()
:
NULL
))
break
;
}
// endfor i
if
(
tdp
->
Pretty
!=
2
)
tjnp
->
CloseDB
(
g
);
return
n
;
err:
if
(
tdp
->
Pretty
!=
2
)
tjnp
->
CloseDB
(
g
);
return
0
;
}
// end of GetColumns
bool
JSONDISC
::
Find
(
PGLOBAL
g
,
PJVAL
jvp
,
int
j
)
{
char
*
p
,
*
pc
=
colname
+
strlen
(
colname
);
int
ars
;
PJOB
job
;
PJAR
jar
;
retry:
if
((
valp
=
jvp
?
jvp
->
GetValue
()
:
NULL
))
{
jcol
.
Type
=
valp
->
GetType
();
jcol
.
Len
=
valp
->
GetValLen
();
...
...
@@ -294,49 +402,79 @@ PQRYRES JSONColumns(PGLOBAL g, PCSZ db, PCSZ dsn, PTOS topt, bool info)
jcol
.
Len
=
jcol
.
Scale
=
0
;
jcol
.
Cbn
=
true
;
}
else
if
(
j
<
lvl
)
{
if
(
!*
p
)
if
(
!
fmt
[
bf
]
)
strcat
(
fmt
,
colname
);
p
=
fmt
+
strlen
(
fmt
);
jsp
=
jvp
->
GetJson
();
switch
(
jsp
->
GetType
())
{
case
TYPE_JOB
:
if
(
!
jrp
[
j
])
jrp
[
j
]
=
jsp
->
GetFirst
();
job
=
(
PJOB
)
jsp
;
if
(
*
jrp
[
j
]
->
GetKey
()
!=
'$'
)
{
strncat
(
strncat
(
fmt
,
sep
,
128
),
jrp
[
j
]
->
GetKey
(),
128
);
strncat
(
strncat
(
colname
,
"_"
,
64
),
jrp
[
j
]
->
GetKey
(),
64
);
for
(
PJPR
jrp
=
job
->
GetFirst
();
jrp
;
jrp
=
jrp
->
GetNext
())
{
if
(
*
jrp
->
GetKey
()
!=
'$'
)
{
strncat
(
strncat
(
fmt
,
sep
,
128
),
jrp
->
GetKey
(),
128
);
strncat
(
strncat
(
colname
,
"_"
,
64
),
jrp
->
GetKey
(),
64
);
}
// endif Key
jvp
=
jrp
[
j
]
->
GetVal
();
j
++
;
break
;
if
(
Find
(
g
,
jrp
->
GetVal
(),
j
+
1
))
return
true
;
*
p
=
*
pc
=
0
;
}
// endfor jrp
return
false
;
case
TYPE_JAR
:
jar
=
(
PJAR
)
jsp
;
if
(
all
||
(
tdp
->
Xcol
&&
!
stricmp
(
tdp
->
Xcol
,
colname
)))
ars
=
jar
->
GetSize
(
false
);
else
ars
=
MY_MIN
(
jar
->
GetSize
(
false
),
1
);
for
(
int
k
=
0
;
k
<
ars
;
k
++
)
{
if
(
!
tdp
->
Xcol
||
stricmp
(
tdp
->
Xcol
,
colname
))
{
sprintf
(
buf
,
"%d"
,
k
);
if
(
tdp
->
Uri
)
strncat
(
strncat
(
fmt
,
sep
,
128
),
"0"
,
128
);
strncat
(
strncat
(
fmt
,
sep
,
128
),
buf
,
128
);
else
strncat
(
fmt
,
"[0]"
,
128
);
strncat
(
strncat
(
strncat
(
fmt
,
"["
,
128
),
buf
,
128
),
"]"
,
128
);
if
(
all
)
strncat
(
strncat
(
colname
,
"_"
,
64
),
buf
,
64
);
}
else
strncat
(
fmt
,
(
tdp
->
Uri
?
sep
:
"[
]"
),
128
);
strncat
(
fmt
,
(
tdp
->
Uri
?
sep
:
"[*
]"
),
128
);
jvp
=
jsp
->
GetValue
(
0
);
break
;
if
(
Find
(
g
,
jar
->
GetValue
(
k
),
j
))
return
true
;
*
p
=
*
pc
=
0
;
}
// endfor k
return
false
;
default:
sprintf
(
g
->
Message
,
"Logical error after %s"
,
fmt
);
goto
err
;
}
// endswitch jsp
return
true
;
}
// endswitch Type
goto
retry
;
}
else
if
(
lvl
>=
0
)
{
jcol
.
Type
=
TYPE_STRING
;
jcol
.
Len
=
256
;
jcol
.
Scale
=
0
;
jcol
.
Cbn
=
true
;
}
else
continue
;
return
false
;
AddColumn
(
g
);
return
false
;
}
// end of Find
void
JSONDISC
::
AddColumn
(
PGLOBAL
g
)
{
bool
b
=
fmt
[
bf
]
!=
0
;
// True if formatted
// Check whether this column was already found
for
(
jcp
=
fjcp
;
jcp
;
jcp
=
jcp
->
Next
)
...
...
@@ -352,7 +490,7 @@ PQRYRES JSONColumns(PGLOBAL g, PCSZ db, PCSZ dsn, PTOS topt, bool info)
}
// endif Type
if
(
*
p
&&
(
!
jcp
->
Fmt
||
strlen
(
jcp
->
Fmt
)
<
strlen
(
fmt
)))
{
if
(
b
&&
(
!
jcp
->
Fmt
||
strlen
(
jcp
->
Fmt
)
<
strlen
(
fmt
)))
{
jcp
->
Fmt
=
PlugDup
(
g
,
fmt
);
length
[
7
]
=
MY_MAX
(
length
[
7
],
strlen
(
fmt
));
}
// endif fmt
...
...
@@ -369,7 +507,7 @@ PQRYRES JSONColumns(PGLOBAL g, PCSZ db, PCSZ dsn, PTOS topt, bool info)
jcp
->
Name
=
PlugDup
(
g
,
colname
);
length
[
0
]
=
MY_MAX
(
length
[
0
],
strlen
(
colname
));
if
(
*
p
)
{
if
(
b
)
{
jcp
->
Fmt
=
PlugDup
(
g
,
fmt
);
length
[
7
]
=
MY_MAX
(
length
[
7
],
strlen
(
fmt
));
}
else
...
...
@@ -385,100 +523,8 @@ PQRYRES JSONColumns(PGLOBAL g, PCSZ db, PCSZ dsn, PTOS topt, bool info)
}
// endif jcp
pjcp
=
jcp
;
}
// end of AddColumn
for
(
j
=
lvl
-
1
;
j
>=
0
;
j
--
)
if
(
jrp
[
j
]
&&
(
jrp
[
j
]
=
jrp
[
j
]
->
GetNext
()))
goto
more
;
}
// endfor jpp
// Missing column can be null
for
(
jcp
=
fjcp
;
jcp
;
jcp
=
jcp
->
Next
)
{
jcp
->
Cbn
|=
!
jcp
->
Found
;
jcp
->
Found
=
false
;
}
// endfor jcp
if
(
tdp
->
Pretty
!=
2
)
{
// Read next record
switch
(
tjnp
->
ReadDB
(
g
))
{
case
RC_EF
:
jsp
=
NULL
;
break
;
case
RC_FX
:
goto
err
;
default:
jsp
=
tjnp
->
GetRow
();
}
// endswitch ReadDB
}
else
jsp
=
tjsp
->
GetDoc
()
->
GetValue
(
i
);
if
(
!
(
row
=
(
jsp
)
?
jsp
->
GetObject
()
:
NULL
))
break
;
}
// endor i
if
(
tdp
->
Pretty
!=
2
)
tjnp
->
CloseDB
(
g
);
skipit:
if
(
trace
(
1
))
htrc
(
"JSONColumns: n=%d len=%d
\n
"
,
n
,
length
[
0
]);
/*********************************************************************/
/* Allocate the structures used to refer to the result set. */
/*********************************************************************/
qrp
=
PlgAllocResult
(
g
,
ncol
,
n
,
IDS_COLUMNS
+
3
,
buftyp
,
fldtyp
,
length
,
false
,
false
);
crp
=
qrp
->
Colresp
->
Next
->
Next
->
Next
->
Next
->
Next
->
Next
;
crp
->
Name
=
"Nullable"
;
crp
->
Next
->
Name
=
"Jpath"
;
if
(
info
||
!
qrp
)
return
qrp
;
qrp
->
Nblin
=
n
;
/*********************************************************************/
/* Now get the results into blocks. */
/*********************************************************************/
for
(
i
=
0
,
jcp
=
fjcp
;
jcp
;
i
++
,
jcp
=
jcp
->
Next
)
{
if
(
jcp
->
Type
==
TYPE_UNKNOWN
)
jcp
->
Type
=
TYPE_STRING
;
// Void column
crp
=
qrp
->
Colresp
;
// Column Name
crp
->
Kdata
->
SetValue
(
jcp
->
Name
,
i
);
crp
=
crp
->
Next
;
// Data Type
crp
->
Kdata
->
SetValue
(
jcp
->
Type
,
i
);
crp
=
crp
->
Next
;
// Type Name
crp
->
Kdata
->
SetValue
(
GetTypeName
(
jcp
->
Type
),
i
);
crp
=
crp
->
Next
;
// Precision
crp
->
Kdata
->
SetValue
(
jcp
->
Len
,
i
);
crp
=
crp
->
Next
;
// Length
crp
->
Kdata
->
SetValue
(
jcp
->
Len
,
i
);
crp
=
crp
->
Next
;
// Scale (precision)
crp
->
Kdata
->
SetValue
(
jcp
->
Scale
,
i
);
crp
=
crp
->
Next
;
// Nullable
crp
->
Kdata
->
SetValue
(
jcp
->
Cbn
?
1
:
0
,
i
);
crp
=
crp
->
Next
;
// Field format
if
(
crp
->
Kdata
)
crp
->
Kdata
->
SetValue
(
jcp
->
Fmt
,
i
);
}
// endfor i
/*********************************************************************/
/* Return the result pointer. */
/*********************************************************************/
return
qrp
;
err:
if
(
tdp
->
Pretty
!=
2
)
tjnp
->
CloseDB
(
g
);
return
NULL
;
}
// end of JSONColumns
/* -------------------------- Class JSONDEF -------------------------- */
...
...
@@ -513,6 +559,7 @@ bool JSONDEF::DefineAM(PGLOBAL g, LPCSTR, int poff)
Limit
=
GetIntCatInfo
(
"Limit"
,
10
);
Base
=
GetIntCatInfo
(
"Base"
,
0
)
?
1
:
0
;
Sep
=
*
GetStringCatInfo
(
g
,
"Separator"
,
"."
);
Accept
=
GetBoolCatInfo
(
"Accept"
,
false
);
if
(
Uri
=
GetStringCatInfo
(
g
,
"Connect"
,
NULL
))
{
#if defined(JAVA_SUPPORT) || defined(CMGO_SUPPORT)
...
...
@@ -1471,6 +1518,9 @@ void JSONCOL::ReadColumn(PGLOBAL g)
if
(
!
Tjp
->
SameRow
||
Xnod
>=
Tjp
->
SameRow
)
Value
->
SetValue_pval
(
GetColumnValue
(
g
,
Tjp
->
Row
,
0
));
if
(
Xpd
&&
Value
->
IsNull
()
&&
!
((
PJDEF
)
Tjp
->
To_Def
)
->
Accept
)
throw
(
"Null expandable JSON value"
);
// Set null when applicable
if
(
!
Nullable
)
Value
->
SetNull
(
false
);
...
...
@@ -1546,11 +1596,16 @@ PVAL JSONCOL::GetColumnValue(PGLOBAL g, PJSON row, int i)
/***********************************************************************/
PVAL
JSONCOL
::
ExpandArray
(
PGLOBAL
g
,
PJAR
arp
,
int
n
)
{
int
ars
;
int
ars
=
MY_MIN
(
Tjp
->
Limit
,
arp
->
size
())
;
PJVAL
jvp
;
JVALUE
jval
;
ars
=
MY_MIN
(
Tjp
->
Limit
,
arp
->
size
());
if
(
!
ars
)
{
Value
->
Reset
();
Value
->
SetNull
(
true
);
Tjp
->
NextSame
=
0
;
return
Value
;
}
// endif ars
if
(
!
(
jvp
=
arp
->
GetValue
((
Nodes
[
n
].
Rx
=
Nodes
[
n
].
Nx
))))
{
strcpy
(
g
->
Message
,
"Logical error expanding array"
);
...
...
storage/connect/tabjson.h
View file @
a88bdbdc
...
...
@@ -15,6 +15,7 @@ enum JMODE {MODE_OBJECT, MODE_ARRAY, MODE_VALUE};
typedef
class
JSONDEF
*
PJDEF
;
typedef
class
TDBJSON
*
PJTDB
;
typedef
class
JSONCOL
*
PJCOL
;
class
TDBJSN
;
/***********************************************************************/
/* The JSON tree node. Can be an Object or an Array. */
...
...
@@ -29,6 +30,47 @@ typedef struct _jnode {
int
Nx
;
// Next to read row number
}
JNODE
,
*
PJNODE
;
typedef
struct
_jncol
{
struct
_jncol
*
Next
;
char
*
Name
;
char
*
Fmt
;
int
Type
;
int
Len
;
int
Scale
;
bool
Cbn
;
bool
Found
;
}
JCOL
,
*
PJCL
;
/***********************************************************************/
/* Class used to get the columns of a mongo collection. */
/***********************************************************************/
class
JSONDISC
:
public
BLOCK
{
public:
// Constructor
JSONDISC
(
PGLOBAL
g
,
int
*
lg
);
// Functions
int
GetColumns
(
PGLOBAL
g
,
PCSZ
db
,
PCSZ
dsn
,
PTOS
topt
);
bool
Find
(
PGLOBAL
g
,
PJVAL
jvp
,
int
j
);
void
AddColumn
(
PGLOBAL
g
);
// Members
JCOL
jcol
;
PJCL
jcp
,
fjcp
,
pjcp
;
PVAL
valp
;
PJDEF
tdp
;
TDBJSN
*
tjnp
;
PJTDB
tjsp
;
PJPR
jpp
;
PJSON
jsp
;
PJOB
row
;
PCSZ
sep
;
char
colname
[
65
],
fmt
[
129
],
buf
[
16
];
int
*
length
;
int
i
,
n
,
bf
,
ncol
,
lvl
;
bool
all
;
};
// end of JSONDISC
/***********************************************************************/
/* JSON table. */
/***********************************************************************/
...
...
@@ -36,13 +78,13 @@ class DllExport JSONDEF : public DOSDEF { /* Table description */
friend
class
TDBJSON
;
friend
class
TDBJSN
;
friend
class
TDBJCL
;
friend
class
JSONDISC
;
#if defined(CMGO_SUPPORT)
friend
class
CMGFAM
;
#endif // CMGO_SUPPORT
#if defined(JAVA_SUPPORT)
friend
class
JMGFAM
;
#endif // JAVA_SUPPORT
friend
PQRYRES
JSONColumns
(
PGLOBAL
,
PCSZ
,
PCSZ
,
PTOS
,
bool
);
public:
// Constructor
JSONDEF
(
void
);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment