Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
MariaDB
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
MariaDB
Commits
0c06320a
Commit
0c06320a
authored
Oct 21, 2022
by
Anel
Committed by
GitHub
Oct 21, 2022
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
MDEV-29687:ODBC tables do not quote identifier names correctly (#2295)
Reviewer: andrew@mariadb.org
parent
e1414fc7
Changes
6
Show whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
68 additions
and
5 deletions
+68
-5
storage/connect/mysql-test/connect/r/odbc_postgresql.result
storage/connect/mysql-test/connect/r/odbc_postgresql.result
+13
-0
storage/connect/mysql-test/connect/t/odbc_postgresql.sql
storage/connect/mysql-test/connect/t/odbc_postgresql.sql
+2
-0
storage/connect/mysql-test/connect/t/odbc_postgresql.test
storage/connect/mysql-test/connect/t/odbc_postgresql.test
+7
-0
storage/connect/odbconn.cpp
storage/connect/odbconn.cpp
+6
-0
storage/connect/tabext.cpp
storage/connect/tabext.cpp
+39
-5
storage/connect/tabext.h
storage/connect/tabext.h
+1
-0
No files found.
storage/connect/mysql-test/connect/r/odbc_postgresql.result
View file @
0c06320a
...
@@ -15,6 +15,7 @@ Table_Cat Table_Schema Table_Name Table_Type Remark
...
@@ -15,6 +15,7 @@ Table_Cat Table_Schema Table_Name Table_Type Remark
mtr public t1 TABLE
mtr public t1 TABLE
mtr public t2 TABLE
mtr public t2 TABLE
mtr public v1 VIEW
mtr public v1 VIEW
mtr schema1 space_in_column_name TABLE
mtr schema1 t1 TABLE
mtr schema1 t1 TABLE
mtr schema1 t2 TABLE
mtr schema1 t2 TABLE
mtr schema1 t3 TABLE
mtr schema1 t3 TABLE
...
@@ -27,6 +28,7 @@ Table_Cat Table_Schema Table_Name Table_Type Remark
...
@@ -27,6 +28,7 @@ Table_Cat Table_Schema Table_Name Table_Type Remark
mtr public t1 TABLE
mtr public t1 TABLE
mtr public t2 TABLE
mtr public t2 TABLE
mtr public v1 VIEW
mtr public v1 VIEW
mtr schema1 space_in_column_name TABLE
mtr schema1 t1 TABLE
mtr schema1 t1 TABLE
mtr schema1 t2 TABLE
mtr schema1 t2 TABLE
mtr schema1 t3 TABLE
mtr schema1 t3 TABLE
...
@@ -39,6 +41,7 @@ Table_Cat Table_Schema Table_Name Table_Type Remark
...
@@ -39,6 +41,7 @@ Table_Cat Table_Schema Table_Name Table_Type Remark
mtr public t1 TABLE
mtr public t1 TABLE
mtr public t2 TABLE
mtr public t2 TABLE
mtr public v1 VIEW
mtr public v1 VIEW
mtr schema1 space_in_column_name TABLE
mtr schema1 t1 TABLE
mtr schema1 t1 TABLE
mtr schema1 t2 TABLE
mtr schema1 t2 TABLE
mtr schema1 t3 TABLE
mtr schema1 t3 TABLE
...
@@ -102,6 +105,7 @@ Table_Cat Table_Schema Table_Name Column_Name Data_Type Type_Name Column_Size Bu
...
@@ -102,6 +105,7 @@ Table_Cat Table_Schema Table_Name Column_Name Data_Type Type_Name Column_Size Bu
mtr public t1 a 4 int4 10 4 0 10 0
mtr public t1 a 4 int4 10 4 0 10 0
mtr public t2 a 4 int4 10 4 0 10 0
mtr public t2 a 4 int4 10 4 0 10 0
mtr public v1 a 4 int4 10 4 0 10 1
mtr public v1 a 4 int4 10 4 0 10 1
mtr schema1 space_in_column_name my space column 1 bpchar 20 80 NULL NULL 0
mtr schema1 t1 a 1 bpchar 10 40 NULL NULL 0
mtr schema1 t1 a 1 bpchar 10 40 NULL NULL 0
mtr schema1 t2 a 1 bpchar 10 40 NULL NULL 0
mtr schema1 t2 a 1 bpchar 10 40 NULL NULL 0
mtr schema1 t3 a 1 bpchar 10 40 NULL NULL 0
mtr schema1 t3 a 1 bpchar 10 40 NULL NULL 0
...
@@ -115,6 +119,7 @@ Table_Cat Table_Schema Table_Name Column_Name Data_Type Type_Name Column_Size Bu
...
@@ -115,6 +119,7 @@ Table_Cat Table_Schema Table_Name Column_Name Data_Type Type_Name Column_Size Bu
mtr public t1 a 4 int4 10 4 0 10 0
mtr public t1 a 4 int4 10 4 0 10 0
mtr public t2 a 4 int4 10 4 0 10 0
mtr public t2 a 4 int4 10 4 0 10 0
mtr public v1 a 4 int4 10 4 0 10 1
mtr public v1 a 4 int4 10 4 0 10 1
mtr schema1 space_in_column_name my space column 1 bpchar 20 80 NULL NULL 0
mtr schema1 t1 a 1 bpchar 10 40 NULL NULL 0
mtr schema1 t1 a 1 bpchar 10 40 NULL NULL 0
mtr schema1 t2 a 1 bpchar 10 40 NULL NULL 0
mtr schema1 t2 a 1 bpchar 10 40 NULL NULL 0
mtr schema1 t3 a 1 bpchar 10 40 NULL NULL 0
mtr schema1 t3 a 1 bpchar 10 40 NULL NULL 0
...
@@ -306,3 +311,11 @@ DELETE FROM t1 WHERE a='20';
...
@@ -306,3 +311,11 @@ DELETE FROM t1 WHERE a='20';
Warnings:
Warnings:
Note 1105 schema1.t3: 0 affected rows
Note 1105 schema1.t3: 0 affected rows
DROP TABLE t1;
DROP TABLE t1;
#
# MDEV-29687 ODBC tables do not quote identifier names correctly
#
CREATE TABLE pg_in_maria ENGINE=CONNECT TABNAME='schema1.space_in_column_name' CHARSET=utf8 DATA_CHARSET=utf8 TABLE_TYPE=ODBC CONNECTION='DSN=ConnectEnginePostgresql;UID=mtr;PWD=mtr' quoted=1;
SELECT * from pg_in_maria;
my space column
My value
DROP TABLE pg_in_maria;
storage/connect/mysql-test/connect/t/odbc_postgresql.sql
View file @
0c06320a
...
@@ -27,4 +27,6 @@ CREATE TABLE schema1.t2 (a CHAR(10) NOT NULL);
...
@@ -27,4 +27,6 @@ CREATE TABLE schema1.t2 (a CHAR(10) NOT NULL);
INSERT
INTO
schema1
.
t2
VALUES
(
'xxx'
),(
'yyy'
),(
'zzz'
),(
'ÄÖÜ'
);
INSERT
INTO
schema1
.
t2
VALUES
(
'xxx'
),(
'yyy'
),(
'zzz'
),(
'ÄÖÜ'
);
CREATE
TABLE
schema1
.
t3
(
a
CHAR
(
10
)
NOT
NULL
,
b
CHAR
(
10
)
NOT
NULL
);
CREATE
TABLE
schema1
.
t3
(
a
CHAR
(
10
)
NOT
NULL
,
b
CHAR
(
10
)
NOT
NULL
);
INSERT
INTO
schema1
.
t3
VALUES
(
'xxx'
,
'aaa'
),(
'yyy'
,
'bbb'
),(
'zzz'
,
'ccc'
),(
'ÄÖÜ'
,
'яяя'
);
INSERT
INTO
schema1
.
t3
VALUES
(
'xxx'
,
'aaa'
),(
'yyy'
,
'bbb'
),(
'zzz'
,
'ccc'
),(
'ÄÖÜ'
,
'яяя'
);
CREATE
TABLE
schema1
.
space_in_column_name
(
"my space column"
CHAR
(
20
)
NOT
NULL
);
INSERT
INTO
schema1
.
space_in_column_name
VALUES
(
'My value'
);
\
dt
schema1
.
*
\
dt
schema1
.
*
storage/connect/mysql-test/connect/t/odbc_postgresql.test
View file @
0c06320a
...
@@ -216,3 +216,10 @@ DROP TABLE t1;
...
@@ -216,3 +216,10 @@ DROP TABLE t1;
CREATE
TABLE
t1
(
a
VARCHAR
(
6
),
b
VARCHAR
(
6
),
PRIMARY
KEY
(
a
,
b
))
ENGINE
=
CONNECT
TABNAME
=
'schema1.t3'
CHARSET
=
utf8
DATA_CHARSET
=
utf8
TABLE_TYPE
=
ODBC
CONNECTION
=
'DSN=ConnectEnginePostgresql;UID=mtr;PWD=mtr'
;
CREATE
TABLE
t1
(
a
VARCHAR
(
6
),
b
VARCHAR
(
6
),
PRIMARY
KEY
(
a
,
b
))
ENGINE
=
CONNECT
TABNAME
=
'schema1.t3'
CHARSET
=
utf8
DATA_CHARSET
=
utf8
TABLE_TYPE
=
ODBC
CONNECTION
=
'DSN=ConnectEnginePostgresql;UID=mtr;PWD=mtr'
;
DELETE
FROM
t1
WHERE
a
=
'20'
;
DELETE
FROM
t1
WHERE
a
=
'20'
;
DROP
TABLE
t1
;
DROP
TABLE
t1
;
--
echo
#
--
echo
# MDEV-29687 ODBC tables do not quote identifier names correctly
--
echo
#
CREATE
TABLE
pg_in_maria
ENGINE
=
CONNECT
TABNAME
=
'schema1.space_in_column_name'
CHARSET
=
utf8
DATA_CHARSET
=
utf8
TABLE_TYPE
=
ODBC
CONNECTION
=
'DSN=ConnectEnginePostgresql;UID=mtr;PWD=mtr'
quoted
=
1
;
SELECT
*
from
pg_in_maria
;
DROP
TABLE
pg_in_maria
;
storage/connect/odbconn.cpp
View file @
0c06320a
...
@@ -997,6 +997,11 @@ ODBConn::ODBConn(PGLOBAL g, TDBODBC *tdbp)
...
@@ -997,6 +997,11 @@ ODBConn::ODBConn(PGLOBAL g, TDBODBC *tdbp)
m_Full
=
false
;
m_Full
=
false
;
m_UseCnc
=
false
;
m_UseCnc
=
false
;
m_IDQuoteChar
[
0
]
=
'"'
;
m_IDQuoteChar
[
0
]
=
'"'
;
if
(
tdbp
)
{
if
(
tdbp
->
Quoted
&&
tdbp
->
Quote
)
m_IDQuoteChar
[
0
]
=
*
tdbp
->
Quote
;
}
m_IDQuoteChar
[
1
]
=
0
;
m_IDQuoteChar
[
1
]
=
0
;
//*m_ErrMsg = '\0';
//*m_ErrMsg = '\0';
}
// end of ODBConn
}
// end of ODBConn
...
@@ -1179,6 +1184,7 @@ int ODBConn::Open(PCSZ ConnectString, POPARM sop, DWORD options)
...
@@ -1179,6 +1184,7 @@ int ODBConn::Open(PCSZ ConnectString, POPARM sop, DWORD options)
// Verify support for required functionality and cache info
// Verify support for required functionality and cache info
// VerifyConnect(); Deprecated
// VerifyConnect(); Deprecated
GetConnectInfo
();
GetConnectInfo
();
// Still we want to use the set QChar
}
catch
(
DBX
*
xp
)
{
}
catch
(
DBX
*
xp
)
{
snprintf
(
g
->
Message
,
sizeof
(
g
->
Message
),
"%s: %s"
,
xp
->
m_Msg
,
xp
->
GetErrorMessage
(
0
));
snprintf
(
g
->
Message
,
sizeof
(
g
->
Message
),
"%s: %s"
,
xp
->
m_Msg
,
xp
->
GetErrorMessage
(
0
));
Close
();
Close
();
...
...
storage/connect/tabext.cpp
View file @
0c06320a
...
@@ -159,6 +159,9 @@ bool EXTDEF::DefineAM(PGLOBAL g, LPCSTR am, int poff)
...
@@ -159,6 +159,9 @@ bool EXTDEF::DefineAM(PGLOBAL g, LPCSTR am, int poff)
Maxerr
=
GetIntCatInfo
(
"Maxerr"
,
0
);
Maxerr
=
GetIntCatInfo
(
"Maxerr"
,
0
);
Maxres
=
GetIntCatInfo
(
"Maxres"
,
0
);
Maxres
=
GetIntCatInfo
(
"Maxres"
,
0
);
Quoted
=
GetIntCatInfo
(
"Quoted"
,
0
);
Quoted
=
GetIntCatInfo
(
"Quoted"
,
0
);
Qchar
=
GetStringCatInfo
(
g
,
"Qchar"
,
NULL
);
if
(
Qchar
&&
!
Quoted
)
Quoted
=
1
;
Options
=
0
;
Options
=
0
;
Cto
=
0
;
Cto
=
0
;
Qto
=
0
;
Qto
=
0
;
...
@@ -198,6 +201,7 @@ TDBEXT::TDBEXT(EXTDEF *tdp) : TDB(tdp)
...
@@ -198,6 +201,7 @@ TDBEXT::TDBEXT(EXTDEF *tdp) : TDB(tdp)
Cto
=
tdp
->
Cto
;
Cto
=
tdp
->
Cto
;
Qto
=
tdp
->
Qto
;
Qto
=
tdp
->
Qto
;
Quoted
=
MY_MAX
(
0
,
tdp
->
GetQuoted
());
Quoted
=
MY_MAX
(
0
,
tdp
->
GetQuoted
());
Quote
=
tdp
->
GetQchar
();
Rows
=
tdp
->
GetElemt
();
Rows
=
tdp
->
GetElemt
();
Memory
=
tdp
->
Memory
;
Memory
=
tdp
->
Memory
;
Scrollable
=
tdp
->
Scrollable
;
Scrollable
=
tdp
->
Scrollable
;
...
@@ -214,12 +218,12 @@ TDBEXT::TDBEXT(EXTDEF *tdp) : TDB(tdp)
...
@@ -214,12 +218,12 @@ TDBEXT::TDBEXT(EXTDEF *tdp) : TDB(tdp)
Cto
=
0
;
Cto
=
0
;
Qto
=
0
;
Qto
=
0
;
Quoted
=
0
;
Quoted
=
0
;
Quote
=
NULL
;
Rows
=
0
;
Rows
=
0
;
Memory
=
0
;
Memory
=
0
;
Scrollable
=
false
;
Scrollable
=
false
;
}
// endif tdp
}
// endif tdp
Quote
=
NULL
;
Query
=
NULL
;
Query
=
NULL
;
Count
=
NULL
;
Count
=
NULL
;
//Where = NULL;
//Where = NULL;
...
@@ -252,6 +256,7 @@ TDBEXT::TDBEXT(PTDBEXT tdbp) : TDB(tdbp)
...
@@ -252,6 +256,7 @@ TDBEXT::TDBEXT(PTDBEXT tdbp) : TDB(tdbp)
Cto
=
tdbp
->
Cto
;
Cto
=
tdbp
->
Cto
;
Qto
=
tdbp
->
Qto
;
Qto
=
tdbp
->
Qto
;
Quoted
=
tdbp
->
Quoted
;
Quoted
=
tdbp
->
Quoted
;
Quote
=
tdbp
->
Quote
;
Rows
=
tdbp
->
Rows
;
Rows
=
tdbp
->
Rows
;
Memory
=
tdbp
->
Memory
;
Memory
=
tdbp
->
Memory
;
Scrollable
=
tdbp
->
Scrollable
;
Scrollable
=
tdbp
->
Scrollable
;
...
@@ -390,6 +395,8 @@ bool TDBEXT::MakeSQL(PGLOBAL g, bool cnt)
...
@@ -390,6 +395,8 @@ bool TDBEXT::MakeSQL(PGLOBAL g, bool cnt)
bool
first
=
true
;
bool
first
=
true
;
PTABLE
tablep
=
To_Table
;
PTABLE
tablep
=
To_Table
;
PCOL
colp
;
PCOL
colp
;
char
*
res
=
NULL
,
*
my_schema_table
=
NULL
;
size_t
my_len
=
0
;
if
(
Srcdef
)
if
(
Srcdef
)
return
MakeSrcdef
(
g
);
return
MakeSrcdef
(
g
);
...
@@ -459,10 +466,37 @@ bool TDBEXT::MakeSQL(PGLOBAL g, bool cnt)
...
@@ -459,10 +466,37 @@ bool TDBEXT::MakeSQL(PGLOBAL g, bool cnt)
Decode
(
TableName
,
buf
,
sizeof
(
buf
));
Decode
(
TableName
,
buf
,
sizeof
(
buf
));
if
(
Quote
)
{
if
(
Quote
)
{
// Tabname can have both database and table identifiers, we need to parse
if
(
res
=
strstr
(
buf
,
"."
))
{
// Parse schema
my_len
=
res
-
buf
+
1
;
my_schema_table
=
(
char
*
)
malloc
(
my_len
);
memcpy
(
my_schema_table
,
buf
,
my_len
-
1
);
my_schema_table
[
my_len
]
=
0
;
Query
->
Append
(
Quote
);
Query
->
Append
(
my_schema_table
);
Query
->
Append
(
Quote
);
free
(
my_schema_table
);
Query
->
Append
(
"."
);
// Parse table
my_len
=
strlen
(
buf
)
-
my_len
+
1
;
my_schema_table
=
(
char
*
)
malloc
(
my_len
);
memcpy
(
my_schema_table
,
++
res
,
my_len
);
my_schema_table
[
my_len
]
=
0
;
Query
->
Append
(
Quote
);
Query
->
Append
(
my_schema_table
);
Query
->
Append
(
Quote
);
free
(
my_schema_table
);
}
else
{
// Put table name between identifier quotes in case in contains blanks
// Put table name between identifier quotes in case in contains blanks
Query
->
Append
(
Quote
);
Query
->
Append
(
Quote
);
Query
->
Append
(
buf
);
Query
->
Append
(
buf
);
Query
->
Append
(
Quote
);
Query
->
Append
(
Quote
);
}
}
else
}
else
Query
->
Append
(
buf
);
Query
->
Append
(
buf
);
...
...
storage/connect/tabext.h
View file @
0c06320a
...
@@ -68,6 +68,7 @@ class DllExport EXTDEF : public TABDEF { /* EXT table */
...
@@ -68,6 +68,7 @@ class DllExport EXTDEF : public TABDEF { /* EXT table */
inline
PSZ
GetSrcdef
(
void
)
{
return
Srcdef
;
}
inline
PSZ
GetSrcdef
(
void
)
{
return
Srcdef
;
}
inline
char
GetSep
(
void
)
{
return
(
Sep
)
?
*
Sep
:
0
;
}
inline
char
GetSep
(
void
)
{
return
(
Sep
)
?
*
Sep
:
0
;
}
inline
int
GetQuoted
(
void
)
{
return
Quoted
;
}
inline
int
GetQuoted
(
void
)
{
return
Quoted
;
}
inline
PSZ
GetQchar
(
void
)
{
return
Qchar
;
}
inline
int
GetOptions
(
void
)
{
return
Options
;
}
inline
int
GetOptions
(
void
)
{
return
Options
;
}
// Methods
// Methods
...
...
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