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
df58c0bc
Commit
df58c0bc
authored
Oct 20, 2004
by
konstantin@mysql.com
Browse files
Options
Browse Files
Download
Plain Diff
Merge bk-internal.mysql.com:/home/bk/mysql-4.1
into mysql.com:/media/sda1/mysql/mysql-4.1-6049
parents
42541dad
e546d901
Changes
10
Hide whitespace changes
Inline
Side-by-side
Showing
10 changed files
with
207 additions
and
118 deletions
+207
-118
include/my_time.h
include/my_time.h
+14
-0
libmysql/libmysql.c
libmysql/libmysql.c
+5
-25
sql-common/my_time.c
sql-common/my_time.c
+72
-0
sql/field.cc
sql/field.cc
+3
-5
sql/item.cc
sql/item.cc
+5
-9
sql/item_timefunc.cc
sql/item_timefunc.cc
+4
-7
sql/mysql_priv.h
sql/mysql_priv.h
+0
-9
sql/protocol.cc
sql/protocol.cc
+3
-4
sql/time.cc
sql/time.cc
+3
-56
tests/client_test.c
tests/client_test.c
+98
-3
No files found.
include/my_time.h
View file @
df58c0bc
...
...
@@ -60,6 +60,20 @@ my_system_gmt_sec(const MYSQL_TIME *t, long *my_timezone, bool *in_dst_time_gap)
void
set_zero_time
(
MYSQL_TIME
*
tm
);
/*
Required buffer length for my_time_to_str, my_date_to_str,
my_datetime_to_str and TIME_to_string functions. Note, that the
caller is still responsible to check that given TIME structure
has values in valid ranges, otherwise size of the buffer could
be not enough.
*/
#define MAX_DATE_STRING_REP_LENGTH 30
int
my_time_to_str
(
const
MYSQL_TIME
*
l_time
,
char
*
to
);
int
my_date_to_str
(
const
MYSQL_TIME
*
l_time
,
char
*
to
);
int
my_datetime_to_str
(
const
MYSQL_TIME
*
l_time
,
char
*
to
);
int
my_TIME_to_str
(
const
MYSQL_TIME
*
l_time
,
char
*
to
);
C_MODE_END
#endif
/* _my_time_h_ */
libmysql/libmysql.c
View file @
df58c0bc
...
...
@@ -3231,12 +3231,12 @@ static void read_binary_time(MYSQL_TIME *tm, uchar **pos)
tm
->
second_part
=
(
length
>
8
)
?
(
ulong
)
sint4korr
(
to
+
8
)
:
0
;
tm
->
year
=
tm
->
month
=
0
;
tm
->
time_type
=
MYSQL_TIMESTAMP_TIME
;
*
pos
+=
length
;
}
else
set_zero_time
(
tm
);
tm
->
time_type
=
MYSQL_TIMESTAMP_TIME
;
}
static
void
read_binary_datetime
(
MYSQL_TIME
*
tm
,
uchar
**
pos
)
...
...
@@ -3261,12 +3261,12 @@ static void read_binary_datetime(MYSQL_TIME *tm, uchar **pos)
else
tm
->
hour
=
tm
->
minute
=
tm
->
second
=
0
;
tm
->
second_part
=
(
length
>
7
)
?
(
ulong
)
sint4korr
(
to
+
7
)
:
0
;
tm
->
time_type
=
MYSQL_TIMESTAMP_DATETIME
;
*
pos
+=
length
;
}
else
set_zero_time
(
tm
);
tm
->
time_type
=
MYSQL_TIMESTAMP_DATETIME
;
}
static
void
read_binary_date
(
MYSQL_TIME
*
tm
,
uchar
**
pos
)
...
...
@@ -3283,12 +3283,12 @@ static void read_binary_date(MYSQL_TIME *tm, uchar **pos)
tm
->
hour
=
tm
->
minute
=
tm
->
second
=
0
;
tm
->
second_part
=
0
;
tm
->
neg
=
0
;
tm
->
time_type
=
MYSQL_TIMESTAMP_DATE
;
*
pos
+=
length
;
}
else
set_zero_time
(
tm
);
tm
->
time_type
=
MYSQL_TIMESTAMP_DATE
;
}
...
...
@@ -3566,28 +3566,8 @@ static void fetch_datetime_with_conversion(MYSQL_BIND *param,
Convert time value to string and delegate the rest to
fetch_string_with_conversion:
*/
char
buff
[
25
];
uint
length
;
switch
(
time
->
time_type
)
{
case
MYSQL_TIMESTAMP_DATE
:
length
=
my_sprintf
(
buff
,(
buff
,
"%04d-%02d-%02d"
,
time
->
year
,
time
->
month
,
time
->
day
));
break
;
case
MYSQL_TIMESTAMP_DATETIME
:
length
=
my_sprintf
(
buff
,(
buff
,
"%04d-%02d-%02d %02d:%02d:%02d"
,
time
->
year
,
time
->
month
,
time
->
day
,
time
->
hour
,
time
->
minute
,
time
->
second
));
break
;
case
MYSQL_TIMESTAMP_TIME
:
length
=
my_sprintf
(
buff
,
(
buff
,
"%02d:%02d:%02d"
,
time
->
hour
,
time
->
minute
,
time
->
second
));
break
;
default:
length
=
0
;
buff
[
0
]
=
'\0'
;
break
;
}
char
buff
[
MAX_DATE_STRING_REP_LENGTH
];
uint
length
=
my_TIME_to_str
(
time
,
buff
);
/* Resort to string conversion */
fetch_string_with_conversion
(
param
,
(
char
*
)
buff
,
length
);
break
;
...
...
sql-common/my_time.c
View file @
df58c0bc
...
...
@@ -726,3 +726,75 @@ void set_zero_time(MYSQL_TIME *tm)
tm
->
time_type
=
MYSQL_TIMESTAMP_NONE
;
}
/*
Functions to convert time/date/datetime value to a string,
using default format.
This functions don't check that given TIME structure members are
in valid range. If they are not, return value won't reflect any
valid date either. Additionally, make_time doesn't take into
account time->day member: it's assumed that days have been converted
to hours already.
RETURN
number of characters written to 'to'
*/
int
my_time_to_str
(
const
MYSQL_TIME
*
l_time
,
char
*
to
)
{
return
my_sprintf
(
to
,
(
to
,
"%s%02d:%02d:%02d"
,
(
l_time
->
neg
?
"-"
:
""
),
l_time
->
hour
,
l_time
->
minute
,
l_time
->
second
));
}
int
my_date_to_str
(
const
MYSQL_TIME
*
l_time
,
char
*
to
)
{
return
my_sprintf
(
to
,
(
to
,
"%04d-%02d-%02d"
,
l_time
->
year
,
l_time
->
month
,
l_time
->
day
));
}
int
my_datetime_to_str
(
const
MYSQL_TIME
*
l_time
,
char
*
to
)
{
return
my_sprintf
(
to
,
(
to
,
"%04d-%02d-%02d %02d:%02d:%02d"
,
l_time
->
year
,
l_time
->
month
,
l_time
->
day
,
l_time
->
hour
,
l_time
->
minute
,
l_time
->
second
));
}
/*
Convert struct DATE/TIME/DATETIME value to string using built-in
MySQL time conversion formats.
SYNOPSIS
my_TIME_to_string()
NOTE
The string must have at least MAX_DATE_STRING_REP_LENGTH bytes reserved.
*/
int
my_TIME_to_str
(
const
MYSQL_TIME
*
l_time
,
char
*
to
)
{
switch
(
l_time
->
time_type
)
{
case
MYSQL_TIMESTAMP_DATETIME
:
return
my_datetime_to_str
(
l_time
,
to
);
case
MYSQL_TIMESTAMP_DATE
:
return
my_date_to_str
(
l_time
,
to
);
case
MYSQL_TIMESTAMP_TIME
:
return
my_time_to_str
(
l_time
,
to
);
case
MYSQL_TIMESTAMP_NONE
:
case
MYSQL_TIMESTAMP_ERROR
:
to
[
0
]
=
'\0'
;
return
0
;
default:
DBUG_ASSERT
(
0
);
return
0
;
}
}
sql/field.cc
View file @
df58c0bc
...
...
@@ -452,11 +452,9 @@ bool Field::get_time(TIME *ltime)
void
Field
::
store_time
(
TIME
*
ltime
,
timestamp_type
type
)
{
char
buff
[
MAX_DATE_REP_LENGTH
];
String
tmp
;
tmp
.
set
(
buff
,
sizeof
(
buff
),
&
my_charset_bin
);
TIME_to_string
(
ltime
,
&
tmp
);
store
(
buff
,
tmp
.
length
(),
&
my_charset_bin
);
char
buff
[
MAX_DATE_STRING_REP_LENGTH
];
uint
length
=
(
uint
)
my_TIME_to_str
(
ltime
,
buff
);
store
(
buff
,
length
,
&
my_charset_bin
);
}
...
...
sql/item.cc
View file @
df58c0bc
...
...
@@ -988,9 +988,10 @@ String *Item_param::val_str(String* str)
return
str
;
case
TIME_VALUE
:
{
if
(
str
->
reserve
(
MAX_DATE_REP_LENGTH
))
if
(
str
->
reserve
(
MAX_DATE_
STRING_
REP_LENGTH
))
break
;
TIME_to_string
(
&
value
.
time
,
str
);
str
->
length
((
uint
)
my_TIME_to_str
(
&
value
.
time
,
(
char
*
)
str
->
ptr
()));
str
->
set_charset
(
&
my_charset_bin
);
return
str
;
}
case
NULL_VALUE
:
...
...
@@ -1020,24 +1021,19 @@ const String *Item_param::query_val_str(String* str) const
case
TIME_VALUE
:
{
char
*
buf
,
*
ptr
;
String
tmp
;
str
->
length
(
0
);
/*
TODO: in case of error we need to notify replication
that binary log contains wrong statement
*/
if
(
str
->
reserve
(
MAX_DATE_REP_LENGTH
+
3
))
if
(
str
->
reserve
(
MAX_DATE_
STRING_
REP_LENGTH
+
3
))
break
;
/* Create date string inplace */
buf
=
str
->
c_ptr_quick
();
ptr
=
buf
;
*
ptr
++=
'\''
;
tmp
.
set
(
ptr
,
MAX_DATE_REP_LENGTH
,
&
my_charset_bin
);
tmp
.
length
(
0
);
TIME_to_string
(
&
value
.
time
,
&
tmp
);
ptr
+=
tmp
.
length
();
ptr
+=
(
uint
)
my_TIME_to_str
(
&
value
.
time
,
ptr
);
*
ptr
++=
'\''
;
str
->
length
((
uint32
)
(
ptr
-
buf
));
break
;
...
...
sql/item_timefunc.cc
View file @
df58c0bc
...
...
@@ -1292,14 +1292,13 @@ String *Item_func_curtime::val_str(String *str)
void
Item_func_curtime
::
fix_length_and_dec
()
{
TIME
ltime
;
String
tmp
((
char
*
)
buff
,
sizeof
(
buff
),
&
my_charset_bin
);
decimals
=
0
;
collation
.
set
(
&
my_charset_bin
);
store_now_in_TIME
(
&
ltime
);
value
=
TIME_to_ulonglong_time
(
&
ltime
);
make_time
((
DATE_TIME_FORMAT
*
)
0
,
&
ltime
,
&
tmp
);
max_length
=
buff_length
=
tmp
.
length
()
;
buff_length
=
(
uint
)
my_time_to_str
(
&
ltime
,
buff
);
max_length
=
buff_length
;
}
...
...
@@ -1341,16 +1340,14 @@ String *Item_func_now::val_str(String *str)
void
Item_func_now
::
fix_length_and_dec
()
{
String
tmp
((
char
*
)
buff
,
sizeof
(
buff
),
&
my_charset_bin
);
decimals
=
0
;
collation
.
set
(
&
my_charset_bin
);
store_now_in_TIME
(
&
ltime
);
value
=
(
longlong
)
TIME_to_ulonglong_datetime
(
&
ltime
);
make_datetime
((
DATE_TIME_FORMAT
*
)
0
,
&
ltime
,
&
tmp
);
max_length
=
buff_length
=
tmp
.
length
()
;
buff_length
=
(
uint
)
my_datetime_to_str
(
&
ltime
,
buff
);
max_length
=
buff_length
;
}
...
...
sql/mysql_priv.h
View file @
df58c0bc
...
...
@@ -284,14 +284,6 @@ void debug_sync_point(const char* lock_name, uint lock_timeout);
#define WEEK_MONDAY_FIRST 1
#define WEEK_YEAR 2
#define WEEK_FIRST_WEEKDAY 4
/*
Required buffer length for make_date, make_time, make_datetime
and TIME_to_string functions. Note, that the caller is still
responsible to check that given TIME structure has values
in valid ranges, otherwise size of the buffer could be not
enough.
*/
#define MAX_DATE_REP_LENGTH 30
enum
enum_parsing_place
{
...
...
@@ -1046,7 +1038,6 @@ void make_date(const DATE_TIME_FORMAT *format, const TIME *l_time,
String
*
str
);
void
make_time
(
const
DATE_TIME_FORMAT
*
format
,
const
TIME
*
l_time
,
String
*
str
);
void
TIME_to_string
(
const
TIME
*
time
,
String
*
str
);
ulonglong
TIME_to_ulonglong_datetime
(
const
TIME
*
time
);
ulonglong
TIME_to_ulonglong_date
(
const
TIME
*
time
);
ulonglong
TIME_to_ulonglong_time
(
const
TIME
*
time
);
...
...
sql/protocol.cc
View file @
df58c0bc
...
...
@@ -880,10 +880,9 @@ bool Protocol_simple::store_date(TIME *tm)
field_types
[
field_pos
]
==
MYSQL_TYPE_DATE
);
field_pos
++
;
#endif
char
buff
[
40
];
String
tmp
((
char
*
)
buff
,
sizeof
(
buff
),
&
my_charset_bin
);
make_date
((
DATE_TIME_FORMAT
*
)
0
,
tm
,
&
tmp
);
return
net_store_data
((
char
*
)
tmp
.
ptr
(),
tmp
.
length
());
char
buff
[
MAX_DATE_STRING_REP_LENGTH
];
int
length
=
my_date_to_str
(
tm
,
buff
);
return
net_store_data
(
buff
,
(
uint
)
length
);
}
...
...
sql/time.cc
View file @
df58c0bc
...
...
@@ -747,13 +747,7 @@ const char *get_date_time_format_str(KNOWN_DATE_TIME_FORMAT *format,
void
make_time
(
const
DATE_TIME_FORMAT
*
format
__attribute__
((
unused
)),
const
TIME
*
l_time
,
String
*
str
)
{
long
length
=
my_sprintf
((
char
*
)
str
->
ptr
(),
((
char
*
)
str
->
ptr
(),
"%s%02d:%02d:%02d"
,
(
l_time
->
neg
?
"-"
:
""
),
l_time
->
hour
,
l_time
->
minute
,
l_time
->
second
));
uint
length
=
(
uint
)
my_time_to_str
(
l_time
,
(
char
*
)
str
->
ptr
());
str
->
length
(
length
);
str
->
set_charset
(
&
my_charset_bin
);
}
...
...
@@ -762,12 +756,7 @@ void make_time(const DATE_TIME_FORMAT *format __attribute__((unused)),
void
make_date
(
const
DATE_TIME_FORMAT
*
format
__attribute__
((
unused
)),
const
TIME
*
l_time
,
String
*
str
)
{
long
length
=
my_sprintf
((
char
*
)
str
->
ptr
(),
((
char
*
)
str
->
ptr
(),
"%04d-%02d-%02d"
,
l_time
->
year
,
l_time
->
month
,
l_time
->
day
));
uint
length
=
(
uint
)
my_date_to_str
(
l_time
,
(
char
*
)
str
->
ptr
());
str
->
length
(
length
);
str
->
set_charset
(
&
my_charset_bin
);
}
...
...
@@ -776,15 +765,7 @@ void make_date(const DATE_TIME_FORMAT *format __attribute__((unused)),
void
make_datetime
(
const
DATE_TIME_FORMAT
*
format
__attribute__
((
unused
)),
const
TIME
*
l_time
,
String
*
str
)
{
long
length
=
my_sprintf
((
char
*
)
str
->
ptr
(),
((
char
*
)
str
->
ptr
(),
"%04d-%02d-%02d %02d:%02d:%02d"
,
l_time
->
year
,
l_time
->
month
,
l_time
->
day
,
l_time
->
hour
,
l_time
->
minute
,
l_time
->
second
));
uint
length
=
(
uint
)
my_datetime_to_str
(
l_time
,
(
char
*
)
str
->
ptr
());
str
->
length
(
length
);
str
->
set_charset
(
&
my_charset_bin
);
}
...
...
@@ -894,38 +875,4 @@ ulonglong TIME_to_ulonglong(const TIME *time)
return
0
;
}
/*
Convert struct DATE/TIME/DATETIME value to string using built-in
MySQL time conversion formats.
SYNOPSIS
TIME_to_string()
NOTE
The string must have at least MAX_DATE_REP_LENGTH bytes reserved.
*/
void
TIME_to_string
(
const
TIME
*
time
,
String
*
str
)
{
switch
(
time
->
time_type
)
{
case
MYSQL_TIMESTAMP_DATETIME
:
make_datetime
((
DATE_TIME_FORMAT
*
)
0
,
time
,
str
);
break
;
case
MYSQL_TIMESTAMP_DATE
:
make_date
((
DATE_TIME_FORMAT
*
)
0
,
time
,
str
);
break
;
case
MYSQL_TIMESTAMP_TIME
:
make_time
((
DATE_TIME_FORMAT
*
)
0
,
time
,
str
);
break
;
case
MYSQL_TIMESTAMP_NONE
:
case
MYSQL_TIMESTAMP_ERROR
:
str
->
length
(
0
);
str
->
set_charset
(
&
my_charset_bin
);
break
;
default:
DBUG_ASSERT
(
0
);
}
}
#endif
tests/client_test.c
View file @
df58c0bc
...
...
@@ -3431,7 +3431,7 @@ static void test_fetch_date()
MYSQL_STMT
*
stmt
;
uint
i
;
int
rc
,
year
;
char
date
[
25
],
time
[
25
],
ts
[
25
],
ts_4
[
1
5
],
ts_6
[
20
],
dt
[
20
];
char
date
[
25
],
time
[
25
],
ts
[
25
],
ts_4
[
2
5
],
ts_6
[
20
],
dt
[
20
];
ulong
d_length
,
t_length
,
ts_length
,
ts4_length
,
ts6_length
,
dt_length
,
y_length
;
MYSQL_BIND
bind
[
8
];
...
...
@@ -3541,8 +3541,8 @@ static void test_fetch_date()
DIE_UNLESS
(
strcmp
(
dt
,
"2010-07-10 00:00:00"
)
==
0
);
DIE_UNLESS
(
dt_length
==
19
);
DIE_UNLESS
(
ts_4
[
0
]
==
'\0'
);
DIE_UNLESS
(
ts4_length
==
0
);
DIE_UNLESS
(
strcmp
(
ts_4
,
"0000-00-00 00:00:00"
)
==
0
);
DIE_UNLESS
(
ts4_length
==
strlen
(
"0000-00-00 00:00:00"
)
);
DIE_UNLESS
(
strcmp
(
ts_6
,
"1999-12-29 00:00:00"
)
==
0
);
DIE_UNLESS
(
ts6_length
==
19
);
...
...
@@ -10533,6 +10533,99 @@ static void test_bug5315()
}
static
void
test_bug6049
()
{
MYSQL_STMT
*
stmt
;
MYSQL_BIND
bind
[
1
];
MYSQL_RES
*
res
;
MYSQL_ROW
row
;
const
char
*
stmt_text
;
char
buffer
[
30
];
ulong
length
;
int
rc
;
myheader
(
"test_bug6049"
);
stmt_text
=
"SELECT MAKETIME(-25, 12, 12)"
;
rc
=
mysql_real_query
(
mysql
,
stmt_text
,
strlen
(
stmt_text
));
myquery
(
rc
);
res
=
mysql_store_result
(
mysql
);
row
=
mysql_fetch_row
(
res
);
stmt
=
mysql_stmt_init
(
mysql
);
rc
=
mysql_stmt_prepare
(
stmt
,
stmt_text
,
strlen
(
stmt_text
));
check_execute
(
stmt
,
rc
);
rc
=
mysql_stmt_execute
(
stmt
);
check_execute
(
stmt
,
rc
);
bzero
(
bind
,
sizeof
(
bind
));
bind
[
0
].
buffer_type
=
MYSQL_TYPE_STRING
;
bind
[
0
].
buffer
=
&
buffer
;
bind
[
0
].
buffer_length
=
sizeof
(
buffer
);
bind
[
0
].
length
=
&
length
;
mysql_stmt_bind_result
(
stmt
,
bind
);
rc
=
mysql_stmt_fetch
(
stmt
);
DIE_UNLESS
(
rc
==
0
);
printf
(
"Result from query: %s
\n
"
,
row
[
0
]);
printf
(
"Result from prepared statement: %s
\n
"
,
(
char
*
)
buffer
);
DIE_UNLESS
(
strcmp
(
row
[
0
],
(
char
*
)
buffer
)
==
0
);
mysql_free_result
(
res
);
mysql_stmt_close
(
stmt
);
}
static
void
test_bug6058
()
{
MYSQL_STMT
*
stmt
;
MYSQL_BIND
bind
[
1
];
MYSQL_RES
*
res
;
MYSQL_ROW
row
;
const
char
*
stmt_text
;
char
buffer
[
30
];
ulong
length
;
int
rc
;
myheader
(
"test_bug6058"
);
stmt_text
=
"SELECT CAST('0000-00-00' AS DATE)"
;
rc
=
mysql_real_query
(
mysql
,
stmt_text
,
strlen
(
stmt_text
));
myquery
(
rc
);
res
=
mysql_store_result
(
mysql
);
row
=
mysql_fetch_row
(
res
);
stmt
=
mysql_stmt_init
(
mysql
);
rc
=
mysql_stmt_prepare
(
stmt
,
stmt_text
,
strlen
(
stmt_text
));
check_execute
(
stmt
,
rc
);
rc
=
mysql_stmt_execute
(
stmt
);
check_execute
(
stmt
,
rc
);
bzero
(
bind
,
sizeof
(
bind
));
bind
[
0
].
buffer_type
=
MYSQL_TYPE_STRING
;
bind
[
0
].
buffer
=
&
buffer
;
bind
[
0
].
buffer_length
=
sizeof
(
buffer
);
bind
[
0
].
length
=
&
length
;
mysql_stmt_bind_result
(
stmt
,
bind
);
rc
=
mysql_stmt_fetch
(
stmt
);
DIE_UNLESS
(
rc
==
0
);
printf
(
"Result from query: %s
\n
"
,
row
[
0
]);
printf
(
"Result from prepared statement: %s
\n
"
,
buffer
);
DIE_UNLESS
(
strcmp
(
row
[
0
],
buffer
)
==
0
);
mysql_free_result
(
res
);
mysql_stmt_close
(
stmt
);
}
/*
Read and parse arguments and MySQL options from my.cnf
*/
...
...
@@ -10843,6 +10936,8 @@ int main(int argc, char **argv)
test_bug5194
();
/* bulk inserts in prepared mode */
test_bug5315
();
/* check that mysql_change_user closes all
prepared statements */
test_bug6049
();
/* check support for negative TIME values */
test_bug6058
();
/* check support for 0000-00-00 dates */
/*
XXX: PLEASE RUN THIS PROGRAM UNDER VALGRIND AND VERIFY THAT YOUR TEST
DOESN'T CONTAIN WARNINGS/ERRORS BEFORE YOU PUSH.
...
...
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