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
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
mariadb
Commits
e33b48ae
Commit
e33b48ae
authored
Mar 02, 2015
by
Sergei Golubchik
Browse files
Options
Browse Files
Download
Plain Diff
Merge remote-tracking branch 'origin/10.0' into 10.0
parents
aa845d12
c06c465a
Changes
22
Hide whitespace changes
Inline
Side-by-side
Showing
22 changed files
with
711 additions
and
143 deletions
+711
-143
storage/connect/ha_connect.cc
storage/connect/ha_connect.cc
+3
-0
storage/connect/json.cpp
storage/connect/json.cpp
+67
-17
storage/connect/json.h
storage/connect/json.h
+7
-2
storage/connect/jsonudf.cpp
storage/connect/jsonudf.cpp
+47
-3
storage/connect/mysql-test/connect/r/json.result
storage/connect/mysql-test/connect/r/json.result
+36
-16
storage/connect/mysql-test/connect/r/json_udf.result
storage/connect/mysql-test/connect/r/json_udf.result
+167
-0
storage/connect/mysql-test/connect/r/odbc_oracle.result
storage/connect/mysql-test/connect/r/odbc_oracle.result
+5
-5
storage/connect/mysql-test/connect/std_data/biblio.json
storage/connect/mysql-test/connect/std_data/biblio.json
+0
-0
storage/connect/mysql-test/connect/std_data/expense.json
storage/connect/mysql-test/connect/std_data/expense.json
+0
-0
storage/connect/mysql-test/connect/std_data/mulexp3.json
storage/connect/mysql-test/connect/std_data/mulexp3.json
+0
-0
storage/connect/mysql-test/connect/std_data/mulexp4.json
storage/connect/mysql-test/connect/std_data/mulexp4.json
+0
-0
storage/connect/mysql-test/connect/std_data/mulexp5.json
storage/connect/mysql-test/connect/std_data/mulexp5.json
+0
-0
storage/connect/mysql-test/connect/t/json.test
storage/connect/mysql-test/connect/t/json.test
+43
-26
storage/connect/mysql-test/connect/t/json_udf.inc
storage/connect/mysql-test/connect/t/json_udf.inc
+33
-0
storage/connect/mysql-test/connect/t/json_udf.test
storage/connect/mysql-test/connect/t/json_udf.test
+93
-0
storage/connect/odbconn.cpp
storage/connect/odbconn.cpp
+36
-37
storage/connect/odbconn.h
storage/connect/odbconn.h
+2
-2
storage/connect/tabjson.cpp
storage/connect/tabjson.cpp
+51
-6
storage/connect/tabjson.h
storage/connect/tabjson.h
+4
-2
storage/connect/tabodbc.cpp
storage/connect/tabodbc.cpp
+106
-23
storage/connect/tabodbc.h
storage/connect/tabodbc.h
+4
-1
storage/connect/tabutil.cpp
storage/connect/tabutil.cpp
+7
-3
No files found.
storage/connect/ha_connect.cc
View file @
e33b48ae
...
@@ -4112,6 +4112,7 @@ MODE ha_connect::CheckMode(PGLOBAL g, THD *thd,
...
@@ -4112,6 +4112,7 @@ MODE ha_connect::CheckMode(PGLOBAL g, THD *thd,
case
SQLCOM_UPDATE_MULTI
:
case
SQLCOM_UPDATE_MULTI
:
case
SQLCOM_SELECT
:
case
SQLCOM_SELECT
:
case
SQLCOM_OPTIMIZE
:
case
SQLCOM_OPTIMIZE
:
case
SQLCOM_SET_OPTION
:
break
;
break
;
case
SQLCOM_LOCK_TABLES
:
case
SQLCOM_LOCK_TABLES
:
locked
=
1
;
locked
=
1
;
...
@@ -5461,7 +5462,9 @@ static int connect_assisted_discovery(handlerton *hton, THD* thd,
...
@@ -5461,7 +5462,9 @@ static int connect_assisted_discovery(handlerton *hton, THD* thd,
case
TYPE_DOUBLE
:
case
TYPE_DOUBLE
:
// Some data sources do not count dec in length (prec)
// Some data sources do not count dec in length (prec)
prec
+=
(
dec
+
2
);
// To be safe
prec
+=
(
dec
+
2
);
// To be safe
break
;
case
TYPE_DECIM
:
case
TYPE_DECIM
:
prec
=
len
;
break
;
break
;
default:
default:
dec
=
0
;
dec
=
0
;
...
...
storage/connect/json.cpp
View file @
e33b48ae
...
@@ -662,7 +662,7 @@ JOUTSTR::JOUTSTR(PGLOBAL g) : JOUT(g)
...
@@ -662,7 +662,7 @@ JOUTSTR::JOUTSTR(PGLOBAL g) : JOUT(g)
N
=
0
;
N
=
0
;
Max
=
pph
->
FreeBlk
;
Max
=
pph
->
FreeBlk
;
Max
=
(
Max
>
512
)
?
Max
-
51
2
:
Max
;
Max
=
(
Max
>
32
)
?
Max
-
3
2
:
Max
;
Strp
=
(
char
*
)
PlugSubAlloc
(
g
,
NULL
,
0
);
// Size not know yet
Strp
=
(
char
*
)
PlugSubAlloc
(
g
,
NULL
,
0
);
// Size not know yet
}
// end of JOUTSTR constructor
}
// end of JOUTSTR constructor
...
@@ -881,27 +881,26 @@ PJVAL JOBJECT::GetValue(const char* key)
...
@@ -881,27 +881,26 @@ PJVAL JOBJECT::GetValue(const char* key)
/***********************************************************************/
/***********************************************************************/
/* Return the text corresponding to all keys (XML like). */
/* Return the text corresponding to all keys (XML like). */
/***********************************************************************/
/***********************************************************************/
PSZ
JOBJECT
::
GetText
(
PGLOBAL
g
)
PSZ
JOBJECT
::
GetText
(
PGLOBAL
g
,
PSZ
text
)
{
{
char
*
p
,
*
text
=
(
char
*
)
PlugSubAlloc
(
g
,
NULL
,
0
);
int
n
;
bool
b
=
true
;
if
(
!
First
)
if
(
!
text
)
{
return
NULL
;
text
=
(
char
*
)
PlugSubAlloc
(
g
,
NULL
,
0
);
else
for
(
PJPR
jp
=
First
;
jp
;
jp
=
jp
->
Next
)
{
text
[
0
]
=
0
;
if
(
!
(
p
=
jp
->
Val
->
GetString
()))
n
=
1
;
p
=
"???"
;
}
else
n
=
0
;
if
(
b
)
{
if
(
!
First
&&
n
)
strcpy
(
text
,
p
);
return
NULL
;
b
=
false
;
else
for
(
PJPR
jp
=
First
;
jp
;
jp
=
jp
->
Next
)
}
else
jp
->
Val
->
GetText
(
g
,
text
);
strcat
(
strcat
(
text
,
" "
),
p
);
}
// endfor jp
if
(
n
)
PlugSubAlloc
(
g
,
NULL
,
strlen
(
text
)
+
1
);
PlugSubAlloc
(
g
,
NULL
,
strlen
(
text
)
+
1
);
return
text
+
n
;
return
text
;
}
// end of GetValue;
}
// end of GetValue;
/***********************************************************************/
/***********************************************************************/
...
@@ -924,6 +923,18 @@ void JOBJECT::SetValue(PGLOBAL g, PJVAL jvp, PSZ key)
...
@@ -924,6 +923,18 @@ void JOBJECT::SetValue(PGLOBAL g, PJVAL jvp, PSZ key)
}
// end of SetValue
}
// end of SetValue
/***********************************************************************/
/* True if void or if all members are nulls. */
/***********************************************************************/
bool
JOBJECT
::
IsNull
(
void
)
{
for
(
PJPR
jp
=
First
;
jp
;
jp
=
jp
->
Next
)
if
(
!
jp
->
Val
->
IsNull
())
return
false
;
return
true
;
}
// end of IsNull
/* -------------------------- Class JARRAY --------------------------- */
/* -------------------------- Class JARRAY --------------------------- */
/***********************************************************************/
/***********************************************************************/
...
@@ -1012,6 +1023,18 @@ bool JARRAY::DeleteValue(int n)
...
@@ -1012,6 +1023,18 @@ bool JARRAY::DeleteValue(int n)
}
// end of DeleteValue
}
// end of DeleteValue
/***********************************************************************/
/* True if void or if all members are nulls. */
/***********************************************************************/
bool
JARRAY
::
IsNull
(
void
)
{
for
(
int
i
=
0
;
i
<
Size
;
i
++
)
if
(
!
Mvals
[
i
]
->
IsNull
())
return
false
;
return
true
;
}
// end of IsNull
/* -------------------------- Class JVALUE- -------------------------- */
/* -------------------------- Class JVALUE- -------------------------- */
/***********************************************************************/
/***********************************************************************/
...
@@ -1086,6 +1109,25 @@ PSZ JVALUE::GetString(void)
...
@@ -1086,6 +1109,25 @@ PSZ JVALUE::GetString(void)
return
(
Value
)
?
Value
->
GetCharString
(
buf
)
:
NULL
;
return
(
Value
)
?
Value
->
GetCharString
(
buf
)
:
NULL
;
}
// end of GetString
}
// end of GetString
/***********************************************************************/
/* Return the Value's String value. */
/***********************************************************************/
PSZ
JVALUE
::
GetText
(
PGLOBAL
g
,
PSZ
text
)
{
if
(
Jsp
&&
Jsp
->
GetType
()
==
TYPE_JOB
)
return
Jsp
->
GetText
(
g
,
text
);
char
buf
[
32
];
PSZ
s
=
(
Value
)
?
Value
->
GetCharString
(
buf
)
:
NULL
;
if
(
s
)
strcat
(
strcat
(
text
,
" "
),
s
);
else
strcat
(
text
,
" ???"
);
return
text
;
}
// end of GetText
/***********************************************************************/
/***********************************************************************/
/* Set the Value's value as the given integer. */
/* Set the Value's value as the given integer. */
/***********************************************************************/
/***********************************************************************/
...
@@ -1110,3 +1152,11 @@ void JVALUE::SetString(PGLOBAL g, PSZ s)
...
@@ -1110,3 +1152,11 @@ void JVALUE::SetString(PGLOBAL g, PSZ s)
Value
=
AllocateValue
(
g
,
s
,
TYPE_STRING
);
Value
=
AllocateValue
(
g
,
s
,
TYPE_STRING
);
}
// end of AddFloat
}
// end of AddFloat
/***********************************************************************/
/* True when its JSON or normal value is null. */
/***********************************************************************/
bool
JVALUE
::
IsNull
(
void
)
{
return
(
Jsp
)
?
Jsp
->
IsNull
()
:
(
Value
)
?
Value
->
IsNull
()
:
true
;
}
// end of IsNull
storage/connect/json.h
View file @
e33b48ae
...
@@ -152,7 +152,7 @@ class JSON : public BLOCK {
...
@@ -152,7 +152,7 @@ class JSON : public BLOCK {
virtual
int
GetInteger
(
void
)
{
X
return
0
;}
virtual
int
GetInteger
(
void
)
{
X
return
0
;}
virtual
double
GetFloat
()
{
X
return
0.0
;}
virtual
double
GetFloat
()
{
X
return
0.0
;}
virtual
PSZ
GetString
()
{
X
return
NULL
;}
virtual
PSZ
GetString
()
{
X
return
NULL
;}
virtual
PSZ
GetText
(
PGLOBAL
g
)
{
X
return
NULL
;}
virtual
PSZ
GetText
(
PGLOBAL
g
,
PSZ
text
)
{
X
return
NULL
;}
virtual
bool
SetValue
(
PGLOBAL
g
,
PJVAL
jvp
,
int
i
)
{
X
return
true
;}
virtual
bool
SetValue
(
PGLOBAL
g
,
PJVAL
jvp
,
int
i
)
{
X
return
true
;}
virtual
void
SetValue
(
PGLOBAL
g
,
PJVAL
jvp
,
PSZ
key
)
{
X
}
virtual
void
SetValue
(
PGLOBAL
g
,
PJVAL
jvp
,
PSZ
key
)
{
X
}
virtual
void
SetValue
(
PVAL
valp
)
{
X
}
virtual
void
SetValue
(
PVAL
valp
)
{
X
}
...
@@ -161,6 +161,7 @@ class JSON : public BLOCK {
...
@@ -161,6 +161,7 @@ class JSON : public BLOCK {
virtual
void
SetInteger
(
PGLOBAL
g
,
int
n
)
{
X
}
virtual
void
SetInteger
(
PGLOBAL
g
,
int
n
)
{
X
}
virtual
void
SetFloat
(
PGLOBAL
g
,
double
f
)
{
X
}
virtual
void
SetFloat
(
PGLOBAL
g
,
double
f
)
{
X
}
virtual
bool
DeleteValue
(
int
i
)
{
X
return
true
;}
virtual
bool
DeleteValue
(
int
i
)
{
X
return
true
;}
virtual
bool
IsNull
(
void
)
{
X
return
true
;}
protected:
protected:
int
Size
;
int
Size
;
...
@@ -182,8 +183,9 @@ class JOBJECT : public JSON {
...
@@ -182,8 +183,9 @@ class JOBJECT : public JSON {
virtual
PJPR
AddPair
(
PGLOBAL
g
,
PSZ
key
);
virtual
PJPR
AddPair
(
PGLOBAL
g
,
PSZ
key
);
virtual
PJOB
GetObject
(
void
)
{
return
this
;}
virtual
PJOB
GetObject
(
void
)
{
return
this
;}
virtual
PJVAL
GetValue
(
const
char
*
key
);
virtual
PJVAL
GetValue
(
const
char
*
key
);
virtual
PSZ
GetText
(
PGLOBAL
g
);
virtual
PSZ
GetText
(
PGLOBAL
g
,
PSZ
text
);
virtual
void
SetValue
(
PGLOBAL
g
,
PJVAL
jvp
,
PSZ
key
);
virtual
void
SetValue
(
PGLOBAL
g
,
PJVAL
jvp
,
PSZ
key
);
virtual
bool
IsNull
(
void
);
protected:
protected:
PJPR
First
;
PJPR
First
;
...
@@ -208,6 +210,7 @@ class JARRAY : public JSON {
...
@@ -208,6 +210,7 @@ class JARRAY : public JSON {
virtual
PJVAL
GetValue
(
int
i
);
virtual
PJVAL
GetValue
(
int
i
);
virtual
bool
SetValue
(
PGLOBAL
g
,
PJVAL
jvp
,
int
i
);
virtual
bool
SetValue
(
PGLOBAL
g
,
PJVAL
jvp
,
int
i
);
virtual
bool
DeleteValue
(
int
n
);
virtual
bool
DeleteValue
(
int
n
);
virtual
bool
IsNull
(
void
);
protected:
protected:
// Members
// Members
...
@@ -244,11 +247,13 @@ class JVALUE : public JSON {
...
@@ -244,11 +247,13 @@ class JVALUE : public JSON {
virtual
int
GetInteger
(
void
);
virtual
int
GetInteger
(
void
);
virtual
double
GetFloat
(
void
);
virtual
double
GetFloat
(
void
);
virtual
PSZ
GetString
(
void
);
virtual
PSZ
GetString
(
void
);
virtual
PSZ
GetText
(
PGLOBAL
g
,
PSZ
text
);
virtual
void
SetValue
(
PVAL
valp
)
{
Value
=
valp
;}
virtual
void
SetValue
(
PVAL
valp
)
{
Value
=
valp
;}
virtual
void
SetValue
(
PJSON
jsp
)
{
Jsp
=
jsp
;}
virtual
void
SetValue
(
PJSON
jsp
)
{
Jsp
=
jsp
;}
virtual
void
SetString
(
PGLOBAL
g
,
PSZ
s
);
virtual
void
SetString
(
PGLOBAL
g
,
PSZ
s
);
virtual
void
SetInteger
(
PGLOBAL
g
,
int
n
);
virtual
void
SetInteger
(
PGLOBAL
g
,
int
n
);
virtual
void
SetFloat
(
PGLOBAL
g
,
double
f
);
virtual
void
SetFloat
(
PGLOBAL
g
,
double
f
);
virtual
bool
IsNull
(
void
);
protected:
protected:
PJSON
Jsp
;
// To the json value
PJSON
Jsp
;
// To the json value
...
...
storage/connect/jsonudf.cpp
View file @
e33b48ae
...
@@ -37,6 +37,10 @@ DllExport my_bool Json_Object_init(UDF_INIT*, UDF_ARGS*, char*);
...
@@ -37,6 +37,10 @@ DllExport my_bool Json_Object_init(UDF_INIT*, UDF_ARGS*, char*);
DllExport
char
*
Json_Object
(
UDF_INIT
*
,
UDF_ARGS
*
,
char
*
,
DllExport
char
*
Json_Object
(
UDF_INIT
*
,
UDF_ARGS
*
,
char
*
,
unsigned
long
*
,
char
*
,
char
*
);
unsigned
long
*
,
char
*
,
char
*
);
DllExport
void
Json_Object_deinit
(
UDF_INIT
*
);
DllExport
void
Json_Object_deinit
(
UDF_INIT
*
);
DllExport
my_bool
Json_Object_Nonull_init
(
UDF_INIT
*
,
UDF_ARGS
*
,
char
*
);
DllExport
char
*
Json_Object_Nonull
(
UDF_INIT
*
,
UDF_ARGS
*
,
char
*
,
unsigned
long
*
,
char
*
,
char
*
);
DllExport
void
Json_Object_Nonull_deinit
(
UDF_INIT
*
);
DllExport
my_bool
Json_Array_Grp_init
(
UDF_INIT
*
,
UDF_ARGS
*
,
char
*
);
DllExport
my_bool
Json_Array_Grp_init
(
UDF_INIT
*
,
UDF_ARGS
*
,
char
*
);
DllExport
void
Json_Array_Grp_add
(
UDF_INIT
*
,
UDF_ARGS
*
,
char
*
,
char
*
);
DllExport
void
Json_Array_Grp_add
(
UDF_INIT
*
,
UDF_ARGS
*
,
char
*
,
char
*
);
DllExport
char
*
Json_Array_Grp
(
UDF_INIT
*
,
UDF_ARGS
*
,
char
*
,
DllExport
char
*
Json_Array_Grp
(
UDF_INIT
*
,
UDF_ARGS
*
,
char
*
,
...
@@ -228,7 +232,7 @@ static PSZ MakeKey(PGLOBAL g, UDF_ARGS *args, int i)
...
@@ -228,7 +232,7 @@ static PSZ MakeKey(PGLOBAL g, UDF_ARGS *args, int i)
/***********************************************************************/
/***********************************************************************/
static
PJVAL
MakeValue
(
PGLOBAL
g
,
UDF_ARGS
*
args
,
int
i
)
static
PJVAL
MakeValue
(
PGLOBAL
g
,
UDF_ARGS
*
args
,
int
i
)
{
{
char
*
sap
=
args
->
args
[
i
]
;
char
*
sap
=
(
args
->
arg_count
>
(
unsigned
)
i
)
?
args
->
args
[
i
]
:
NULL
;
PJSON
jsp
;
PJSON
jsp
;
PJVAL
jvp
=
new
(
g
)
JVALUE
;
PJVAL
jvp
=
new
(
g
)
JVALUE
;
...
@@ -358,7 +362,7 @@ my_bool Json_Array_Add_init(UDF_INIT *initid, UDF_ARGS *args, char *message)
...
@@ -358,7 +362,7 @@ my_bool Json_Array_Add_init(UDF_INIT *initid, UDF_ARGS *args, char *message)
strcpy
(
message
,
"Json_Value_Add must have at least 2 arguments"
);
strcpy
(
message
,
"Json_Value_Add must have at least 2 arguments"
);
return
true
;
return
true
;
}
else
if
(
!
IsJson
(
args
,
0
))
{
}
else
if
(
!
IsJson
(
args
,
0
))
{
strcpy
(
message
,
"Json_Value_Add first argument must be a json
array
"
);
strcpy
(
message
,
"Json_Value_Add first argument must be a json
item
"
);
return
true
;
return
true
;
}
else
}
else
CalcLen
(
args
,
false
,
reslen
,
memlen
);
CalcLen
(
args
,
false
,
reslen
,
memlen
);
...
@@ -437,6 +441,46 @@ void Json_Object_deinit(UDF_INIT* initid)
...
@@ -437,6 +441,46 @@ void Json_Object_deinit(UDF_INIT* initid)
PlugExit
((
PGLOBAL
)
initid
->
ptr
);
PlugExit
((
PGLOBAL
)
initid
->
ptr
);
}
// end of Json_Object_deinit
}
// end of Json_Object_deinit
/***********************************************************************/
/* Make a Json Oject containing all not null parameters. */
/***********************************************************************/
my_bool
Json_Object_Nonull_init
(
UDF_INIT
*
initid
,
UDF_ARGS
*
args
,
char
*
message
)
{
unsigned
long
reslen
,
memlen
;
CalcLen
(
args
,
true
,
reslen
,
memlen
);
return
JsonInit
(
initid
,
message
,
reslen
,
memlen
);
}
// end of Json_Object_Nonull_init
char
*
Json_Object_Nonull
(
UDF_INIT
*
initid
,
UDF_ARGS
*
args
,
char
*
result
,
unsigned
long
*
res_length
,
char
*
is_null
,
char
*
error
)
{
char
*
str
;
uint
i
;
PJOB
objp
;
PJVAL
jvp
;
PGLOBAL
g
=
(
PGLOBAL
)
initid
->
ptr
;
PlugSubSet
(
g
,
g
->
Sarea
,
g
->
Sarea_Size
);
objp
=
new
(
g
)
JOBJECT
;
for
(
i
=
0
;
i
<
args
->
arg_count
;
i
++
)
if
(
!
(
jvp
=
MakeValue
(
g
,
args
,
i
))
->
IsNull
())
objp
->
SetValue
(
g
,
jvp
,
MakeKey
(
g
,
args
,
i
));
if
(
!
(
str
=
Serialize
(
g
,
objp
,
NULL
,
0
)))
str
=
strcpy
(
result
,
g
->
Message
);
*
res_length
=
strlen
(
str
);
return
str
;
}
// end of Json_Object_Nonull
void
Json_Object_Nonull_deinit
(
UDF_INIT
*
initid
)
{
PlugExit
((
PGLOBAL
)
initid
->
ptr
);
}
// end of Json_Object_nonull_deinit
/***********************************************************************/
/***********************************************************************/
/* Make a Json array from values comming from rows. */
/* Make a Json array from values comming from rows. */
/***********************************************************************/
/***********************************************************************/
...
@@ -517,7 +561,7 @@ my_bool Json_Object_Grp_init(UDF_INIT *initid, UDF_ARGS *args, char *message)
...
@@ -517,7 +561,7 @@ my_bool Json_Object_Grp_init(UDF_INIT *initid, UDF_ARGS *args, char *message)
unsigned
long
reslen
,
memlen
,
n
=
GetJsonGrpSize
();
unsigned
long
reslen
,
memlen
,
n
=
GetJsonGrpSize
();
if
(
args
->
arg_count
!=
2
)
{
if
(
args
->
arg_count
!=
2
)
{
strcpy
(
message
,
"Json_Array_Grp can only accept 2 argument"
);
strcpy
(
message
,
"Json_Array_Grp can only accept 2 argument
s
"
);
return
true
;
return
true
;
}
else
}
else
CalcLen
(
args
,
true
,
reslen
,
memlen
);
CalcLen
(
args
,
true
,
reslen
,
memlen
);
...
...
storage/connect/mysql-test/connect/r/json.result
View file @
e33b48ae
...
@@ -12,7 +12,7 @@ TRANSLATION CHAR(32),
...
@@ -12,7 +12,7 @@ TRANSLATION CHAR(32),
TRANSLATOR CHAR(80),
TRANSLATOR CHAR(80),
PUBLISHER CHAR(32),
PUBLISHER CHAR(32),
DATEPUB int(4)
DATEPUB int(4)
) ENGINE=CONNECT TABLE_TYPE=JSON FILE_NAME='biblio.jsn';
) ENGINE=CONNECT TABLE_TYPE=JSON FILE_NAME='biblio.js
o
n';
SELECT * FROM t1;
SELECT * FROM t1;
ISBN LANG SUBJECT AUTHOR TITLE TRANSLATION TRANSLATOR PUBLISHER DATEPUB
ISBN LANG SUBJECT AUTHOR TITLE TRANSLATION TRANSLATOR PUBLISHER DATEPUB
9782212090819 fr applications Jean-Christophe Bernadac Construire une application XML Eyrolles Paris 1999
9782212090819 fr applications Jean-Christophe Bernadac Construire une application XML Eyrolles Paris 1999
...
@@ -34,7 +34,7 @@ Publisher CHAR(20) FIELD_FORMAT='PUBLISHER:NAME',
...
@@ -34,7 +34,7 @@ Publisher CHAR(20) FIELD_FORMAT='PUBLISHER:NAME',
Location CHAR(16) FIELD_FORMAT='PUBLISHER:PLACE',
Location CHAR(16) FIELD_FORMAT='PUBLISHER:PLACE',
Year int(4) FIELD_FORMAT='DATEPUB'
Year int(4) FIELD_FORMAT='DATEPUB'
)
)
ENGINE=CONNECT TABLE_TYPE=JSON FILE_NAME='biblio.jsn';
ENGINE=CONNECT TABLE_TYPE=JSON FILE_NAME='biblio.js
o
n';
SELECT * FROM t1;
SELECT * FROM t1;
ISBN Language Subject Authors Title Translation Translator Publisher Location Year
ISBN Language Subject Authors Title Translation Translator Publisher Location Year
9782212090819 fr applications 2 Construire une application XML Eyrolles Paris 1999
9782212090819 fr applications 2 Construire une application XML Eyrolles Paris 1999
...
@@ -57,7 +57,7 @@ Publisher CHAR(20) FIELD_FORMAT='PUBLISHER:NAME',
...
@@ -57,7 +57,7 @@ Publisher CHAR(20) FIELD_FORMAT='PUBLISHER:NAME',
Location CHAR(16) FIELD_FORMAT='PUBLISHER:PLACE',
Location CHAR(16) FIELD_FORMAT='PUBLISHER:PLACE',
Year int(4) FIELD_FORMAT='DATEPUB'
Year int(4) FIELD_FORMAT='DATEPUB'
)
)
ENGINE=CONNECT TABLE_TYPE=JSON FILE_NAME='biblio.jsn';
ENGINE=CONNECT TABLE_TYPE=JSON FILE_NAME='biblio.js
o
n';
SELECT * FROM t1;
SELECT * FROM t1;
ISBN Language Subject AuthorFN AuthorLN Title Translation Translator Publisher Location Year
ISBN Language Subject AuthorFN AuthorLN Title Translation Translator Publisher Location Year
9782212090819 fr applications Jean-Christophe and Franois Bernadac and Knab Construire une application XML Eyrolles Paris 1999
9782212090819 fr applications Jean-Christophe and Franois Bernadac and Knab Construire une application XML Eyrolles Paris 1999
...
@@ -80,7 +80,7 @@ Publisher CHAR(20) FIELD_FORMAT='PUBLISHER:NAME',
...
@@ -80,7 +80,7 @@ Publisher CHAR(20) FIELD_FORMAT='PUBLISHER:NAME',
Location CHAR(16) FIELD_FORMAT='PUBLISHER:PLACE',
Location CHAR(16) FIELD_FORMAT='PUBLISHER:PLACE',
Year int(4) FIELD_FORMAT='DATEPUB'
Year int(4) FIELD_FORMAT='DATEPUB'
)
)
ENGINE=CONNECT TABLE_TYPE=JSON FILE_NAME='biblio.jsn';
ENGINE=CONNECT TABLE_TYPE=JSON FILE_NAME='biblio.js
o
n';
SELECT * FROM t1;
SELECT * FROM t1;
ISBN Language Subject AuthorFN AuthorLN Title Translation Translator Publisher Location Year
ISBN Language Subject AuthorFN AuthorLN Title Translation Translator Publisher Location Year
9782212090819 fr applications Jean-Christophe Bernadac Construire une application XML Eyrolles Paris 1999
9782212090819 fr applications Jean-Christophe Bernadac Construire une application XML Eyrolles Paris 1999
...
@@ -97,7 +97,7 @@ ISBN Language Subject AuthorFN AuthorLN Title Translation Translator Publisher L
...
@@ -97,7 +97,7 @@ ISBN Language Subject AuthorFN AuthorLN Title Translation Translator Publisher L
CREATE TABLE t2 (
CREATE TABLE t2 (
FIRSTNAME CHAR(32),
FIRSTNAME CHAR(32),
LASTNAME CHAR(32))
LASTNAME CHAR(32))
ENGINE=CONNECT TABLE_TYPE=JSON FILE_NAME='biblio.jsn' OPTION_LIST='Object=[2]:AUTHOR';
ENGINE=CONNECT TABLE_TYPE=JSON FILE_NAME='biblio.js
o
n' OPTION_LIST='Object=[2]:AUTHOR';
SELECT * FROM t2;
SELECT * FROM t2;
FIRSTNAME LASTNAME
FIRSTNAME LASTNAME
William J. Pardi
William J. Pardi
...
@@ -117,7 +117,7 @@ CREATE TABLE t1
...
@@ -117,7 +117,7 @@ CREATE TABLE t1
(
(
line char(255)
line char(255)
)
)
ENGINE=CONNECT TABLE_TYPE=DOS FILE_NAME='biblio.jsn';
ENGINE=CONNECT TABLE_TYPE=DOS FILE_NAME='biblio.js
o
n';
SELECT * FROM t1;
SELECT * FROM t1;
line
line
[
[
...
@@ -178,7 +178,7 @@ WHO CHAR(12),
...
@@ -178,7 +178,7 @@ WHO CHAR(12),
WEEK INT(2) FIELD_FORMAT='WEEK:[X]:NUMBER',
WEEK INT(2) FIELD_FORMAT='WEEK:[X]:NUMBER',
WHAT CHAR(32) FIELD_FORMAT='WEEK::EXPENSE:["+"]:WHAT',
WHAT CHAR(32) FIELD_FORMAT='WEEK::EXPENSE:["+"]:WHAT',
AMOUNT DOUBLE(8,2) FIELD_FORMAT='WEEK::EXPENSE:[+]:AMOUNT')
AMOUNT DOUBLE(8,2) FIELD_FORMAT='WEEK::EXPENSE:[+]:AMOUNT')
ENGINE=CONNECT TABLE_TYPE=JSON FILE_NAME='expense.jsn';
ENGINE=CONNECT TABLE_TYPE=JSON FILE_NAME='expense.js
o
n';
SELECT * FROM t1;
SELECT * FROM t1;
WHO WEEK WHAT AMOUNT
WHO WEEK WHAT AMOUNT
Joe 3 Beer+Food+Food+Car 69.00
Joe 3 Beer+Food+Food+Car 69.00
...
@@ -199,7 +199,7 @@ WHO CHAR(12),
...
@@ -199,7 +199,7 @@ WHO CHAR(12),
WEEK INT(2) FIELD_FORMAT='WEEK:[X]:NUMBER',
WEEK INT(2) FIELD_FORMAT='WEEK:[X]:NUMBER',
WHAT CHAR(32) FIELD_FORMAT='WEEK:[X]:EXPENSE:[X]:WHAT',
WHAT CHAR(32) FIELD_FORMAT='WEEK:[X]:EXPENSE:[X]:WHAT',
AMOUNT DOUBLE(8,2) FIELD_FORMAT='WEEK:[X]:EXPENSE:[X]:AMOUNT')
AMOUNT DOUBLE(8,2) FIELD_FORMAT='WEEK:[X]:EXPENSE:[X]:AMOUNT')
ENGINE=CONNECT TABLE_TYPE=JSON FILE_NAME='expense.jsn';
ENGINE=CONNECT TABLE_TYPE=JSON FILE_NAME='expense.js
o
n';
SELECT * FROM t1;
SELECT * FROM t1;
WHO WEEK WHAT AMOUNT
WHO WEEK WHAT AMOUNT
Joe 3 Beer 18.00
Joe 3 Beer 18.00
...
@@ -228,6 +228,26 @@ Janet 5 Beer 19.00
...
@@ -228,6 +228,26 @@ Janet 5 Beer 19.00
Janet 5 Food 12.00
Janet 5 Food 12.00
DROP TABLE t1;
DROP TABLE t1;
#
#
# A table showing many calculated results
#
CREATE TABLE t1 (
WHO CHAR(12) NOT NULL,
WEEKS CHAR(12) NOT NULL FIELD_FORMAT='WEEK:[", "]:NUMBER',
SUMS CHAR(64) NOT NULL FIELD_FORMAT='WEEK:["+"]:EXPENSE:[+]:AMOUNT',
SUM DOUBLE(8,2) NOT NULL FIELD_FORMAT='WEEK:[+]:EXPENSE:[+]:AMOUNT',
AVGS CHAR(64) NOT NULL FIELD_FORMAT='WEEK:["+"]:EXPENSE:[!]:AMOUNT',
SUMAVG DOUBLE(8,2) NOT NULL FIELD_FORMAT='WEEK:[+]:EXPENSE:[!]:AMOUNT',
AVGSUM DOUBLE(8,2) NOT NULL FIELD_FORMAT='WEEK:[!]:EXPENSE:[+]:AMOUNT',
AVGAVG DOUBLE(8,2) NOT NULL FIELD_FORMAT='WEEK:[!]:EXPENSE:[!]:AMOUNT',
AVERAGE DOUBLE(8,2) NOT NULL FIELD_FORMAT='WEEK:[!]:EXPENSE:[X]:AMOUNT')
ENGINE=CONNECT TABLE_TYPE=JSON FILE_NAME='expense.json';
SELECT * FROM t1;
WHO WEEKS SUMS SUM AVGS SUMAVG AVGSUM AVGAVG AVERAGE
Joe 3, 4, 5 69.00+83.00+26.00 178.00 17.25+16.60+13.00 46.85 59.33 15.62 16.18
Beth 3, 4, 5 16.00+32.00+32.00 80.00 16.00+16.00+16.00 48.00 26.67 16.00 16.00
Janet 3, 4, 5 55.00+17.00+57.00 129.00 18.33+17.00+14.25 49.58 43.00 16.53 16.12
DROP TABLE t1;
#
# Expand expense in 3 one week tables
# Expand expense in 3 one week tables
#
#
CREATE TABLE t2 (
CREATE TABLE t2 (
...
@@ -235,7 +255,7 @@ WHO CHAR(12),
...
@@ -235,7 +255,7 @@ WHO CHAR(12),
WEEK INT(2) FIELD_FORMAT='WEEK:[1]:NUMBER',
WEEK INT(2) FIELD_FORMAT='WEEK:[1]:NUMBER',
WHAT CHAR(32) FIELD_FORMAT='WEEK:[1]:EXPENSE:[X]:WHAT',
WHAT CHAR(32) FIELD_FORMAT='WEEK:[1]:EXPENSE:[X]:WHAT',
AMOUNT DOUBLE(8,2) FIELD_FORMAT='WEEK:[1]:EXPENSE:[X]:AMOUNT')
AMOUNT DOUBLE(8,2) FIELD_FORMAT='WEEK:[1]:EXPENSE:[X]:AMOUNT')
ENGINE=CONNECT TABLE_TYPE=JSON FILE_NAME='expense.jsn';
ENGINE=CONNECT TABLE_TYPE=JSON FILE_NAME='expense.js
o
n';
SELECT * FROM t2;
SELECT * FROM t2;
WHO WEEK WHAT AMOUNT
WHO WEEK WHAT AMOUNT
Joe 3 Beer 18.00
Joe 3 Beer 18.00
...
@@ -251,7 +271,7 @@ WHO CHAR(12),
...
@@ -251,7 +271,7 @@ WHO CHAR(12),
WEEK INT(2) FIELD_FORMAT='WEEK:[2]:NUMBER',
WEEK INT(2) FIELD_FORMAT='WEEK:[2]:NUMBER',
WHAT CHAR(32) FIELD_FORMAT='WEEK:[2]:EXPENSE:[X]:WHAT',
WHAT CHAR(32) FIELD_FORMAT='WEEK:[2]:EXPENSE:[X]:WHAT',
AMOUNT DOUBLE(8,2) FIELD_FORMAT='WEEK:[2]:EXPENSE:[X]:AMOUNT')
AMOUNT DOUBLE(8,2) FIELD_FORMAT='WEEK:[2]:EXPENSE:[X]:AMOUNT')
ENGINE=CONNECT TABLE_TYPE=JSON FILE_NAME='expense.jsn';
ENGINE=CONNECT TABLE_TYPE=JSON FILE_NAME='expense.js
o
n';
SELECT * FROM t3;
SELECT * FROM t3;
WHO WEEK WHAT AMOUNT
WHO WEEK WHAT AMOUNT
Joe 4 Beer 19.00
Joe 4 Beer 19.00
...
@@ -267,7 +287,7 @@ WHO CHAR(12),
...
@@ -267,7 +287,7 @@ WHO CHAR(12),
WEEK INT(2) FIELD_FORMAT='WEEK:[3]:NUMBER',
WEEK INT(2) FIELD_FORMAT='WEEK:[3]:NUMBER',
WHAT CHAR(32) FIELD_FORMAT='WEEK:[3]:EXPENSE:[X]:WHAT',
WHAT CHAR(32) FIELD_FORMAT='WEEK:[3]:EXPENSE:[X]:WHAT',
AMOUNT DOUBLE(8,2) FIELD_FORMAT='WEEK:[3]:EXPENSE:[X]:AMOUNT')
AMOUNT DOUBLE(8,2) FIELD_FORMAT='WEEK:[3]:EXPENSE:[X]:AMOUNT')
ENGINE=CONNECT TABLE_TYPE=JSON FILE_NAME='expense.jsn';
ENGINE=CONNECT TABLE_TYPE=JSON FILE_NAME='expense.js
o
n';
SELECT * FROM t4;
SELECT * FROM t4;
WHO WEEK WHAT AMOUNT
WHO WEEK WHAT AMOUNT
Joe 5 Beer 14.00
Joe 5 Beer 14.00
...
@@ -322,7 +342,7 @@ WHO CHAR(12),
...
@@ -322,7 +342,7 @@ WHO CHAR(12),
WEEK INT(2),
WEEK INT(2),
WHAT CHAR(32) FIELD_FORMAT='EXPENSE:[X]:WHAT',
WHAT CHAR(32) FIELD_FORMAT='EXPENSE:[X]:WHAT',
AMOUNT DOUBLE(8,2) FIELD_FORMAT='EXPENSE:[X]:AMOUNT')
AMOUNT DOUBLE(8,2) FIELD_FORMAT='EXPENSE:[X]:AMOUNT')
ENGINE=CONNECT TABLE_TYPE=JSON FILE_NAME='mulexp3.jsn';
ENGINE=CONNECT TABLE_TYPE=JSON FILE_NAME='mulexp3.js
o
n';
SELECT * FROM t2;
SELECT * FROM t2;
WHO WEEK WHAT AMOUNT
WHO WEEK WHAT AMOUNT
Joe 3 Beer 18.00
Joe 3 Beer 18.00
...
@@ -338,7 +358,7 @@ WHO CHAR(12),
...
@@ -338,7 +358,7 @@ WHO CHAR(12),
WEEK INT(2),
WEEK INT(2),
WHAT CHAR(32) FIELD_FORMAT='EXPENSE:[X]:WHAT',
WHAT CHAR(32) FIELD_FORMAT='EXPENSE:[X]:WHAT',
AMOUNT DOUBLE(8,2) FIELD_FORMAT='EXPENSE:[X]:AMOUNT')
AMOUNT DOUBLE(8,2) FIELD_FORMAT='EXPENSE:[X]:AMOUNT')
ENGINE=CONNECT TABLE_TYPE=JSON FILE_NAME='mulexp4.jsn';
ENGINE=CONNECT TABLE_TYPE=JSON FILE_NAME='mulexp4.js
o
n';
SELECT * FROM t3;
SELECT * FROM t3;
WHO WEEK WHAT AMOUNT
WHO WEEK WHAT AMOUNT
Joe 4 Beer 19.00
Joe 4 Beer 19.00
...
@@ -354,7 +374,7 @@ WHO CHAR(12),
...
@@ -354,7 +374,7 @@ WHO CHAR(12),
WEEK INT(2),
WEEK INT(2),
WHAT CHAR(32) FIELD_FORMAT='EXPENSE:[X]:WHAT',
WHAT CHAR(32) FIELD_FORMAT='EXPENSE:[X]:WHAT',
AMOUNT DOUBLE(8,2) FIELD_FORMAT='EXPENSE:[X]:AMOUNT')
AMOUNT DOUBLE(8,2) FIELD_FORMAT='EXPENSE:[X]:AMOUNT')
ENGINE=CONNECT TABLE_TYPE=JSON FILE_NAME='mulexp5.jsn';
ENGINE=CONNECT TABLE_TYPE=JSON FILE_NAME='mulexp5.js
o
n';
SELECT * FROM t4;
SELECT * FROM t4;
WHO WEEK WHAT AMOUNT
WHO WEEK WHAT AMOUNT
Joe 5 Beer 14.00
Joe 5 Beer 14.00
...
@@ -373,7 +393,7 @@ WHO CHAR(12),
...
@@ -373,7 +393,7 @@ WHO CHAR(12),
WEEK INT(2),
WEEK INT(2),
WHAT CHAR(32) FIELD_FORMAT='EXPENSE:[X]:WHAT',
WHAT CHAR(32) FIELD_FORMAT='EXPENSE:[X]:WHAT',
AMOUNT DOUBLE(8,2) FIELD_FORMAT='EXPENSE:[X]:AMOUNT')
AMOUNT DOUBLE(8,2) FIELD_FORMAT='EXPENSE:[X]:AMOUNT')
ENGINE=CONNECT TABLE_TYPE=JSON FILE_NAME='mulexp*.jsn' MULTIPLE=1;
ENGINE=CONNECT TABLE_TYPE=JSON FILE_NAME='mulexp*.js
o
n' MULTIPLE=1;
SELECT * FROM t1 ORDER BY WHO, WEEK, WHAT, AMOUNT;
SELECT * FROM t1 ORDER BY WHO, WEEK, WHAT, AMOUNT;
WHO WEEK WHAT AMOUNT
WHO WEEK WHAT AMOUNT
Beth 3 Beer 16.00
Beth 3 Beer 16.00
...
@@ -409,7 +429,7 @@ WHO CHAR(12),
...
@@ -409,7 +429,7 @@ WHO CHAR(12),
WEEK INT(2),
WEEK INT(2),
WHAT CHAR(32) FIELD_FORMAT='EXPENSE:[X]:WHAT',
WHAT CHAR(32) FIELD_FORMAT='EXPENSE:[X]:WHAT',
AMOUNT DOUBLE(8,2) FIELD_FORMAT='EXPENSE:[X]:AMOUNT')
AMOUNT DOUBLE(8,2) FIELD_FORMAT='EXPENSE:[X]:AMOUNT')
ENGINE=CONNECT TABLE_TYPE=JSON FILE_NAME='mulexp%s.jsn';
ENGINE=CONNECT TABLE_TYPE=JSON FILE_NAME='mulexp%s.js
o
n';
ALTER TABLE t1
ALTER TABLE t1
PARTITION BY LIST COLUMNS(WEEK) (
PARTITION BY LIST COLUMNS(WEEK) (
PARTITION `3` VALUES IN(3),
PARTITION `3` VALUES IN(3),
...
...
storage/connect/mysql-test/connect/r/json_udf.result
0 → 100644
View file @
e33b48ae
#
# Test UDF's with constant arguments
#
SELECT Json_Array();
Json_Array()
[]
SELECT Json_Object(56,3.1416,'foo',NULL);
Json_Object(56,3.1416,'foo',NULL)
{"56":56,"3.1416":3.141600,"foo":"foo","NULL":null}
SELECT Json_Object(56 qty,3.1416 price,'foo' truc, NULL garanty);
Json_Object(56 qty,3.1416 price,'foo' truc, NULL garanty)
{"qty":56,"price":3.141600,"truc":"foo","garanty":null}
SELECT Json_Array(56,3.1416,'My name is "Foo"',NULL);
Json_Array(56,3.1416,'My name is "Foo"',NULL)
[56,3.141600,"My name is \"Foo\"",null]
SELECT Json_Array_Add(Json_Array(56,3.1416,'foo',NULL)) Array;
ERROR HY000: Can't initialize function 'Json_Array_Add'; Json_Value_Add must have at least 2 arguments
SELECT Json_Array_Add(Json_Array(56,3.1416,'foo',NULL),'One more') Array;
Array
[56,3.141600,"foo",null,"One more"]
SELECT Json_Array_Add(Json_Value('one value'),'One more');
Json_Array_Add(Json_Value('one value'),'One more')
["one value","One more"]
SELECT Json_Array_Add('one value','One more');
ERROR HY000: Can't initialize function 'Json_Array_Add'; Json_Value_Add first argument must be a json item
SELECT Json_Array_Add('one value' json_,'One more');
Json_Array_Add('one value' json_,'One more')
[null,"One more"]
Warnings:
Warning 1105 Bad 'o' character near one value
SELECT Json_Value(56,3.1416,'foo',NULL);
ERROR HY000: Can't initialize function 'Json_Value'; Json_Value cannot accept more than 1 argument
SELECT Json_Value(3.1416);
Json_Value(3.1416)
3.141600
SELECT Json_Value('foo');
Json_Value('foo')
"foo"
SELECT Json_Value(NULL);
Json_Value(NULL)
null
SELECT Json_Value();
Json_Value()
null
SELECT Json_Object();
Json_Object()
{}
SELECT Json_Object(Json_Array(56,3.1416,'foo'),NULL);
Json_Object(Json_Array(56,3.1416,'foo'),NULL)
{"Array(56,3.1416,'foo')":[56,3.141600,"foo"],"NULL":null}
SELECT Json_Array(Json_Array(56,3.1416,'foo'),NULL);
Json_Array(Json_Array(56,3.1416,'foo'),NULL)
[[56,3.141600,"foo"],null]
SELECT Json_Array(Json_Object(56 "qty",3.1416 "price",'foo'),NULL);
Json_Array(Json_Object(56 "qty",3.1416 "price",'foo'),NULL)
[{"qty":56,"price":3.141600,"foo":"foo"},null]
#
# Test UDF's with column arguments
#
CREATE TABLE t1
(
ISBN CHAR(15),
LANG CHAR(2),
SUBJECT CHAR(32),
AUTHOR CHAR(64),
TITLE CHAR(32),
TRANSLATION CHAR(32),
TRANSLATOR CHAR(80),
PUBLISHER CHAR(32),
DATEPUB int(4)
) ENGINE=CONNECT TABLE_TYPE=JSON FILE_NAME='biblio.json';
SELECT Json_Array(AUTHOR, TITLE, DATEPUB) FROM t1;
Json_Array(AUTHOR, TITLE, DATEPUB)
["Jean-Christophe Bernadac","Construire une application XML",1999]
["William J. Pardi","XML en Action",1999]
SELECT Json_Object(AUTHOR, TITLE, DATEPUB) FROM t1;
Json_Object(AUTHOR, TITLE, DATEPUB)
{"AUTHOR":"Jean-Christophe Bernadac","TITLE":"Construire une application XML","DATEPUB":1999}
{"AUTHOR":"William J. Pardi","TITLE":"XML en Action","DATEPUB":1999}
SELECT Json_Array_Grp(TITLE, DATEPUB) FROM t1;
ERROR HY000: Can't initialize function 'Json_Array_Grp'; Json_Array_Grp can only accept 1 argument
SELECT Json_Array_Grp(TITLE) FROM t1;
Json_Array_Grp(TITLE)
["Construire une application XML","XML en Action"]
DROP TABLE t1;
CREATE TABLE t1 (
SERIALNO CHAR(5) NOT NULL,
NAME VARCHAR(12) NOT NULL FLAG=6,
SEX SMALLINT(1) NOT NULL,
TITLE VARCHAR(15) NOT NULL FLAG=20,
MANAGER CHAR(5) DEFAULT NULL,
DEPARTMENT CHAr(4) NOT NULL FLAG=41,
SECRETARY CHAR(5) DEFAULT NULL FLAG=46,
SALARY DOUBLE(8,2) NOT NULL FLAG=52
) ENGINE=CONNECT TABLE_TYPE=FIX BLOCK_SIZE=8 FILE_NAME='employee.dat' ENDING=1;
SELECT Json_Object(SERIALNO, NAME, TITLE, SALARY) FROM t1 WHERE NAME = 'MERCHANT';
Json_Object(SERIALNO, NAME, TITLE, SALARY)
{"SERIALNO":"78943","NAME":"MERCHANT","TITLE":"SALESMAN","SALARY":8700.000000}
SELECT DEPARTMENT, Json_Array_Grp(NAME) FROM t1 GROUP BY DEPARTMENT;
DEPARTMENT Json_Array_Grp(NAME)
0021 ["STRONG","SHORTSIGHT"]
0318 ["BANCROFT","PLUMHEAD","HONEY","TONGHO","WALTER","SHRINKY","WERTHER","MERCHANT","WHEELFOR"]
0319 ["BULLOZER","QUINN","BROWNY","KITTY","MONAPENNY","MARTIN","FUNNIGUY","BUGHAPPY","FODDERMAN","MESSIFUL"]
2452 ["BIGHEAD","ORELLY","BIGHORN","SMITH","CHERRY"]
Warnings:
Warning 1105 Result truncated to json_grp_size values
set connect_json_grp_size=30;
SELECT Json_Array(DEPARTMENT, Json_Array_Grp(NAME)) FROM t1 GROUP BY DEPARTMENT;
Json_Array(DEPARTMENT, Json_Array_Grp(NAME))
["0021",["STRONG","SHORTSIGHT"]]
["0318",["BANCROFT","PLUMHEAD","HONEY","TONGHO","WALTER","SHRINKY","WERTHER","MERCHANT","WHEELFOR"]]
["0319",["BULLOZER","QUINN","BROWNY","KITTY","MONAPENNY","MARTIN","FUNNIGUY","BUGHAPPY","FODDERMAN","MESSIFUL","GOOSEPEN"]]
["2452",["BIGHEAD","ORELLY","BIGHORN","SMITH","CHERRY"]]
SELECT Json_Object(DEPARTMENT, Json_Array_Grp(NAME) json_NAMES) FROM t1 GROUP BY DEPARTMENT;
Json_Object(DEPARTMENT, Json_Array_Grp(NAME) json_NAMES)
{"DEPARTMENT":"0021","NAMES":["STRONG","SHORTSIGHT"]}
{"DEPARTMENT":"0318","NAMES":["BANCROFT","PLUMHEAD","HONEY","TONGHO","WALTER","SHRINKY","WERTHER","MERCHANT","WHEELFOR"]}
{"DEPARTMENT":"0319","NAMES":["BULLOZER","QUINN","BROWNY","KITTY","MONAPENNY","MARTIN","FUNNIGUY","BUGHAPPY","FODDERMAN","MESSIFUL","GOOSEPEN"]}
{"DEPARTMENT":"2452","NAMES":["BIGHEAD","ORELLY","BIGHORN","SMITH","CHERRY"]}
SELECT Json_Object(DEPARTMENT, Json_Array_Grp(Json_Object(SERIALNO, NAME, TITLE, SALARY)) json_EMPLOYES) FROM t1 GROUP BY DEPARTMENT;
Json_Object(DEPARTMENT, Json_Array_Grp(Json_Object(SERIALNO, NAME, TITLE, SALARY)) json_EMPLOYES)
{"DEPARTMENT":"0021","EMPLOYES":[{"SERIALNO":"87777","NAME":"STRONG","TITLE":"DIRECTOR","SALARY":23000.000000},{"SERIALNO":"22222","NAME":"SHORTSIGHT","TITLE":"SECRETARY","SALARY":5500.000000}]}
{"DEPARTMENT":"0318","EMPLOYES":[{"SERIALNO":"74200","NAME":"BANCROFT","TITLE":"SALESMAN","SALARY":9600.000000},{"SERIALNO":"24888","NAME":"PLUMHEAD","TITLE":"TYPIST","SALARY":2800.000000},{"SERIALNO":"27845","NAME":"HONEY","TITLE":"SECRETARY","SALARY":4900.000000},{"SERIALNO":"73452","NAME":"TONGHO","TITLE":"ENGINEER","SALARY":6800.000000},{"SERIALNO":"74234","NAME":"WALTER","TITLE":"ENGINEER","SALARY":7400.000000},{"SERIALNO":"77777","NAME":"SHRINKY","TITLE":"ADMINISTRATOR","SALARY":7500.000000},{"SERIALNO":"70012","NAME":"WERTHER","TITLE":"DIRECTOR","SALARY":14500.000000},{"SERIALNO":"78943","NAME":"MERCHANT","TITLE":"SALESMAN","SALARY":8700.000000},{"SERIALNO":"73111","NAME":"WHEELFOR","TITLE":"SALESMAN","SALARY":10030.000000}]}
{"DEPARTMENT":"0319","EMPLOYES":[{"SERIALNO":"76543","NAME":"BULLOZER","TITLE":"SALESMAN","SALARY":14800.000000},{"SERIALNO":"40567","NAME":"QUINN","TITLE":"DIRECTOR","SALARY":14000.000000},{"SERIALNO":"00137","NAME":"BROWNY","TITLE":"ENGINEER","SALARY":10500.000000},{"SERIALNO":"12345","NAME":"KITTY","TITLE":"TYPIST","SALARY":3000.450000},{"SERIALNO":"33333","NAME":"MONAPENNY","TITLE":"SECRETARY","SALARY":3800.000000},{"SERIALNO":"00023","NAME":"MARTIN","TITLE":"ENGINEER","SALARY":10000.000000},{"SERIALNO":"07654","NAME":"FUNNIGUY","TITLE":"ADMINISTRATOR","SALARY":8500.000000},{"SERIALNO":"45678","NAME":"BUGHAPPY","TITLE":"PROGRAMMER","SALARY":8500.000000},{"SERIALNO":"56789","NAME":"FODDERMAN","TITLE":"SALESMAN","SALARY":7000.000000},{"SERIALNO":"55555","NAME":"MESSIFUL","TITLE":"SECRETARY","SALARY":5000.500000},{"SERIALNO":"98765","NAME":"GOOSEPEN","TITLE":"ADMINISTRATOR","SALARY":4700.000000}]}
{"DEPARTMENT":"2452","EMPLOYES":[{"SERIALNO":"34567","NAME":"BIGHEAD","TITLE":"SCIENTIST","SALARY":8000.000000},{"SERIALNO":"31416","NAME":"ORELLY","TITLE":"ENGINEER","SALARY":13400.000000},{"SERIALNO":"36666","NAME":"BIGHORN","TITLE":"SCIENTIST","SALARY":11000.000000},{"SERIALNO":"02345","NAME":"SMITH","TITLE":"ENGINEER","SALARY":9000.000000},{"SERIALNO":"11111","NAME":"CHERRY","TITLE":"SECRETARY","SALARY":4500.000000}]}
SELECT Json_Object(DEPARTMENT, TITLE, Json_Array_Grp(Json_Object(SERIALNO, NAME, SALARY)) json_EMPLOYES) FROM t1 GROUP BY DEPARTMENT, TITLE;
Json_Object(DEPARTMENT, TITLE, Json_Array_Grp(Json_Object(SERIALNO, NAME, SALARY)) json_EMPLOYES)
{"DEPARTMENT":"0021","TITLE":"DIRECTOR","EMPLOYES":[{"SERIALNO":"87777","NAME":"STRONG","SALARY":23000.000000}]}
{"DEPARTMENT":"0021","TITLE":"SECRETARY","EMPLOYES":[{"SERIALNO":"22222","NAME":"SHORTSIGHT","SALARY":5500.000000}]}
{"DEPARTMENT":"0318","TITLE":"ADMINISTRATOR","EMPLOYES":[{"SERIALNO":"77777","NAME":"SHRINKY","SALARY":7500.000000}]}
{"DEPARTMENT":"0318","TITLE":"DIRECTOR","EMPLOYES":[{"SERIALNO":"70012","NAME":"WERTHER","SALARY":14500.000000}]}
{"DEPARTMENT":"0318","TITLE":"ENGINEER","EMPLOYES":[{"SERIALNO":"73452","NAME":"TONGHO","SALARY":6800.000000},{"SERIALNO":"74234","NAME":"WALTER","SALARY":7400.000000}]}
{"DEPARTMENT":"0318","TITLE":"SALESMAN","EMPLOYES":[{"SERIALNO":"74200","NAME":"BANCROFT","SALARY":9600.000000},{"SERIALNO":"78943","NAME":"MERCHANT","SALARY":8700.000000},{"SERIALNO":"73111","NAME":"WHEELFOR","SALARY":10030.000000}]}
{"DEPARTMENT":"0318","TITLE":"SECRETARY","EMPLOYES":[{"SERIALNO":"27845","NAME":"HONEY","SALARY":4900.000000}]}
{"DEPARTMENT":"0318","TITLE":"TYPIST","EMPLOYES":[{"SERIALNO":"24888","NAME":"PLUMHEAD","SALARY":2800.000000}]}
{"DEPARTMENT":"0319","TITLE":"ADMINISTRATOR","EMPLOYES":[{"SERIALNO":"98765","NAME":"GOOSEPEN","SALARY":4700.000000},{"SERIALNO":"07654","NAME":"FUNNIGUY","SALARY":8500.000000}]}
{"DEPARTMENT":"0319","TITLE":"DIRECTOR","EMPLOYES":[{"SERIALNO":"40567","NAME":"QUINN","SALARY":14000.000000}]}
{"DEPARTMENT":"0319","TITLE":"ENGINEER","EMPLOYES":[{"SERIALNO":"00023","NAME":"MARTIN","SALARY":10000.000000},{"SERIALNO":"00137","NAME":"BROWNY","SALARY":10500.000000}]}
{"DEPARTMENT":"0319","TITLE":"PROGRAMMER","EMPLOYES":[{"SERIALNO":"45678","NAME":"BUGHAPPY","SALARY":8500.000000}]}
{"DEPARTMENT":"0319","TITLE":"SALESMAN","EMPLOYES":[{"SERIALNO":"76543","NAME":"BULLOZER","SALARY":14800.000000},{"SERIALNO":"56789","NAME":"FODDERMAN","SALARY":7000.000000}]}
{"DEPARTMENT":"0319","TITLE":"SECRETARY","EMPLOYES":[{"SERIALNO":"33333","NAME":"MONAPENNY","SALARY":3800.000000},{"SERIALNO":"55555","NAME":"MESSIFUL","SALARY":5000.500000}]}
{"DEPARTMENT":"0319","TITLE":"TYPIST","EMPLOYES":[{"SERIALNO":"12345","NAME":"KITTY","SALARY":3000.450000}]}
{"DEPARTMENT":"2452","TITLE":"ENGINEER","EMPLOYES":[{"SERIALNO":"31416","NAME":"ORELLY","SALARY":13400.000000},{"SERIALNO":"02345","NAME":"SMITH","SALARY":9000.000000}]}
{"DEPARTMENT":"2452","TITLE":"SCIENTIST","EMPLOYES":[{"SERIALNO":"34567","NAME":"BIGHEAD","SALARY":8000.000000},{"SERIALNO":"36666","NAME":"BIGHORN","SALARY":11000.000000}]}
{"DEPARTMENT":"2452","TITLE":"SECRETARY","EMPLOYES":[{"SERIALNO":"11111","NAME":"CHERRY","SALARY":4500.000000}]}
SELECT Json_Object_Grp(SALARY) FROM t1;
ERROR HY000: Can't initialize function 'Json_Object_Grp'; Json_Array_Grp can only accept 2 arguments
SELECT Json_Object_Grp(SALARY, NAME) FROM t1;
Json_Object_Grp(SALARY, NAME)
{"BANCROFT":9600.000000,"SMITH":9000.000000,"MERCHANT":8700.000000,"FUNNIGUY":8500.000000,"BUGHAPPY":8500.000000,"BIGHEAD":8000.000000,"SHRINKY":7500.000000,"WALTER":7400.000000,"FODDERMAN":7000.000000,"TONGHO":6800.000000,"SHORTSIGHT":5500.000000,"MESSIFUL":5000.500000,"HONEY":4900.000000,"GOOSEPEN":4700.000000,"CHERRY":4500.000000,"MONAPENNY":3800.000000,"KITTY":3000.450000,"PLUMHEAD":2800.000000,"STRONG":23000.000000,"BULLOZER":14800.000000,"WERTHER":14500.000000,"QUINN":14000.000000,"ORELLY":13400.000000,"BIGHORN":11000.000000,"BROWNY":10500.000000,"WHEELFOR":10030.000000,"MARTIN":10000.000000}
SELECT Json_Object(DEPARTMENT, Json_Object_Grp(SALARY, NAME) "Json_SALARIES") FROM t1 GROUP BY DEPARTMENT;
Json_Object(DEPARTMENT, Json_Object_Grp(SALARY, NAME) "Json_SALARIES")
{"DEPARTMENT":"0021","SALARIES":{"STRONG":23000.000000,"SHORTSIGHT":5500.000000}}
{"DEPARTMENT":"0318","SALARIES":{"BANCROFT":9600.000000,"PLUMHEAD":2800.000000,"HONEY":4900.000000,"TONGHO":6800.000000,"WALTER":7400.000000,"SHRINKY":7500.000000,"WERTHER":14500.000000,"MERCHANT":8700.000000,"WHEELFOR":10030.000000}}
{"DEPARTMENT":"0319","SALARIES":{"BULLOZER":14800.000000,"QUINN":14000.000000,"BROWNY":10500.000000,"KITTY":3000.450000,"MONAPENNY":3800.000000,"MARTIN":10000.000000,"FUNNIGUY":8500.000000,"BUGHAPPY":8500.000000,"FODDERMAN":7000.000000,"MESSIFUL":5000.500000,"GOOSEPEN":4700.000000}}
{"DEPARTMENT":"2452","SALARIES":{"BIGHEAD":8000.000000,"ORELLY":13400.000000,"BIGHORN":11000.000000,"SMITH":9000.000000,"CHERRY":4500.000000}}
SELECT Json_Array_Grp(NAME) from t1;
Json_Array_Grp(NAME)
["BANCROFT","SMITH","MERCHANT","FUNNIGUY","BUGHAPPY","BIGHEAD","SHRINKY","WALTER","FODDERMAN","TONGHO","SHORTSIGHT","MESSIFUL","HONEY","GOOSEPEN","CHERRY","MONAPENNY","KITTY","PLUMHEAD","STRONG","BULLOZER","WERTHER","QUINN","ORELLY","BIGHORN","BROWNY","WHEELFOR","MARTIN"]
DROP TABLE t1;
DROP FUNCTION Json_Array;
DROP FUNCTION Json_Array_Add;
DROP FUNCTION Json_Object;
DROP FUNCTION Json_Object_Nonull;
DROP FUNCTION Json_Value;
DROP FUNCTION Json_Array_Grp;
DROP FUNCTION Json_Object_Grp;
storage/connect/mysql-test/connect/r/odbc_oracle.result
View file @
e33b48ae
...
@@ -126,7 +126,7 @@ TABNAME='T1';
...
@@ -126,7 +126,7 @@ TABNAME='T1';
SHOW CREATE TABLE t1;
SHOW CREATE TABLE t1;
Table Create Table
Table Create Table
t1 CREATE TABLE `t1` (
t1 CREATE TABLE `t1` (
`A` decimal(
38
,0) DEFAULT NULL,
`A` decimal(
40
,0) DEFAULT NULL,
`B` double(40,0) DEFAULT NULL
`B` double(40,0) DEFAULT NULL
) ENGINE=CONNECT DEFAULT CHARSET=latin1 CONNECTION='DSN=ConnectEngineOracle;UID=mtr;PWD=mtr' `TABLE_TYPE`='ODBC' `TABNAME`='T1'
) ENGINE=CONNECT DEFAULT CHARSET=latin1 CONNECTION='DSN=ConnectEngineOracle;UID=mtr;PWD=mtr' `TABLE_TYPE`='ODBC' `TABNAME`='T1'
SELECT * FROM t1 ORDER BY A;
SELECT * FROM t1 ORDER BY A;
...
@@ -138,7 +138,7 @@ CREATE TABLE t2 AS SELECT * FROM t1;
...
@@ -138,7 +138,7 @@ CREATE TABLE t2 AS SELECT * FROM t1;
SHOW CREATE TABLE t2;
SHOW CREATE TABLE t2;
Table Create Table
Table Create Table
t2 CREATE TABLE `t2` (
t2 CREATE TABLE `t2` (
`A` decimal(
38
,0) DEFAULT NULL,
`A` decimal(
40
,0) DEFAULT NULL,
`B` double(40,0) DEFAULT NULL
`B` double(40,0) DEFAULT NULL
) ENGINE=MyISAM DEFAULT CHARSET=latin1
) ENGINE=MyISAM DEFAULT CHARSET=latin1
SELECT * FROM t2;
SELECT * FROM t2;
...
@@ -162,7 +162,7 @@ TABNAME='MTR.T1';
...
@@ -162,7 +162,7 @@ TABNAME='MTR.T1';
SHOW CREATE TABLE t1;
SHOW CREATE TABLE t1;
Table Create Table
Table Create Table
t1 CREATE TABLE `t1` (
t1 CREATE TABLE `t1` (
`A` decimal(
38
,0) DEFAULT NULL,
`A` decimal(
40
,0) DEFAULT NULL,
`B` double(40,0) DEFAULT NULL
`B` double(40,0) DEFAULT NULL
) ENGINE=CONNECT DEFAULT CHARSET=latin1 CONNECTION='DSN=ConnectEngineOracle;UID=mtr;PWD=mtr' `TABLE_TYPE`='ODBC' `TABNAME`='MTR.T1'
) ENGINE=CONNECT DEFAULT CHARSET=latin1 CONNECTION='DSN=ConnectEngineOracle;UID=mtr;PWD=mtr' `TABLE_TYPE`='ODBC' `TABNAME`='MTR.T1'
SELECT * FROM t1;
SELECT * FROM t1;
...
@@ -178,7 +178,7 @@ TABNAME='MTR.V1';
...
@@ -178,7 +178,7 @@ TABNAME='MTR.V1';
SHOW CREATE TABLE t1;
SHOW CREATE TABLE t1;
Table Create Table
Table Create Table
t1 CREATE TABLE `t1` (
t1 CREATE TABLE `t1` (
`A` decimal(
38
,0) DEFAULT NULL,
`A` decimal(
40
,0) DEFAULT NULL,
`B` double(40,0) DEFAULT NULL
`B` double(40,0) DEFAULT NULL
) ENGINE=CONNECT DEFAULT CHARSET=latin1 CONNECTION='DSN=ConnectEngineOracle;UID=mtr;PWD=mtr' `TABLE_TYPE`='ODBC' `TABNAME`='MTR.V1'
) ENGINE=CONNECT DEFAULT CHARSET=latin1 CONNECTION='DSN=ConnectEngineOracle;UID=mtr;PWD=mtr' `TABLE_TYPE`='ODBC' `TABNAME`='MTR.V1'
SELECT * FROM t1;
SELECT * FROM t1;
...
@@ -190,7 +190,7 @@ CREATE TABLE t2 AS SELECT * FROM t1;
...
@@ -190,7 +190,7 @@ CREATE TABLE t2 AS SELECT * FROM t1;
SHOW CREATE TABLE t2;
SHOW CREATE TABLE t2;
Table Create Table
Table Create Table
t2 CREATE TABLE `t2` (
t2 CREATE TABLE `t2` (
`A` decimal(
38
,0) DEFAULT NULL,
`A` decimal(
40
,0) DEFAULT NULL,
`B` double(40,0) DEFAULT NULL
`B` double(40,0) DEFAULT NULL
) ENGINE=MyISAM DEFAULT CHARSET=latin1
) ENGINE=MyISAM DEFAULT CHARSET=latin1
SELECT * FROM t2;
SELECT * FROM t2;
...
...
storage/connect/mysql-test/connect/std_data/biblio.jsn
→
storage/connect/mysql-test/connect/std_data/biblio.js
o
n
View file @
e33b48ae
File moved
storage/connect/mysql-test/connect/std_data/expense.jsn
→
storage/connect/mysql-test/connect/std_data/expense.js
o
n
View file @
e33b48ae
File moved
storage/connect/mysql-test/connect/std_data/mulexp3.jsn
→
storage/connect/mysql-test/connect/std_data/mulexp3.js
o
n
View file @
e33b48ae
File moved
storage/connect/mysql-test/connect/std_data/mulexp4.jsn
→
storage/connect/mysql-test/connect/std_data/mulexp4.js
o
n
View file @
e33b48ae
File moved
storage/connect/mysql-test/connect/std_data/mulexp5.jsn
→
storage/connect/mysql-test/connect/std_data/mulexp5.js
o
n
View file @
e33b48ae
File moved
storage/connect/mysql-test/connect/t/json.test
View file @
e33b48ae
...
@@ -3,11 +3,11 @@
...
@@ -3,11 +3,11 @@
let
$MYSQLD_DATADIR
=
`select @@datadir`
;
let
$MYSQLD_DATADIR
=
`select @@datadir`
;
--
copy_file
$MTR_SUITE_DIR
/
std_data
/
biblio
.
js
n
$MYSQLD_DATADIR
/
test
/
biblio
.
js
n
--
copy_file
$MTR_SUITE_DIR
/
std_data
/
biblio
.
js
on
$MYSQLD_DATADIR
/
test
/
biblio
.
jso
n
--
copy_file
$MTR_SUITE_DIR
/
std_data
/
expense
.
js
n
$MYSQLD_DATADIR
/
test
/
expense
.
js
n
--
copy_file
$MTR_SUITE_DIR
/
std_data
/
expense
.
js
on
$MYSQLD_DATADIR
/
test
/
expense
.
jso
n
--
copy_file
$MTR_SUITE_DIR
/
std_data
/
mulexp3
.
js
n
$MYSQLD_DATADIR
/
test
/
mulexp3
.
js
n
--
copy_file
$MTR_SUITE_DIR
/
std_data
/
mulexp3
.
js
on
$MYSQLD_DATADIR
/
test
/
mulexp3
.
jso
n
--
copy_file
$MTR_SUITE_DIR
/
std_data
/
mulexp4
.
js
n
$MYSQLD_DATADIR
/
test
/
mulexp4
.
js
n
--
copy_file
$MTR_SUITE_DIR
/
std_data
/
mulexp4
.
js
on
$MYSQLD_DATADIR
/
test
/
mulexp4
.
jso
n
--
copy_file
$MTR_SUITE_DIR
/
std_data
/
mulexp5
.
js
n
$MYSQLD_DATADIR
/
test
/
mulexp5
.
js
n
--
copy_file
$MTR_SUITE_DIR
/
std_data
/
mulexp5
.
js
on
$MYSQLD_DATADIR
/
test
/
mulexp5
.
jso
n
--
echo
#
--
echo
#
--
echo
# Testing doc samples
--
echo
# Testing doc samples
...
@@ -23,7 +23,7 @@ CREATE TABLE t1
...
@@ -23,7 +23,7 @@ CREATE TABLE t1
TRANSLATOR
CHAR
(
80
),
TRANSLATOR
CHAR
(
80
),
PUBLISHER
CHAR
(
32
),
PUBLISHER
CHAR
(
32
),
DATEPUB
int
(
4
)
DATEPUB
int
(
4
)
)
ENGINE
=
CONNECT
TABLE_TYPE
=
JSON
FILE_NAME
=
'biblio.jsn'
;
)
ENGINE
=
CONNECT
TABLE_TYPE
=
JSON
FILE_NAME
=
'biblio.js
o
n'
;
SELECT
*
FROM
t1
;
SELECT
*
FROM
t1
;
DROP
TABLE
t1
;
DROP
TABLE
t1
;
...
@@ -44,7 +44,7 @@ CREATE TABLE t1
...
@@ -44,7 +44,7 @@ CREATE TABLE t1
Location
CHAR
(
16
)
FIELD_FORMAT
=
'PUBLISHER:PLACE'
,
Location
CHAR
(
16
)
FIELD_FORMAT
=
'PUBLISHER:PLACE'
,
Year
int
(
4
)
FIELD_FORMAT
=
'DATEPUB'
Year
int
(
4
)
FIELD_FORMAT
=
'DATEPUB'
)
)
ENGINE
=
CONNECT
TABLE_TYPE
=
JSON
FILE_NAME
=
'biblio.jsn'
;
ENGINE
=
CONNECT
TABLE_TYPE
=
JSON
FILE_NAME
=
'biblio.js
o
n'
;
SELECT
*
FROM
t1
;
SELECT
*
FROM
t1
;
DROP
TABLE
t1
;
DROP
TABLE
t1
;
...
@@ -65,7 +65,7 @@ CREATE TABLE t1
...
@@ -65,7 +65,7 @@ CREATE TABLE t1
Location
CHAR
(
16
)
FIELD_FORMAT
=
'PUBLISHER:PLACE'
,
Location
CHAR
(
16
)
FIELD_FORMAT
=
'PUBLISHER:PLACE'
,
Year
int
(
4
)
FIELD_FORMAT
=
'DATEPUB'
Year
int
(
4
)
FIELD_FORMAT
=
'DATEPUB'
)
)
ENGINE
=
CONNECT
TABLE_TYPE
=
JSON
FILE_NAME
=
'biblio.jsn'
;
ENGINE
=
CONNECT
TABLE_TYPE
=
JSON
FILE_NAME
=
'biblio.js
o
n'
;
SELECT
*
FROM
t1
;
SELECT
*
FROM
t1
;
DROP
TABLE
t1
;
DROP
TABLE
t1
;
...
@@ -86,7 +86,7 @@ CREATE TABLE t1
...
@@ -86,7 +86,7 @@ CREATE TABLE t1
Location
CHAR
(
16
)
FIELD_FORMAT
=
'PUBLISHER:PLACE'
,
Location
CHAR
(
16
)
FIELD_FORMAT
=
'PUBLISHER:PLACE'
,
Year
int
(
4
)
FIELD_FORMAT
=
'DATEPUB'
Year
int
(
4
)
FIELD_FORMAT
=
'DATEPUB'
)
)
ENGINE
=
CONNECT
TABLE_TYPE
=
JSON
FILE_NAME
=
'biblio.jsn'
;
ENGINE
=
CONNECT
TABLE_TYPE
=
JSON
FILE_NAME
=
'biblio.js
o
n'
;
SELECT
*
FROM
t1
;
SELECT
*
FROM
t1
;
UPDATE
t1
SET
AuthorFN
=
'Philippe'
WHERE
AuthorLN
=
'Knab'
;
UPDATE
t1
SET
AuthorFN
=
'Philippe'
WHERE
AuthorLN
=
'Knab'
;
SELECT
*
FROM
t1
WHERE
ISBN
=
'9782212090819'
;
SELECT
*
FROM
t1
WHERE
ISBN
=
'9782212090819'
;
...
@@ -97,7 +97,7 @@ SELECT * FROM t1 WHERE ISBN = '9782212090819';
...
@@ -97,7 +97,7 @@ SELECT * FROM t1 WHERE ISBN = '9782212090819';
CREATE
TABLE
t2
(
CREATE
TABLE
t2
(
FIRSTNAME
CHAR
(
32
),
FIRSTNAME
CHAR
(
32
),
LASTNAME
CHAR
(
32
))
LASTNAME
CHAR
(
32
))
ENGINE
=
CONNECT
TABLE_TYPE
=
JSON
FILE_NAME
=
'biblio.jsn'
OPTION_LIST
=
'Object=[2]:AUTHOR'
;
ENGINE
=
CONNECT
TABLE_TYPE
=
JSON
FILE_NAME
=
'biblio.js
o
n'
OPTION_LIST
=
'Object=[2]:AUTHOR'
;
SELECT
*
FROM
t2
;
SELECT
*
FROM
t2
;
INSERT
INTO
t2
VALUES
(
'Charles'
,
'Dickens'
);
INSERT
INTO
t2
VALUES
(
'Charles'
,
'Dickens'
);
SELECT
*
FROM
t1
;
SELECT
*
FROM
t1
;
...
@@ -111,7 +111,7 @@ CREATE TABLE t1
...
@@ -111,7 +111,7 @@ CREATE TABLE t1
(
(
line
char
(
255
)
line
char
(
255
)
)
)
ENGINE
=
CONNECT
TABLE_TYPE
=
DOS
FILE_NAME
=
'biblio.jsn'
;
ENGINE
=
CONNECT
TABLE_TYPE
=
DOS
FILE_NAME
=
'biblio.js
o
n'
;
SELECT
*
FROM
t1
;
SELECT
*
FROM
t1
;
DROP
TABLE
t1
;
DROP
TABLE
t1
;
...
@@ -123,7 +123,7 @@ WHO CHAR(12),
...
@@ -123,7 +123,7 @@ WHO CHAR(12),
WEEK
INT
(
2
)
FIELD_FORMAT
=
'WEEK:[X]:NUMBER'
,
WEEK
INT
(
2
)
FIELD_FORMAT
=
'WEEK:[X]:NUMBER'
,
WHAT
CHAR
(
32
)
FIELD_FORMAT
=
'WEEK::EXPENSE:["+"]:WHAT'
,
WHAT
CHAR
(
32
)
FIELD_FORMAT
=
'WEEK::EXPENSE:["+"]:WHAT'
,
AMOUNT
DOUBLE
(
8
,
2
)
FIELD_FORMAT
=
'WEEK::EXPENSE:[+]:AMOUNT'
)
AMOUNT
DOUBLE
(
8
,
2
)
FIELD_FORMAT
=
'WEEK::EXPENSE:[+]:AMOUNT'
)
ENGINE
=
CONNECT
TABLE_TYPE
=
JSON
FILE_NAME
=
'expense.jsn'
;
ENGINE
=
CONNECT
TABLE_TYPE
=
JSON
FILE_NAME
=
'expense.js
o
n'
;
SELECT
*
FROM
t1
;
SELECT
*
FROM
t1
;
DROP
TABLE
t1
;
DROP
TABLE
t1
;
...
@@ -135,11 +135,28 @@ WHO CHAR(12),
...
@@ -135,11 +135,28 @@ WHO CHAR(12),
WEEK
INT
(
2
)
FIELD_FORMAT
=
'WEEK:[X]:NUMBER'
,
WEEK
INT
(
2
)
FIELD_FORMAT
=
'WEEK:[X]:NUMBER'
,
WHAT
CHAR
(
32
)
FIELD_FORMAT
=
'WEEK:[X]:EXPENSE:[X]:WHAT'
,
WHAT
CHAR
(
32
)
FIELD_FORMAT
=
'WEEK:[X]:EXPENSE:[X]:WHAT'
,
AMOUNT
DOUBLE
(
8
,
2
)
FIELD_FORMAT
=
'WEEK:[X]:EXPENSE:[X]:AMOUNT'
)
AMOUNT
DOUBLE
(
8
,
2
)
FIELD_FORMAT
=
'WEEK:[X]:EXPENSE:[X]:AMOUNT'
)
ENGINE
=
CONNECT
TABLE_TYPE
=
JSON
FILE_NAME
=
'expense.jsn'
;
ENGINE
=
CONNECT
TABLE_TYPE
=
JSON
FILE_NAME
=
'expense.js
o
n'
;
#--error ER_GET_ERRMSG
#--error ER_GET_ERRMSG
SELECT
*
FROM
t1
;
SELECT
*
FROM
t1
;
DROP
TABLE
t1
;
DROP
TABLE
t1
;
--
echo
#
--
echo
# A table showing many calculated results
--
echo
#
CREATE
TABLE
t1
(
WHO
CHAR
(
12
)
NOT
NULL
,
WEEKS
CHAR
(
12
)
NOT
NULL
FIELD_FORMAT
=
'WEEK:[", "]:NUMBER'
,
SUMS
CHAR
(
64
)
NOT
NULL
FIELD_FORMAT
=
'WEEK:["+"]:EXPENSE:[+]:AMOUNT'
,
SUM
DOUBLE
(
8
,
2
)
NOT
NULL
FIELD_FORMAT
=
'WEEK:[+]:EXPENSE:[+]:AMOUNT'
,
AVGS
CHAR
(
64
)
NOT
NULL
FIELD_FORMAT
=
'WEEK:["+"]:EXPENSE:[!]:AMOUNT'
,
SUMAVG
DOUBLE
(
8
,
2
)
NOT
NULL
FIELD_FORMAT
=
'WEEK:[+]:EXPENSE:[!]:AMOUNT'
,
AVGSUM
DOUBLE
(
8
,
2
)
NOT
NULL
FIELD_FORMAT
=
'WEEK:[!]:EXPENSE:[+]:AMOUNT'
,
AVGAVG
DOUBLE
(
8
,
2
)
NOT
NULL
FIELD_FORMAT
=
'WEEK:[!]:EXPENSE:[!]:AMOUNT'
,
AVERAGE
DOUBLE
(
8
,
2
)
NOT
NULL
FIELD_FORMAT
=
'WEEK:[!]:EXPENSE:[X]:AMOUNT'
)
ENGINE
=
CONNECT
TABLE_TYPE
=
JSON
FILE_NAME
=
'expense.json'
;
SELECT
*
FROM
t1
;
DROP
TABLE
t1
;
--
echo
#
--
echo
#
--
echo
# Expand expense in 3 one week tables
--
echo
# Expand expense in 3 one week tables
--
echo
#
--
echo
#
...
@@ -148,7 +165,7 @@ WHO CHAR(12),
...
@@ -148,7 +165,7 @@ WHO CHAR(12),
WEEK
INT
(
2
)
FIELD_FORMAT
=
'WEEK:[1]:NUMBER'
,
WEEK
INT
(
2
)
FIELD_FORMAT
=
'WEEK:[1]:NUMBER'
,
WHAT
CHAR
(
32
)
FIELD_FORMAT
=
'WEEK:[1]:EXPENSE:[X]:WHAT'
,
WHAT
CHAR
(
32
)
FIELD_FORMAT
=
'WEEK:[1]:EXPENSE:[X]:WHAT'
,
AMOUNT
DOUBLE
(
8
,
2
)
FIELD_FORMAT
=
'WEEK:[1]:EXPENSE:[X]:AMOUNT'
)
AMOUNT
DOUBLE
(
8
,
2
)
FIELD_FORMAT
=
'WEEK:[1]:EXPENSE:[X]:AMOUNT'
)
ENGINE
=
CONNECT
TABLE_TYPE
=
JSON
FILE_NAME
=
'expense.jsn'
;
ENGINE
=
CONNECT
TABLE_TYPE
=
JSON
FILE_NAME
=
'expense.js
o
n'
;
SELECT
*
FROM
t2
;
SELECT
*
FROM
t2
;
CREATE
TABLE
t3
(
CREATE
TABLE
t3
(
...
@@ -156,7 +173,7 @@ WHO CHAR(12),
...
@@ -156,7 +173,7 @@ WHO CHAR(12),
WEEK
INT
(
2
)
FIELD_FORMAT
=
'WEEK:[2]:NUMBER'
,
WEEK
INT
(
2
)
FIELD_FORMAT
=
'WEEK:[2]:NUMBER'
,
WHAT
CHAR
(
32
)
FIELD_FORMAT
=
'WEEK:[2]:EXPENSE:[X]:WHAT'
,
WHAT
CHAR
(
32
)
FIELD_FORMAT
=
'WEEK:[2]:EXPENSE:[X]:WHAT'
,
AMOUNT
DOUBLE
(
8
,
2
)
FIELD_FORMAT
=
'WEEK:[2]:EXPENSE:[X]:AMOUNT'
)
AMOUNT
DOUBLE
(
8
,
2
)
FIELD_FORMAT
=
'WEEK:[2]:EXPENSE:[X]:AMOUNT'
)
ENGINE
=
CONNECT
TABLE_TYPE
=
JSON
FILE_NAME
=
'expense.jsn'
;
ENGINE
=
CONNECT
TABLE_TYPE
=
JSON
FILE_NAME
=
'expense.js
o
n'
;
SELECT
*
FROM
t3
;
SELECT
*
FROM
t3
;
CREATE
TABLE
t4
(
CREATE
TABLE
t4
(
...
@@ -164,7 +181,7 @@ WHO CHAR(12),
...
@@ -164,7 +181,7 @@ WHO CHAR(12),
WEEK
INT
(
2
)
FIELD_FORMAT
=
'WEEK:[3]:NUMBER'
,
WEEK
INT
(
2
)
FIELD_FORMAT
=
'WEEK:[3]:NUMBER'
,
WHAT
CHAR
(
32
)
FIELD_FORMAT
=
'WEEK:[3]:EXPENSE:[X]:WHAT'
,
WHAT
CHAR
(
32
)
FIELD_FORMAT
=
'WEEK:[3]:EXPENSE:[X]:WHAT'
,
AMOUNT
DOUBLE
(
8
,
2
)
FIELD_FORMAT
=
'WEEK:[3]:EXPENSE:[X]:AMOUNT'
)
AMOUNT
DOUBLE
(
8
,
2
)
FIELD_FORMAT
=
'WEEK:[3]:EXPENSE:[X]:AMOUNT'
)
ENGINE
=
CONNECT
TABLE_TYPE
=
JSON
FILE_NAME
=
'expense.jsn'
;
ENGINE
=
CONNECT
TABLE_TYPE
=
JSON
FILE_NAME
=
'expense.js
o
n'
;
SELECT
*
FROM
t4
;
SELECT
*
FROM
t4
;
--
echo
#
--
echo
#
...
@@ -187,7 +204,7 @@ WHO CHAR(12),
...
@@ -187,7 +204,7 @@ WHO CHAR(12),
WEEK
INT
(
2
),
WEEK
INT
(
2
),
WHAT
CHAR
(
32
)
FIELD_FORMAT
=
'EXPENSE:[X]:WHAT'
,
WHAT
CHAR
(
32
)
FIELD_FORMAT
=
'EXPENSE:[X]:WHAT'
,
AMOUNT
DOUBLE
(
8
,
2
)
FIELD_FORMAT
=
'EXPENSE:[X]:AMOUNT'
)
AMOUNT
DOUBLE
(
8
,
2
)
FIELD_FORMAT
=
'EXPENSE:[X]:AMOUNT'
)
ENGINE
=
CONNECT
TABLE_TYPE
=
JSON
FILE_NAME
=
'mulexp3.jsn'
;
ENGINE
=
CONNECT
TABLE_TYPE
=
JSON
FILE_NAME
=
'mulexp3.js
o
n'
;
SELECT
*
FROM
t2
;
SELECT
*
FROM
t2
;
CREATE
TABLE
t3
(
CREATE
TABLE
t3
(
...
@@ -195,7 +212,7 @@ WHO CHAR(12),
...
@@ -195,7 +212,7 @@ WHO CHAR(12),
WEEK
INT
(
2
),
WEEK
INT
(
2
),
WHAT
CHAR
(
32
)
FIELD_FORMAT
=
'EXPENSE:[X]:WHAT'
,
WHAT
CHAR
(
32
)
FIELD_FORMAT
=
'EXPENSE:[X]:WHAT'
,
AMOUNT
DOUBLE
(
8
,
2
)
FIELD_FORMAT
=
'EXPENSE:[X]:AMOUNT'
)
AMOUNT
DOUBLE
(
8
,
2
)
FIELD_FORMAT
=
'EXPENSE:[X]:AMOUNT'
)
ENGINE
=
CONNECT
TABLE_TYPE
=
JSON
FILE_NAME
=
'mulexp4.jsn'
;
ENGINE
=
CONNECT
TABLE_TYPE
=
JSON
FILE_NAME
=
'mulexp4.js
o
n'
;
SELECT
*
FROM
t3
;
SELECT
*
FROM
t3
;
CREATE
TABLE
t4
(
CREATE
TABLE
t4
(
...
@@ -203,7 +220,7 @@ WHO CHAR(12),
...
@@ -203,7 +220,7 @@ WHO CHAR(12),
WEEK
INT
(
2
),
WEEK
INT
(
2
),
WHAT
CHAR
(
32
)
FIELD_FORMAT
=
'EXPENSE:[X]:WHAT'
,
WHAT
CHAR
(
32
)
FIELD_FORMAT
=
'EXPENSE:[X]:WHAT'
,
AMOUNT
DOUBLE
(
8
,
2
)
FIELD_FORMAT
=
'EXPENSE:[X]:AMOUNT'
)
AMOUNT
DOUBLE
(
8
,
2
)
FIELD_FORMAT
=
'EXPENSE:[X]:AMOUNT'
)
ENGINE
=
CONNECT
TABLE_TYPE
=
JSON
FILE_NAME
=
'mulexp5.jsn'
;
ENGINE
=
CONNECT
TABLE_TYPE
=
JSON
FILE_NAME
=
'mulexp5.js
o
n'
;
SELECT
*
FROM
t4
;
SELECT
*
FROM
t4
;
--
echo
#
--
echo
#
...
@@ -214,7 +231,7 @@ WHO CHAR(12),
...
@@ -214,7 +231,7 @@ WHO CHAR(12),
WEEK
INT
(
2
),
WEEK
INT
(
2
),
WHAT
CHAR
(
32
)
FIELD_FORMAT
=
'EXPENSE:[X]:WHAT'
,
WHAT
CHAR
(
32
)
FIELD_FORMAT
=
'EXPENSE:[X]:WHAT'
,
AMOUNT
DOUBLE
(
8
,
2
)
FIELD_FORMAT
=
'EXPENSE:[X]:AMOUNT'
)
AMOUNT
DOUBLE
(
8
,
2
)
FIELD_FORMAT
=
'EXPENSE:[X]:AMOUNT'
)
ENGINE
=
CONNECT
TABLE_TYPE
=
JSON
FILE_NAME
=
'mulexp*.jsn'
MULTIPLE
=
1
;
ENGINE
=
CONNECT
TABLE_TYPE
=
JSON
FILE_NAME
=
'mulexp*.js
o
n'
MULTIPLE
=
1
;
SELECT
*
FROM
t1
ORDER
BY
WHO
,
WEEK
,
WHAT
,
AMOUNT
;
SELECT
*
FROM
t1
ORDER
BY
WHO
,
WEEK
,
WHAT
,
AMOUNT
;
DROP
TABLE
t1
;
DROP
TABLE
t1
;
...
@@ -226,7 +243,7 @@ WHO CHAR(12),
...
@@ -226,7 +243,7 @@ WHO CHAR(12),
WEEK
INT
(
2
),
WEEK
INT
(
2
),
WHAT
CHAR
(
32
)
FIELD_FORMAT
=
'EXPENSE:[X]:WHAT'
,
WHAT
CHAR
(
32
)
FIELD_FORMAT
=
'EXPENSE:[X]:WHAT'
,
AMOUNT
DOUBLE
(
8
,
2
)
FIELD_FORMAT
=
'EXPENSE:[X]:AMOUNT'
)
AMOUNT
DOUBLE
(
8
,
2
)
FIELD_FORMAT
=
'EXPENSE:[X]:AMOUNT'
)
ENGINE
=
CONNECT
TABLE_TYPE
=
JSON
FILE_NAME
=
'mulexp%s.jsn'
;
ENGINE
=
CONNECT
TABLE_TYPE
=
JSON
FILE_NAME
=
'mulexp%s.js
o
n'
;
ALTER
TABLE
t1
ALTER
TABLE
t1
PARTITION
BY
LIST
COLUMNS
(
WEEK
)
(
PARTITION
BY
LIST
COLUMNS
(
WEEK
)
(
PARTITION
`3`
VALUES
IN
(
3
),
PARTITION
`3`
VALUES
IN
(
3
),
...
@@ -240,8 +257,8 @@ DROP TABLE t1, t2, t3, t4;
...
@@ -240,8 +257,8 @@ DROP TABLE t1, t2, t3, t4;
#
#
# Clean up
# Clean up
#
#
--
remove_file
$MYSQLD_DATADIR
/
test
/
biblio
.
jsn
--
remove_file
$MYSQLD_DATADIR
/
test
/
biblio
.
js
o
n
--
remove_file
$MYSQLD_DATADIR
/
test
/
expense
.
jsn
--
remove_file
$MYSQLD_DATADIR
/
test
/
expense
.
js
o
n
--
remove_file
$MYSQLD_DATADIR
/
test
/
mulexp3
.
jsn
--
remove_file
$MYSQLD_DATADIR
/
test
/
mulexp3
.
js
o
n
--
remove_file
$MYSQLD_DATADIR
/
test
/
mulexp4
.
jsn
--
remove_file
$MYSQLD_DATADIR
/
test
/
mulexp4
.
js
o
n
--
remove_file
$MYSQLD_DATADIR
/
test
/
mulexp5
.
jsn
--
remove_file
$MYSQLD_DATADIR
/
test
/
mulexp5
.
js
o
n
storage/connect/mysql-test/connect/t/json_udf.inc
0 → 100644
View file @
e33b48ae
--
disable_query_log
#
# Check if server has support for loading plugins
#
if
(
`SELECT @@have_dynamic_loading != 'YES'`
)
{
--
skip
UDF
requires
dynamic
loading
}
let
$is_win
=
`select convert(@@version_compile_os using latin1) IN ("Win32","Win64","Windows")`
;
if
(
$is_win
)
{
--
eval
CREATE
FUNCTION
Json_Array
RETURNS
STRING
SONAME
'ha_connect.dll'
;
--
eval
CREATE
FUNCTION
Json_Array_Add
RETURNS
STRING
SONAME
'ha_connect.dll'
;
--
eval
CREATE
FUNCTION
Json_Object
RETURNS
STRING
SONAME
'ha_connect.dll'
;
--
eval
CREATE
FUNCTION
Json_Object_Nonull
RETURNS
STRING
SONAME
'ha_connect.dll'
;
--
eval
CREATE
FUNCTION
Json_Value
returns
STRING
SONAME
'ha_connect.dll'
;
--
eval
CREATE
AGGREGATE
FUNCTION
Json_Array_Grp
RETURNS
STRING
SONAME
'ha_connect.dll'
;
--
eval
CREATE
AGGREGATE
FUNCTION
Json_Object_Grp
RETURNS
STRING
SONAME
'ha_connect.dll'
;
}
if
(
!
$is_win
)
{
--
eval
CREATE
FUNCTION
Json_Array
RETURNS
STRING
SONAME
'ha_connect.so'
;
--
eval
CREATE
FUNCTION
Json_Array_Add
RETURNS
STRING
SONAME
'ha_connect.so'
;
--
eval
CREATE
FUNCTION
Json_Object
RETURNS
STRING
SONAME
'ha_connect.so'
;
--
eval
CREATE
FUNCTION
Json_Object_Nonull
RETURNS
STRING
SONAME
'ha_connect.so'
;
--
eval
CREATE
FUNCTION
Json_Value
returns
STRING
SONAME
'ha_connect.so'
;
--
eval
CREATE
AGGREGATE
FUNCTION
Json_Array_Grp
RETURNS
STRING
SONAME
'ha_connect.so'
;
--
eval
CREATE
AGGREGATE
FUNCTION
Json_Object_Grp
RETURNS
STRING
SONAME
'ha_connect.so'
;
}
--
enable_query_log
storage/connect/mysql-test/connect/t/json_udf.test
0 → 100644
View file @
e33b48ae
--
source
json_udf
.
inc
let
$MYSQLD_DATADIR
=
`select @@datadir`
;
--
copy_file
$MTR_SUITE_DIR
/
std_data
/
biblio
.
json
$MYSQLD_DATADIR
/
test
/
biblio
.
json
--
copy_file
$MTR_SUITE_DIR
/
std_data
/
employee
.
dat
$MYSQLD_DATADIR
/
test
/
employee
.
dat
--
echo
#
--
echo
# Test UDF's with constant arguments
--
echo
#
SELECT
Json_Array
();
SELECT
Json_Object
(
56
,
3.1416
,
'foo'
,
NULL
);
SELECT
Json_Object
(
56
qty
,
3.1416
price
,
'foo'
truc
,
NULL
garanty
);
SELECT
Json_Array
(
56
,
3.1416
,
'My name is "Foo"'
,
NULL
);
--
error
ER_CANT_INITIALIZE_UDF
SELECT
Json_Array_Add
(
Json_Array
(
56
,
3.1416
,
'foo'
,
NULL
))
Array
;
SELECT
Json_Array_Add
(
Json_Array
(
56
,
3.1416
,
'foo'
,
NULL
),
'One more'
)
Array
;
SELECT
Json_Array_Add
(
Json_Value
(
'one value'
),
'One more'
);
--
error
ER_CANT_INITIALIZE_UDF
SELECT
Json_Array_Add
(
'one value'
,
'One more'
);
SELECT
Json_Array_Add
(
'one value'
json_
,
'One more'
);
--
error
ER_CANT_INITIALIZE_UDF
SELECT
Json_Value
(
56
,
3.1416
,
'foo'
,
NULL
);
SELECT
Json_Value
(
3.1416
);
SELECT
Json_Value
(
'foo'
);
SELECT
Json_Value
(
NULL
);
SELECT
Json_Value
();
SELECT
Json_Object
();
SELECT
Json_Object
(
Json_Array
(
56
,
3.1416
,
'foo'
),
NULL
);
SELECT
Json_Array
(
Json_Array
(
56
,
3.1416
,
'foo'
),
NULL
);
SELECT
Json_Array
(
Json_Object
(
56
"qty"
,
3.1416
"price"
,
'foo'
),
NULL
);
--
echo
#
--
echo
# Test UDF's with column arguments
--
echo
#
CREATE
TABLE
t1
(
ISBN
CHAR
(
15
),
LANG
CHAR
(
2
),
SUBJECT
CHAR
(
32
),
AUTHOR
CHAR
(
64
),
TITLE
CHAR
(
32
),
TRANSLATION
CHAR
(
32
),
TRANSLATOR
CHAR
(
80
),
PUBLISHER
CHAR
(
32
),
DATEPUB
int
(
4
)
)
ENGINE
=
CONNECT
TABLE_TYPE
=
JSON
FILE_NAME
=
'biblio.json'
;
SELECT
Json_Array
(
AUTHOR
,
TITLE
,
DATEPUB
)
FROM
t1
;
SELECT
Json_Object
(
AUTHOR
,
TITLE
,
DATEPUB
)
FROM
t1
;
--
error
ER_CANT_INITIALIZE_UDF
SELECT
Json_Array_Grp
(
TITLE
,
DATEPUB
)
FROM
t1
;
SELECT
Json_Array_Grp
(
TITLE
)
FROM
t1
;
DROP
TABLE
t1
;
CREATE
TABLE
t1
(
SERIALNO
CHAR
(
5
)
NOT
NULL
,
NAME
VARCHAR
(
12
)
NOT
NULL
FLAG
=
6
,
SEX
SMALLINT
(
1
)
NOT
NULL
,
TITLE
VARCHAR
(
15
)
NOT
NULL
FLAG
=
20
,
MANAGER
CHAR
(
5
)
DEFAULT
NULL
,
DEPARTMENT
CHAr
(
4
)
NOT
NULL
FLAG
=
41
,
SECRETARY
CHAR
(
5
)
DEFAULT
NULL
FLAG
=
46
,
SALARY
DOUBLE
(
8
,
2
)
NOT
NULL
FLAG
=
52
)
ENGINE
=
CONNECT
TABLE_TYPE
=
FIX
BLOCK_SIZE
=
8
FILE_NAME
=
'employee.dat'
ENDING
=
1
;
SELECT
Json_Object
(
SERIALNO
,
NAME
,
TITLE
,
SALARY
)
FROM
t1
WHERE
NAME
=
'MERCHANT'
;
SELECT
DEPARTMENT
,
Json_Array_Grp
(
NAME
)
FROM
t1
GROUP
BY
DEPARTMENT
;
set
connect_json_grp_size
=
30
;
SELECT
Json_Array
(
DEPARTMENT
,
Json_Array_Grp
(
NAME
))
FROM
t1
GROUP
BY
DEPARTMENT
;
SELECT
Json_Object
(
DEPARTMENT
,
Json_Array_Grp
(
NAME
)
json_NAMES
)
FROM
t1
GROUP
BY
DEPARTMENT
;
SELECT
Json_Object
(
DEPARTMENT
,
Json_Array_Grp
(
Json_Object
(
SERIALNO
,
NAME
,
TITLE
,
SALARY
))
json_EMPLOYES
)
FROM
t1
GROUP
BY
DEPARTMENT
;
SELECT
Json_Object
(
DEPARTMENT
,
TITLE
,
Json_Array_Grp
(
Json_Object
(
SERIALNO
,
NAME
,
SALARY
))
json_EMPLOYES
)
FROM
t1
GROUP
BY
DEPARTMENT
,
TITLE
;
--
error
ER_CANT_INITIALIZE_UDF
SELECT
Json_Object_Grp
(
SALARY
)
FROM
t1
;
SELECT
Json_Object_Grp
(
SALARY
,
NAME
)
FROM
t1
;
SELECT
Json_Object
(
DEPARTMENT
,
Json_Object_Grp
(
SALARY
,
NAME
)
"Json_SALARIES"
)
FROM
t1
GROUP
BY
DEPARTMENT
;
SELECT
Json_Array_Grp
(
NAME
)
from
t1
;
DROP
TABLE
t1
;
DROP
FUNCTION
Json_Array
;
DROP
FUNCTION
Json_Array_Add
;
DROP
FUNCTION
Json_Object
;
DROP
FUNCTION
Json_Object_Nonull
;
DROP
FUNCTION
Json_Value
;
DROP
FUNCTION
Json_Array_Grp
;
DROP
FUNCTION
Json_Object_Grp
;
#
# Clean up
#
--
remove_file
$MYSQLD_DATADIR
/
test
/
biblio
.
json
--
remove_file
$MYSQLD_DATADIR
/
test
/
employee
.
dat
storage/connect/odbconn.cpp
View file @
e33b48ae
...
@@ -102,7 +102,12 @@ static int GetSQLCType(int type)
...
@@ -102,7 +102,12 @@ static int GetSQLCType(int type)
case
TYPE_BIGINT
:
tp
=
SQL_C_SBIGINT
;
break
;
case
TYPE_BIGINT
:
tp
=
SQL_C_SBIGINT
;
break
;
case
TYPE_DOUBLE
:
tp
=
SQL_C_DOUBLE
;
break
;
case
TYPE_DOUBLE
:
tp
=
SQL_C_DOUBLE
;
break
;
case
TYPE_TINY
:
tp
=
SQL_C_TINYINT
;
break
;
case
TYPE_TINY
:
tp
=
SQL_C_TINYINT
;
break
;
//#if (ODBCVER >= 0x0300)
// case TYPE_DECIM: tp = SQL_C_NUMERIC; break; (CRASH!!!)
//#else
case
TYPE_DECIM
:
tp
=
SQL_C_CHAR
;
break
;
case
TYPE_DECIM
:
tp
=
SQL_C_CHAR
;
break
;
//#endif
}
// endswitch type
}
// endswitch type
return
tp
;
return
tp
;
...
@@ -923,13 +928,13 @@ ODBConn::ODBConn(PGLOBAL g, TDBODBC *tdbp)
...
@@ -923,13 +928,13 @@ ODBConn::ODBConn(PGLOBAL g, TDBODBC *tdbp)
m_RowsetSize
=
(
DWORD
)((
tdbp
)
?
tdbp
->
Rows
:
10
);
m_RowsetSize
=
(
DWORD
)((
tdbp
)
?
tdbp
->
Rows
:
10
);
m_Catver
=
(
tdbp
)
?
tdbp
->
Catver
:
0
;
m_Catver
=
(
tdbp
)
?
tdbp
->
Catver
:
0
;
m_Rows
=
0
;
m_Rows
=
0
;
m_Fetch
=
0
;
m_Connect
=
NULL
;
m_Connect
=
NULL
;
m_User
=
NULL
;
m_User
=
NULL
;
m_Pwd
=
NULL
;
m_Pwd
=
NULL
;
m_Updatable
=
true
;
m_Updatable
=
true
;
m_Transact
=
false
;
m_Transact
=
false
;
m_Scrollable
=
(
tdbp
)
?
tdbp
->
Scrollable
:
false
;
m_Scrollable
=
(
tdbp
)
?
tdbp
->
Scrollable
:
false
;
m_First
=
true
;
m_Full
=
false
;
m_Full
=
false
;
m_UseCnc
=
false
;
m_UseCnc
=
false
;
m_IDQuoteChar
[
0
]
=
'"'
;
m_IDQuoteChar
[
0
]
=
'"'
;
...
@@ -984,7 +989,7 @@ void ODBConn::ThrowDBX(RETCODE rc, PSZ msg, HSTMT hstmt)
...
@@ -984,7 +989,7 @@ void ODBConn::ThrowDBX(RETCODE rc, PSZ msg, HSTMT hstmt)
void
ODBConn
::
ThrowDBX
(
PSZ
msg
)
void
ODBConn
::
ThrowDBX
(
PSZ
msg
)
{
{
DBX
*
xp
=
new
(
m_G
)
DBX
(
0
,
msg
);
DBX
*
xp
=
new
(
m_G
)
DBX
(
0
,
"Error"
);
xp
->
m_ErrMsg
[
0
]
=
msg
;
xp
->
m_ErrMsg
[
0
]
=
msg
;
throw
xp
;
throw
xp
;
...
@@ -1099,8 +1104,7 @@ int ODBConn::Open(PSZ ConnectString, POPARM sop, DWORD options)
...
@@ -1099,8 +1104,7 @@ int ODBConn::Open(PSZ ConnectString, POPARM sop, DWORD options)
// VerifyConnect(); Deprecated
// VerifyConnect(); Deprecated
GetConnectInfo
();
GetConnectInfo
();
}
catch
(
DBX
*
xp
)
{
}
catch
(
DBX
*
xp
)
{
// strcpy(g->Message, xp->m_ErrMsg[0]);
sprintf
(
g
->
Message
,
"%s: %s"
,
xp
->
m_Msg
,
xp
->
GetErrorMessage
(
0
));
strcpy
(
g
->
Message
,
xp
->
GetErrorMessage
(
0
));
Close
();
Close
();
// Free();
// Free();
return
-
1
;
return
-
1
;
...
@@ -1356,7 +1360,7 @@ int ODBConn::ExecDirectSQL(char *sql, ODBCCOL *tocols)
...
@@ -1356,7 +1360,7 @@ int ODBConn::ExecDirectSQL(char *sql, ODBCCOL *tocols)
rc
=
SQLFreeStmt
(
m_hstmt
,
SQL_CLOSE
);
rc
=
SQLFreeStmt
(
m_hstmt
,
SQL_CLOSE
);
if
(
!
Check
(
rc
))
if
(
!
Check
(
rc
))
ThrowDBX
(
rc
,
"SQLFreeStmt"
);
ThrowDBX
(
rc
,
"SQLFreeStmt"
,
m_hstmt
);
m_hstmt
=
NULL
;
m_hstmt
=
NULL
;
}
// endif m_hstmt
}
// endif m_hstmt
...
@@ -1371,7 +1375,7 @@ int ODBConn::ExecDirectSQL(char *sql, ODBCCOL *tocols)
...
@@ -1371,7 +1375,7 @@ int ODBConn::ExecDirectSQL(char *sql, ODBCCOL *tocols)
(
void
*
)
SQL_SCROLLABLE
,
0
);
(
void
*
)
SQL_SCROLLABLE
,
0
);
if
(
!
Check
(
rc
))
if
(
!
Check
(
rc
))
ThrowDBX
(
rc
,
"S
QLSetStmtAttr"
);
ThrowDBX
(
rc
,
"S
crollable"
,
hstmt
);
}
// endif m_Scrollable
}
// endif m_Scrollable
...
@@ -1422,7 +1426,7 @@ int ODBConn::ExecDirectSQL(char *sql, ODBCCOL *tocols)
...
@@ -1422,7 +1426,7 @@ int ODBConn::ExecDirectSQL(char *sql, ODBCCOL *tocols)
for
(
n
=
0
,
colp
=
tocols
;
colp
;
colp
=
(
PODBCCOL
)
colp
->
GetNext
())
for
(
n
=
0
,
colp
=
tocols
;
colp
;
colp
=
(
PODBCCOL
)
colp
->
GetNext
())
if
(
!
colp
->
IsSpecial
())
if
(
!
colp
->
IsSpecial
())
n
++
;
n
++
;
// n can be 0 for query such as Select count(*) from table
// n can be 0 for query such as Select count(*) from table
if
(
n
&&
n
!=
(
UWORD
)
ncol
)
if
(
n
&&
n
!=
(
UWORD
)
ncol
)
...
@@ -1458,7 +1462,7 @@ int ODBConn::ExecDirectSQL(char *sql, ODBCCOL *tocols)
...
@@ -1458,7 +1462,7 @@ int ODBConn::ExecDirectSQL(char *sql, ODBCCOL *tocols)
for
(
int
i
=
0
;
i
<
MAX_NUM_OF_MSG
&&
x
->
m_ErrMsg
[
i
];
i
++
)
for
(
int
i
=
0
;
i
<
MAX_NUM_OF_MSG
&&
x
->
m_ErrMsg
[
i
];
i
++
)
htrc
(
x
->
m_ErrMsg
[
i
]);
htrc
(
x
->
m_ErrMsg
[
i
]);
s
trcpy
(
m_G
->
Message
,
x
->
GetErrorMessage
(
0
));
s
printf
(
m_G
->
Message
,
"%s: %s"
,
x
->
m_Msg
,
x
->
GetErrorMessage
(
0
));
if
(
b
)
if
(
b
)
SQLCancel
(
hstmt
);
SQLCancel
(
hstmt
);
...
@@ -1521,7 +1525,7 @@ int ODBConn::GetResultSize(char *sql, ODBCCOL *colp)
...
@@ -1521,7 +1525,7 @@ int ODBConn::GetResultSize(char *sql, ODBCCOL *colp)
/***********************************************************************/
/***********************************************************************/
/* Fetch next row. */
/* Fetch next row. */
/***********************************************************************/
/***********************************************************************/
int
ODBConn
::
Fetch
()
int
ODBConn
::
Fetch
(
int
pos
)
{
{
ASSERT
(
m_hstmt
);
ASSERT
(
m_hstmt
);
int
irc
;
int
irc
;
...
@@ -1531,7 +1535,9 @@ int ODBConn::Fetch()
...
@@ -1531,7 +1535,9 @@ int ODBConn::Fetch()
try
{
try
{
// do {
// do {
if
(
m_RowsetSize
)
{
if
(
pos
)
{
rc
=
SQLExtendedFetch
(
m_hstmt
,
SQL_FETCH_ABSOLUTE
,
pos
,
&
crow
,
NULL
);
}
else
if
(
m_RowsetSize
)
{
rc
=
SQLExtendedFetch
(
m_hstmt
,
SQL_FETCH_NEXT
,
1
,
&
crow
,
NULL
);
rc
=
SQLExtendedFetch
(
m_hstmt
,
SQL_FETCH_NEXT
,
1
,
&
crow
,
NULL
);
}
else
{
}
else
{
rc
=
SQLFetch
(
m_hstmt
);
rc
=
SQLFetch
(
m_hstmt
);
...
@@ -1544,29 +1550,22 @@ int ODBConn::Fetch()
...
@@ -1544,29 +1550,22 @@ int ODBConn::Fetch()
m_hstmt
,
m_RowsetSize
,
rc
);
m_hstmt
,
m_RowsetSize
,
rc
);
if
(
!
Check
(
rc
))
if
(
!
Check
(
rc
))
ThrowDBX
(
rc
,
"Fetch"
,
m_hstmt
);
ThrowDBX
(
rc
,
"Fetching"
,
m_hstmt
);
irc
=
(
rc
==
SQL_NO_DATA_FOUND
)
?
0
:
(
int
)
crow
;
if
(
m_First
)
{
// First fetch. Check whether the full table was read
if
((
m_Full
=
irc
<
(
signed
)
m_RowsetSize
))
{
m_Tdb
->
Memory
=
0
;
// Not needed anymore
m_Rows
=
irc
;
// Table size
}
// endif m_Full
m_First
=
false
;
}
// endif m_First
if
(
m_Tdb
->
Memory
==
1
)
if
(
rc
==
SQL_NO_DATA_FOUND
)
{
m_Rows
+=
irc
;
m_Full
=
(
m_Fetch
==
1
);
irc
=
0
;
}
else
irc
=
(
int
)
crow
;
m_Fetch
++
;
m_Rows
+=
irc
;
}
catch
(
DBX
*
x
)
{
}
catch
(
DBX
*
x
)
{
if
(
trace
)
if
(
trace
)
for
(
int
i
=
0
;
i
<
MAX_NUM_OF_MSG
&&
x
->
m_ErrMsg
[
i
];
i
++
)
for
(
int
i
=
0
;
i
<
MAX_NUM_OF_MSG
&&
x
->
m_ErrMsg
[
i
];
i
++
)
htrc
(
x
->
m_ErrMsg
[
i
]);
htrc
(
x
->
m_ErrMsg
[
i
]);
s
trcpy
(
g
->
Message
,
x
->
GetErrorMessage
(
0
));
s
printf
(
g
->
Message
,
"%s: %s"
,
x
->
m_Msg
,
x
->
GetErrorMessage
(
0
));
irc
=
-
1
;
irc
=
-
1
;
}
// end try/catch
}
// end try/catch
...
@@ -1602,7 +1601,7 @@ int ODBConn::PrepareSQL(char *sql)
...
@@ -1602,7 +1601,7 @@ int ODBConn::PrepareSQL(char *sql)
for
(
int
i
=
0
;
i
<
MAX_NUM_OF_MSG
&&
x
->
m_ErrMsg
[
i
];
i
++
)
for
(
int
i
=
0
;
i
<
MAX_NUM_OF_MSG
&&
x
->
m_ErrMsg
[
i
];
i
++
)
htrc
(
x
->
m_ErrMsg
[
i
]);
htrc
(
x
->
m_ErrMsg
[
i
]);
strcpy
(
g
->
Message
,
x
->
GetErrorMessage
(
0
));
sprintf
(
g
->
Message
,
"%s: %s"
,
x
->
m_Msg
,
x
->
GetErrorMessage
(
0
));
}
// end try/catch
}
// end try/catch
}
// endif Mode
}
// endif Mode
...
@@ -1648,7 +1647,7 @@ int ODBConn::PrepareSQL(char *sql)
...
@@ -1648,7 +1647,7 @@ int ODBConn::PrepareSQL(char *sql)
for
(
int
i
=
0
;
i
<
MAX_NUM_OF_MSG
&&
x
->
m_ErrMsg
[
i
];
i
++
)
for
(
int
i
=
0
;
i
<
MAX_NUM_OF_MSG
&&
x
->
m_ErrMsg
[
i
];
i
++
)
htrc
(
x
->
m_ErrMsg
[
i
]);
htrc
(
x
->
m_ErrMsg
[
i
]);
s
trcpy
(
g
->
Message
,
x
->
GetErrorMessage
(
0
));
s
printf
(
g
->
Message
,
"%s: %s"
,
x
->
m_Msg
,
x
->
GetErrorMessage
(
0
));
if
(
b
)
if
(
b
)
SQLCancel
(
hstmt
);
SQLCancel
(
hstmt
);
...
@@ -1700,7 +1699,7 @@ int ODBConn::ExecuteSQL(void)
...
@@ -1700,7 +1699,7 @@ int ODBConn::ExecuteSQL(void)
}
// endif ncol
}
// endif ncol
}
catch
(
DBX
*
x
)
{
}
catch
(
DBX
*
x
)
{
s
trcpy
(
m_G
->
Message
,
x
->
GetErrorMessage
(
0
));
s
printf
(
m_G
->
Message
,
"%s: %s"
,
x
->
m_Msg
,
x
->
GetErrorMessage
(
0
));
SQLCancel
(
m_hstmt
);
SQLCancel
(
m_hstmt
);
rc
=
SQLFreeStmt
(
m_hstmt
,
SQL_DROP
);
rc
=
SQLFreeStmt
(
m_hstmt
,
SQL_DROP
);
m_hstmt
=
NULL
;
m_hstmt
=
NULL
;
...
@@ -1737,7 +1736,7 @@ bool ODBConn::BindParam(ODBCCOL *colp)
...
@@ -1737,7 +1736,7 @@ bool ODBConn::BindParam(ODBCCOL *colp)
ThrowDBX
(
rc
,
"SQLDescribeParam"
,
m_hstmt
);
ThrowDBX
(
rc
,
"SQLDescribeParam"
,
m_hstmt
);
}
catch
(
DBX
*
x
)
{
}
catch
(
DBX
*
x
)
{
s
trcpy
(
m_G
->
Message
,
x
->
GetErrorMessage
(
0
));
s
printf
(
m_G
->
Message
,
"%s: %s"
,
x
->
m_Msg
,
x
->
GetErrorMessage
(
0
));
colsize
=
colp
->
GetPrecision
();
colsize
=
colp
->
GetPrecision
();
sqlt
=
GetSQLType
(
buftype
);
sqlt
=
GetSQLType
(
buftype
);
dec
=
IsTypeChar
(
buftype
)
?
0
:
colp
->
GetScale
();
dec
=
IsTypeChar
(
buftype
)
?
0
:
colp
->
GetScale
();
...
@@ -1845,7 +1844,7 @@ bool ODBConn::ExecSQLcommand(char *sql)
...
@@ -1845,7 +1844,7 @@ bool ODBConn::ExecSQLcommand(char *sql)
for
(
int
i
=
0
;
i
<
MAX_NUM_OF_MSG
&&
x
->
m_ErrMsg
[
i
];
i
++
)
for
(
int
i
=
0
;
i
<
MAX_NUM_OF_MSG
&&
x
->
m_ErrMsg
[
i
];
i
++
)
htrc
(
x
->
m_ErrMsg
[
i
]);
htrc
(
x
->
m_ErrMsg
[
i
]);
sprintf
(
g
->
Message
,
"Remote
: %s"
,
x
->
GetErrorMessage
(
0
));
sprintf
(
g
->
Message
,
"Remote
%s: %s"
,
x
->
m_Msg
,
x
->
GetErrorMessage
(
0
));
if
(
b
)
if
(
b
)
SQLCancel
(
hstmt
);
SQLCancel
(
hstmt
);
...
@@ -1930,7 +1929,7 @@ PQRYRES ODBConn::GetMetaData(PGLOBAL g, char *dsn, char *src)
...
@@ -1930,7 +1929,7 @@ PQRYRES ODBConn::GetMetaData(PGLOBAL g, char *dsn, char *src)
}
// endfor i
}
// endfor i
}
catch
(
DBX
*
x
)
{
}
catch
(
DBX
*
x
)
{
s
trcpy
(
g
->
Message
,
x
->
GetErrorMessage
(
0
));
s
printf
(
g
->
Message
,
"%s: %s"
,
x
->
m_Msg
,
x
->
GetErrorMessage
(
0
));
goto
err
;
goto
err
;
}
// end try/catch
}
// end try/catch
...
@@ -1981,7 +1980,7 @@ PQRYRES ODBConn::GetMetaData(PGLOBAL g, char *dsn, char *src)
...
@@ -1981,7 +1980,7 @@ PQRYRES ODBConn::GetMetaData(PGLOBAL g, char *dsn, char *src)
}
// endfor i
}
// endfor i
}
catch
(
DBX
*
x
)
{
}
catch
(
DBX
*
x
)
{
s
trcpy
(
g
->
Message
,
x
->
GetErrorMessage
(
0
));
s
printf
(
g
->
Message
,
"%s: %s"
,
x
->
m_Msg
,
x
->
GetErrorMessage
(
0
));
qrp
=
NULL
;
qrp
=
NULL
;
}
// end try/catch
}
// end try/catch
...
@@ -2033,7 +2032,7 @@ bool ODBConn::GetDataSources(PQRYRES qrp)
...
@@ -2033,7 +2032,7 @@ bool ODBConn::GetDataSources(PQRYRES qrp)
}
// endfor i
}
// endfor i
}
catch
(
DBX
*
x
)
{
}
catch
(
DBX
*
x
)
{
s
trcpy
(
m_G
->
Message
,
x
->
GetErrorMessage
(
0
));
s
printf
(
m_G
->
Message
,
"%s: %s"
,
x
->
m_Msg
,
x
->
GetErrorMessage
(
0
));
rv
=
true
;
rv
=
true
;
}
// end try/catch
}
// end try/catch
...
@@ -2084,7 +2083,7 @@ bool ODBConn::GetDrivers(PQRYRES qrp)
...
@@ -2084,7 +2083,7 @@ bool ODBConn::GetDrivers(PQRYRES qrp)
}
// endfor n
}
// endfor n
}
catch
(
DBX
*
x
)
{
}
catch
(
DBX
*
x
)
{
s
trcpy
(
m_G
->
Message
,
x
->
GetErrorMessage
(
0
));
s
printf
(
m_G
->
Message
,
"%s: %s"
,
x
->
m_Msg
,
x
->
GetErrorMessage
(
0
));
rv
=
true
;
rv
=
true
;
}
// end try/catch
}
// end try/catch
...
@@ -2402,7 +2401,7 @@ int ODBConn::GetCatInfo(CATPARM *cap)
...
@@ -2402,7 +2401,7 @@ int ODBConn::GetCatInfo(CATPARM *cap)
for
(
int
i
=
0
;
i
<
MAX_NUM_OF_MSG
&&
x
->
m_ErrMsg
[
i
];
i
++
)
for
(
int
i
=
0
;
i
<
MAX_NUM_OF_MSG
&&
x
->
m_ErrMsg
[
i
];
i
++
)
htrc
(
x
->
m_ErrMsg
[
i
]);
htrc
(
x
->
m_ErrMsg
[
i
]);
s
trcpy
(
g
->
Message
,
x
->
GetErrorMessage
(
0
));
s
printf
(
g
->
Message
,
"%s: %s"
,
x
->
m_Msg
,
x
->
GetErrorMessage
(
0
));
irc
=
-
1
;
irc
=
-
1
;
}
// end try/catch
}
// end try/catch
...
@@ -2506,7 +2505,7 @@ int ODBConn::Rewind(char *sql, ODBCCOL *tocols)
...
@@ -2506,7 +2505,7 @@ int ODBConn::Rewind(char *sql, ODBCCOL *tocols)
rbuf
=
(
int
)
crow
;
rbuf
=
(
int
)
crow
;
}
catch
(
DBX
*
x
)
{
}
catch
(
DBX
*
x
)
{
s
trcpy
(
m_G
->
Message
,
x
->
GetErrorMessage
(
0
));
s
printf
(
m_G
->
Message
,
"%s: %s"
,
x
->
m_Msg
,
x
->
GetErrorMessage
(
0
));
rbuf
=
-
1
;
rbuf
=
-
1
;
}
// end try/catch
}
// end try/catch
...
...
storage/connect/odbconn.h
View file @
e33b48ae
...
@@ -141,7 +141,7 @@ class ODBConn : public BLOCK {
...
@@ -141,7 +141,7 @@ class ODBConn : public BLOCK {
//void SetUserPwd(PSZ pwd) {m_Pwd = pwd;}
//void SetUserPwd(PSZ pwd) {m_Pwd = pwd;}
int
GetResultSize
(
char
*
sql
,
ODBCCOL
*
colp
);
int
GetResultSize
(
char
*
sql
,
ODBCCOL
*
colp
);
int
ExecDirectSQL
(
char
*
sql
,
ODBCCOL
*
tocols
);
int
ExecDirectSQL
(
char
*
sql
,
ODBCCOL
*
tocols
);
int
Fetch
(
void
);
int
Fetch
(
int
pos
=
0
);
int
PrepareSQL
(
char
*
sql
);
int
PrepareSQL
(
char
*
sql
);
int
ExecuteSQL
(
void
);
int
ExecuteSQL
(
void
);
bool
BindParam
(
ODBCCOL
*
colp
);
bool
BindParam
(
ODBCCOL
*
colp
);
...
@@ -192,10 +192,10 @@ class ODBConn : public BLOCK {
...
@@ -192,10 +192,10 @@ class ODBConn : public BLOCK {
PSZ
m_Pwd
;
PSZ
m_Pwd
;
int
m_Catver
;
int
m_Catver
;
int
m_Rows
;
int
m_Rows
;
int
m_Fetch
;
bool
m_Updatable
;
bool
m_Updatable
;
bool
m_Transact
;
bool
m_Transact
;
bool
m_Scrollable
;
bool
m_Scrollable
;
bool
m_UseCnc
;
bool
m_UseCnc
;
bool
m_First
;
bool
m_Full
;
bool
m_Full
;
};
// end of ODBConn class definition
};
// end of ODBConn class definition
storage/connect/tabjson.cpp
View file @
e33b48ae
...
@@ -117,7 +117,8 @@ TDBJSN::TDBJSN(PJDEF tdp, PTXF txfp) : TDBDOS(tdp, txfp)
...
@@ -117,7 +117,8 @@ TDBJSN::TDBJSN(PJDEF tdp, PTXF txfp) : TDBDOS(tdp, txfp)
Jmode
=
tdp
->
Jmode
;
Jmode
=
tdp
->
Jmode
;
Xcol
=
tdp
->
Xcol
;
Xcol
=
tdp
->
Xcol
;
Fpos
=
-
1
;
Fpos
=
-
1
;
Spos
=
N
=
0
;
//Spos = 0;
N
=
0
;
Limit
=
tdp
->
Limit
;
Limit
=
tdp
->
Limit
;
NextSame
=
0
;
NextSame
=
0
;
SameRow
=
0
;
SameRow
=
0
;
...
@@ -134,7 +135,7 @@ TDBJSN::TDBJSN(TDBJSN *tdbp) : TDBDOS(NULL, tdbp)
...
@@ -134,7 +135,7 @@ TDBJSN::TDBJSN(TDBJSN *tdbp) : TDBDOS(NULL, tdbp)
Jmode
=
tdbp
->
Jmode
;
Jmode
=
tdbp
->
Jmode
;
Xcol
=
tdbp
->
Xcol
;
Xcol
=
tdbp
->
Xcol
;
Fpos
=
tdbp
->
Fpos
;
Fpos
=
tdbp
->
Fpos
;
Spos
=
tdbp
->
Spos
;
//
Spos = tdbp->Spos;
N
=
tdbp
->
N
;
N
=
tdbp
->
N
;
Limit
=
tdbp
->
Limit
;
Limit
=
tdbp
->
Limit
;
NextSame
=
tdbp
->
NextSame
;
NextSame
=
tdbp
->
NextSame
;
...
@@ -222,7 +223,7 @@ bool TDBJSN::OpenDB(PGLOBAL g)
...
@@ -222,7 +223,7 @@ bool TDBJSN::OpenDB(PGLOBAL g)
/* Table already open replace it at its beginning. */
/* Table already open replace it at its beginning. */
/*******************************************************************/
/*******************************************************************/
Fpos
=
-
1
;
Fpos
=
-
1
;
Spos
=
0
;
//
Spos = 0;
NextSame
=
0
;
NextSame
=
0
;
SameRow
=
0
;
SameRow
=
0
;
}
else
{
}
else
{
...
@@ -493,7 +494,7 @@ bool JSONCOL::SetArrayOptions(PGLOBAL g, char *p, int i, PSZ nm)
...
@@ -493,7 +494,7 @@ bool JSONCOL::SetArrayOptions(PGLOBAL g, char *p, int i, PSZ nm)
if
(
!
IsTypeChar
(
Buf_Type
))
if
(
!
IsTypeChar
(
Buf_Type
))
jnp
->
Valp
=
AllocateValue
(
g
,
Buf_Type
,
0
,
GetPrecision
());
jnp
->
Valp
=
AllocateValue
(
g
,
Buf_Type
,
0
,
GetPrecision
());
else
else
jnp
->
Valp
=
AllocateValue
(
g
,
TYPE_DOUBLE
);
jnp
->
Valp
=
AllocateValue
(
g
,
TYPE_DOUBLE
,
0
,
2
);
break
;
break
;
case
OP_MIN
:
case
OP_MIN
:
...
@@ -610,7 +611,7 @@ void JSONCOL::SetJsonValue(PGLOBAL g, PVAL vp, PJVAL val, int n)
...
@@ -610,7 +611,7 @@ void JSONCOL::SetJsonValue(PGLOBAL g, PVAL vp, PJVAL val, int n)
break
;
break
;
case
TYPE_JOB
:
case
TYPE_JOB
:
// if (!vp->IsTypeNum() || !Strict) {
// if (!vp->IsTypeNum() || !Strict) {
vp
->
SetValue_psz
(
val
->
GetObject
()
->
GetText
(
g
));
vp
->
SetValue_psz
(
val
->
GetObject
()
->
GetText
(
g
,
NULL
));
break
;
break
;
// } // endif Type
// } // endif Type
...
@@ -1289,6 +1290,51 @@ int TDBJSON::MakeIndex(PGLOBAL g, PIXDEF pxdf, bool add)
...
@@ -1289,6 +1290,51 @@ int TDBJSON::MakeIndex(PGLOBAL g, PIXDEF pxdf, bool add)
}
// end of MakeIndex
}
// end of MakeIndex
/***********************************************************************/
/* Return the position in the table. */
/***********************************************************************/
int
TDBJSON
::
GetRecpos
(
void
)
{
#if 0
union {
uint Rpos;
BYTE Spos[4];
};
Rpos = htonl(Fpos);
Spos[0] = (BYTE)NextSame;
return Rpos;
#endif // 0
return
Fpos
;
}
// end of GetRecpos
/***********************************************************************/
/* Set the position in the table. */
/***********************************************************************/
bool
TDBJSON
::
SetRecpos
(
PGLOBAL
g
,
int
recpos
)
{
#if 0
union {
uint Rpos;
BYTE Spos[4];
};
Rpos = recpos;
NextSame = Spos[0];
Spos[0] = 0;
Fpos = (signed)ntohl(Rpos);
//if (Fpos != (signed)ntohl(Rpos)) {
// Fpos = ntohl(Rpos);
// same = false;
//} else
// same = true;
#endif // 0
Fpos
=
recpos
-
1
;
return
false
;
}
// end of SetRecpos
/***********************************************************************/
/***********************************************************************/
/* JSON Access Method opening routine. */
/* JSON Access Method opening routine. */
/***********************************************************************/
/***********************************************************************/
...
@@ -1299,7 +1345,6 @@ bool TDBJSON::OpenDB(PGLOBAL g)
...
@@ -1299,7 +1345,6 @@ bool TDBJSON::OpenDB(PGLOBAL g)
/* Table already open replace it at its beginning. */
/* Table already open replace it at its beginning. */
/*******************************************************************/
/*******************************************************************/
Fpos
=
-
1
;
Fpos
=
-
1
;
Spos
=
0
;
NextSame
=
false
;
NextSame
=
false
;
SameRow
=
0
;
SameRow
=
0
;
return
false
;
return
false
;
...
...
storage/connect/tabjson.h
View file @
e33b48ae
...
@@ -94,7 +94,7 @@ class TDBJSN : public TDBDOS {
...
@@ -94,7 +94,7 @@ class TDBJSN : public TDBDOS {
JMODE
Jmode
;
// MODE_OBJECT by default
JMODE
Jmode
;
// MODE_OBJECT by default
char
*
Xcol
;
// Name of expandable column
char
*
Xcol
;
// Name of expandable column
int
Fpos
;
// The current row index
int
Fpos
;
// The current row index
int
Spos
;
// DELETE start index
//
int Spos; // DELETE start index
int
N
;
// The current Rownum
int
N
;
// The current Rownum
int
Limit
;
// Limit of multiple values
int
Limit
;
// Limit of multiple values
int
Pretty
;
// Depends on file structure
int
Pretty
;
// Depends on file structure
...
@@ -174,7 +174,9 @@ class TDBJSON : public TDBJSN {
...
@@ -174,7 +174,9 @@ class TDBJSON : public TDBJSN {
virtual
int
Cardinality
(
PGLOBAL
g
);
virtual
int
Cardinality
(
PGLOBAL
g
);
virtual
int
GetMaxSize
(
PGLOBAL
g
);
virtual
int
GetMaxSize
(
PGLOBAL
g
);
virtual
void
ResetSize
(
void
);
virtual
void
ResetSize
(
void
);
virtual
int
GetRecpos
(
void
)
{
return
Fpos
;}
virtual
int
GetProgCur
(
void
)
{
return
N
;}
virtual
int
GetRecpos
(
void
);
virtual
bool
SetRecpos
(
PGLOBAL
g
,
int
recpos
);
virtual
bool
OpenDB
(
PGLOBAL
g
);
virtual
bool
OpenDB
(
PGLOBAL
g
);
virtual
int
ReadDB
(
PGLOBAL
g
);
virtual
int
ReadDB
(
PGLOBAL
g
);
virtual
bool
PrepareWriting
(
PGLOBAL
g
)
{
return
false
;}
virtual
bool
PrepareWriting
(
PGLOBAL
g
)
{
return
false
;}
...
...
storage/connect/tabodbc.cpp
View file @
e33b48ae
...
@@ -135,9 +135,16 @@ bool ODBCDEF::DefineAM(PGLOBAL g, LPCSTR am, int poff)
...
@@ -135,9 +135,16 @@ bool ODBCDEF::DefineAM(PGLOBAL g, LPCSTR am, int poff)
//Options = ODBConn::noOdbcDialog | ODBConn::useCursorLib;
//Options = ODBConn::noOdbcDialog | ODBConn::useCursorLib;
Cto
=
GetIntCatInfo
(
"ConnectTimeout"
,
DEFAULT_LOGIN_TIMEOUT
);
Cto
=
GetIntCatInfo
(
"ConnectTimeout"
,
DEFAULT_LOGIN_TIMEOUT
);
Qto
=
GetIntCatInfo
(
"QueryTimeout"
,
DEFAULT_QUERY_TIMEOUT
);
Qto
=
GetIntCatInfo
(
"QueryTimeout"
,
DEFAULT_QUERY_TIMEOUT
);
Scrollable
=
GetBoolCatInfo
(
"Scrollable"
,
false
);
if
((
Scrollable
=
GetBoolCatInfo
(
"Scrollable"
,
false
))
&&
!
Elemt
)
Elemt
=
1
;
// Cannot merge SQLFetch and SQLExtendedFetch
UseCnc
=
GetBoolCatInfo
(
"UseDSN"
,
false
);
UseCnc
=
GetBoolCatInfo
(
"UseDSN"
,
false
);
Memory
=
GetBoolCatInfo
(
"Memory"
,
false
);
// Memory was Boolean, it is now integer
if
(
!
(
Memory
=
GetIntCatInfo
(
"Memory"
,
0
)))
Memory
=
GetBoolCatInfo
(
"Memory"
,
false
)
?
1
:
0
;
Pseudo
=
2
;
// FILID is Ok but not ROWID
Pseudo
=
2
;
// FILID is Ok but not ROWID
return
false
;
return
false
;
}
// end of DefineAM
}
// end of DefineAM
...
@@ -206,7 +213,7 @@ TDBODBC::TDBODBC(PODEF tdp) : TDBASE(tdp)
...
@@ -206,7 +213,7 @@ TDBODBC::TDBODBC(PODEF tdp) : TDBASE(tdp)
Quoted
=
MY_MAX
(
0
,
tdp
->
GetQuoted
());
Quoted
=
MY_MAX
(
0
,
tdp
->
GetQuoted
());
Rows
=
tdp
->
GetElemt
();
Rows
=
tdp
->
GetElemt
();
Catver
=
tdp
->
Catver
;
Catver
=
tdp
->
Catver
;
Memory
=
(
tdp
->
Memory
)
?
1
:
0
;
Memory
=
tdp
->
Memory
;
Scrollable
=
tdp
->
Scrollable
;
Scrollable
=
tdp
->
Scrollable
;
Ops
.
UseCnc
=
tdp
->
UseCnc
;
Ops
.
UseCnc
=
tdp
->
UseCnc
;
}
else
{
}
else
{
...
@@ -238,11 +245,13 @@ TDBODBC::TDBODBC(PODEF tdp) : TDBASE(tdp)
...
@@ -238,11 +245,13 @@ TDBODBC::TDBODBC(PODEF tdp) : TDBASE(tdp)
DBQ
=
NULL
;
DBQ
=
NULL
;
Qrp
=
NULL
;
Qrp
=
NULL
;
Fpos
=
0
;
Fpos
=
0
;
Curpos
=
0
;
AftRows
=
0
;
AftRows
=
0
;
CurNum
=
0
;
CurNum
=
0
;
Rbuf
=
0
;
Rbuf
=
0
;
BufSize
=
0
;
BufSize
=
0
;
Nparm
=
0
;
Nparm
=
0
;
Placed
=
false
;
}
// end of TDBODBC standard constructor
}
// end of TDBODBC standard constructor
TDBODBC
::
TDBODBC
(
PTDBODBC
tdbp
)
:
TDBASE
(
tdbp
)
TDBODBC
::
TDBODBC
(
PTDBODBC
tdbp
)
:
TDBASE
(
tdbp
)
...
@@ -267,15 +276,15 @@ TDBODBC::TDBODBC(PTDBODBC tdbp) : TDBASE(tdbp)
...
@@ -267,15 +276,15 @@ TDBODBC::TDBODBC(PTDBODBC tdbp) : TDBASE(tdbp)
Options
=
tdbp
->
Options
;
Options
=
tdbp
->
Options
;
Quoted
=
tdbp
->
Quoted
;
Quoted
=
tdbp
->
Quoted
;
Rows
=
tdbp
->
Rows
;
Rows
=
tdbp
->
Rows
;
Fpos
=
tdbp
->
Fpos
;
Fpos
=
0
;
AftRows
=
tdbp
->
AftRows
;
Curpos
=
0
;
//Tpos = tdbp->Tpos;
AftRows
=
0
;
//Spos = tdbp->Spos;
CurNum
=
0
;
CurNum
=
tdbp
->
CurNum
;
Rbuf
=
0
;
Rbuf
=
tdbp
->
Rbuf
;
BufSize
=
tdbp
->
BufSize
;
BufSize
=
tdbp
->
BufSize
;
Nparm
=
tdbp
->
Nparm
;
Nparm
=
tdbp
->
Nparm
;
Qrp
=
tdbp
->
Qrp
;
Qrp
=
tdbp
->
Qrp
;
Placed
=
false
;
}
// end of TDBODBC copy constructor
}
// end of TDBODBC copy constructor
// Method
// Method
...
@@ -811,10 +820,12 @@ bool TDBODBC::OpenDB(PGLOBAL g)
...
@@ -811,10 +820,12 @@ bool TDBODBC::OpenDB(PGLOBAL g)
return
true
;
return
true
;
}
// endif Rewind
}
// endif Rewind
}
// endif Memory
}
else
Rbuf
=
Qrp
->
Nblin
;
CurNum
=
0
;
CurNum
=
0
;
Fpos
=
0
;
Fpos
=
0
;
Curpos
=
1
;
return
false
;
return
false
;
}
// endif use
}
// endif use
...
@@ -841,6 +852,37 @@ bool TDBODBC::OpenDB(PGLOBAL g)
...
@@ -841,6 +852,37 @@ bool TDBODBC::OpenDB(PGLOBAL g)
/* Make the command and allocate whatever is used for getting results. */
/* Make the command and allocate whatever is used for getting results. */
/*********************************************************************/
/*********************************************************************/
if
(
Mode
==
MODE_READ
||
Mode
==
MODE_READX
)
{
if
(
Mode
==
MODE_READ
||
Mode
==
MODE_READX
)
{
if
(
Memory
>
1
&&
!
Srcdef
)
{
char
*
Sql
;
int
n
;
if
((
Sql
=
MakeSQL
(
g
,
true
)))
{
// Allocate a Count(*) column
Cnp
=
new
(
g
)
ODBCCOL
;
Cnp
->
InitValue
(
g
);
if
((
n
=
Ocp
->
GetResultSize
(
Sql
,
Cnp
))
<
0
)
{
strcpy
(
g
->
Message
,
"Cannot get result size"
);
return
true
;
}
// endif n
Ocp
->
m_Rows
=
n
;
if
((
Qrp
=
Ocp
->
AllocateResult
(
g
)))
Memory
=
2
;
// Must be filled
else
{
strcpy
(
g
->
Message
,
"Memory allocation failed"
);
return
true
;
}
// endif n
Ocp
->
m_Rows
=
0
;
}
else
{
strcpy
(
g
->
Message
,
"MakeSQL failed"
);
return
true
;
}
// endif Sql
}
// endif Memory
if
((
Query
=
MakeSQL
(
g
,
false
)))
{
if
((
Query
=
MakeSQL
(
g
,
false
)))
{
for
(
PODBCCOL
colp
=
(
PODBCCOL
)
Columns
;
colp
;
for
(
PODBCCOL
colp
=
(
PODBCCOL
)
Columns
;
colp
;
colp
=
(
PODBCCOL
)
colp
->
GetNext
())
colp
=
(
PODBCCOL
)
colp
->
GetNext
())
...
@@ -882,9 +924,40 @@ bool TDBODBC::OpenDB(PGLOBAL g)
...
@@ -882,9 +924,40 @@ bool TDBODBC::OpenDB(PGLOBAL g)
/***********************************************************************/
/***********************************************************************/
int
TDBODBC
::
GetRecpos
(
void
)
int
TDBODBC
::
GetRecpos
(
void
)
{
{
return
Fpos
;
// To be really implemented
return
Fpos
;
}
// end of GetRecpos
}
// end of GetRecpos
/***********************************************************************/
/* SetRecpos: set the position of next read record. */
/***********************************************************************/
bool
TDBODBC
::
SetRecpos
(
PGLOBAL
g
,
int
recpos
)
{
if
(
Ocp
->
m_Full
)
{
Fpos
=
0
;
CurNum
=
recpos
-
1
;
}
else
if
(
Memory
==
3
)
{
Fpos
=
recpos
;
CurNum
=
-
1
;
}
else
if
(
Scrollable
)
{
// Is new position in the current row set?
if
(
recpos
>=
Curpos
&&
recpos
<
Curpos
+
Rbuf
)
{
CurNum
=
recpos
-
Curpos
;
Fpos
=
0
;
}
else
{
Fpos
=
recpos
;
CurNum
=
0
;
}
// endif recpos
}
else
{
strcpy
(
g
->
Message
,
"This action requires a scrollable cursor"
);
return
true
;
}
// endif's
// Indicate the table position was externally set
Placed
=
true
;
return
false
;
}
// end of SetRecpos
/***********************************************************************/
/***********************************************************************/
/* VRDNDOS: Data Base read routine for odbc access method. */
/* VRDNDOS: Data Base read routine for odbc access method. */
/***********************************************************************/
/***********************************************************************/
...
@@ -924,22 +997,32 @@ int TDBODBC::ReadDB(PGLOBAL g)
...
@@ -924,22 +997,32 @@ int TDBODBC::ReadDB(PGLOBAL g)
/* Now start the reading process. */
/* Now start the reading process. */
/* Here is the place to fetch the line(s). */
/* Here is the place to fetch the line(s). */
/*********************************************************************/
/*********************************************************************/
if
(
Memory
!=
3
)
{
if
(
Placed
)
{
if
(
++
CurNum
>=
Rbuf
)
{
if
(
Fpos
&&
CurNum
>=
0
)
Rbuf
=
Ocp
->
Fetch
();
Rbuf
=
Ocp
->
Fetch
((
Curpos
=
Fpos
));
CurNum
=
0
;
}
// endif CurNum
rc
=
(
Rbuf
>
0
)
?
RC_OK
:
(
Rbuf
==
0
)
?
RC_EF
:
RC_FX
;
rc
=
(
Rbuf
>
0
)
?
RC_OK
:
(
Rbuf
==
0
)
?
RC_EF
:
RC_FX
;
}
else
// Getting result from memory
Placed
=
false
;
rc
=
(
Fpos
<
Qrp
->
Nblin
)
?
RC_OK
:
RC_EF
;
}
else
{
if
(
Memory
!=
3
)
{
if
(
++
CurNum
>=
Rbuf
)
{
Rbuf
=
Ocp
->
Fetch
();
Curpos
=
Fpos
+
1
;
CurNum
=
0
;
}
// endif CurNum
if
(
rc
==
RC_OK
)
{
rc
=
(
Rbuf
>
0
)
?
RC_OK
:
(
Rbuf
==
0
)
?
RC_EF
:
RC_FX
;
if
(
Memory
==
2
)
}
else
// Getting result from memory
Qrp
->
Nblin
++
;
rc
=
(
Fpos
<
Qrp
->
Nblin
)
?
RC_OK
:
RC_EF
;
Fpos
++
;
// Used for memory
if
(
rc
==
RC_OK
)
{
}
// endif rc
if
(
Memory
==
2
)
Qrp
->
Nblin
++
;
Fpos
++
;
// Used for memory and pos
}
// endif rc
}
// endif Placed
if
(
trace
>
1
)
if
(
trace
>
1
)
htrc
(
" Read: Rbuf=%d rc=%d
\n
"
,
Rbuf
,
rc
);
htrc
(
" Read: Rbuf=%d rc=%d
\n
"
,
Rbuf
,
rc
);
...
...
storage/connect/tabodbc.h
View file @
e33b48ae
...
@@ -64,8 +64,8 @@ class DllExport ODBCDEF : public TABDEF { /* Logical table description */
...
@@ -64,8 +64,8 @@ class DllExport ODBCDEF : public TABDEF { /* Logical table description */
int
Quoted
;
/* Identifier quoting level */
int
Quoted
;
/* Identifier quoting level */
int
Maxerr
;
/* Maxerr for an Exec table */
int
Maxerr
;
/* Maxerr for an Exec table */
int
Maxres
;
/* Maxres for a catalog table */
int
Maxres
;
/* Maxres for a catalog table */
int
Memory
;
/* Put result set in memory */
bool
Scrollable
;
/* Use scrollable cursor */
bool
Scrollable
;
/* Use scrollable cursor */
bool
Memory
;
/* Put result set in memory */
bool
Xsrc
;
/* Execution type */
bool
Xsrc
;
/* Execution type */
bool
UseCnc
;
/* Use SQLConnect (!SQLDriverConnect) */
bool
UseCnc
;
/* Use SQLConnect (!SQLDriverConnect) */
};
// end of ODBCDEF
};
// end of ODBCDEF
...
@@ -93,6 +93,7 @@ class TDBODBC : public TDBASE {
...
@@ -93,6 +93,7 @@ class TDBODBC : public TDBASE {
// Methods
// Methods
virtual
PTDB
CopyOne
(
PTABS
t
);
virtual
PTDB
CopyOne
(
PTABS
t
);
virtual
int
GetRecpos
(
void
);
virtual
int
GetRecpos
(
void
);
virtual
bool
SetRecpos
(
PGLOBAL
g
,
int
recpos
);
virtual
PSZ
GetFile
(
PGLOBAL
g
);
virtual
PSZ
GetFile
(
PGLOBAL
g
);
virtual
void
SetFile
(
PGLOBAL
g
,
PSZ
fn
);
virtual
void
SetFile
(
PGLOBAL
g
,
PSZ
fn
);
virtual
void
ResetSize
(
void
);
virtual
void
ResetSize
(
void
);
...
@@ -148,6 +149,7 @@ class TDBODBC : public TDBASE {
...
@@ -148,6 +149,7 @@ class TDBODBC : public TDBASE {
int
Qto
;
// Query timeout
int
Qto
;
// Query timeout
int
Quoted
;
// The identifier quoting level
int
Quoted
;
// The identifier quoting level
int
Fpos
;
// Position of last read record
int
Fpos
;
// Position of last read record
int
Curpos
;
// Cursor position of last fetch
int
AftRows
;
// The number of affected rows
int
AftRows
;
// The number of affected rows
int
Rows
;
// Rowset size
int
Rows
;
// Rowset size
int
Catver
;
// Catalog ODBC version
int
Catver
;
// Catalog ODBC version
...
@@ -157,6 +159,7 @@ class TDBODBC : public TDBASE {
...
@@ -157,6 +159,7 @@ class TDBODBC : public TDBASE {
int
Nparm
;
// The number of statement parameters
int
Nparm
;
// The number of statement parameters
int
Memory
;
// 0: No 1: Alloc 2: Put 3: Get
int
Memory
;
// 0: No 1: Alloc 2: Put 3: Get
bool
Scrollable
;
// Use scrollable cursor
bool
Scrollable
;
// Use scrollable cursor
bool
Placed
;
// True for position reading
bool
UseCnc
;
// Use SQLConnect (!SQLDriverConnect)
bool
UseCnc
;
// Use SQLConnect (!SQLDriverConnect)
PQRYRES
Qrp
;
// Points to storage result
PQRYRES
Qrp
;
// Points to storage result
};
// end of class TDBODBC
};
// end of class TDBODBC
...
...
storage/connect/tabutil.cpp
View file @
e33b48ae
/************* Tabutil cpp Declares Source Code File (.CPP) ************/
/************* Tabutil cpp Declares Source Code File (.CPP) ************/
/* Name: TABUTIL.CPP Version 1.
0
*/
/* Name: TABUTIL.CPP Version 1.
1
*/
/* */
/* */
/* (C) Copyright to the author Olivier BERTRAND 2013
*/
/* (C) Copyright to the author Olivier BERTRAND 2013
- 2015
*/
/* */
/* */
/* Utility function used by the PROXY, XCOL, OCCUR, and TBL tables. */
/* Utility function used by the PROXY, XCOL, OCCUR, and TBL tables. */
/***********************************************************************/
/***********************************************************************/
...
@@ -9,7 +9,8 @@
...
@@ -9,7 +9,8 @@
/***********************************************************************/
/***********************************************************************/
/* Include relevant section of system dependant header files. */
/* Include relevant section of system dependant header files. */
/***********************************************************************/
/***********************************************************************/
#include "my_global.h"
#define MYSQL_SERVER 1
#include <my_global.h>
#include "sql_class.h"
#include "sql_class.h"
#include "table.h"
#include "table.h"
#include "field.h"
#include "field.h"
...
@@ -108,6 +109,9 @@ TABLE_SHARE *GetTableShare(PGLOBAL g, THD *thd, const char *db,
...
@@ -108,6 +109,9 @@ TABLE_SHARE *GetTableShare(PGLOBAL g, THD *thd, const char *db,
}
// endif is_view
}
// endif is_view
}
else
{
}
else
{
if
(
thd
->
is_error
())
thd
->
clear_error
();
// Avoid stopping info commands
sprintf
(
g
->
Message
,
"Error %d opening share
\n
"
,
s
->
error
);
sprintf
(
g
->
Message
,
"Error %d opening share
\n
"
,
s
->
error
);
free_table_share
(
s
);
free_table_share
(
s
);
return
NULL
;
return
NULL
;
...
...
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