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
c6beb583
Commit
c6beb583
authored
Jan 29, 2003
by
bell@sanja.is.com.ua
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
fixed functions to be able work with group function as argument
made bisone 1.75 compatible code
parent
710ffb2d
Changes
10
Hide whitespace changes
Inline
Side-by-side
Showing
10 changed files
with
416 additions
and
38 deletions
+416
-38
BitKeeper/etc/logging_ok
BitKeeper/etc/logging_ok
+1
-0
mysql-test/r/group_by.result
mysql-test/r/group_by.result
+18
-0
mysql-test/t/group_by.test
mysql-test/t/group_by.test
+23
-0
sql/item_cmpfunc.cc
sql/item_cmpfunc.cc
+42
-1
sql/item_cmpfunc.h
sql/item_cmpfunc.h
+2
-0
sql/item_func.cc
sql/item_func.cc
+11
-0
sql/item_func.h
sql/item_func.h
+1
-0
sql/item_strfunc.cc
sql/item_strfunc.cc
+39
-0
sql/item_strfunc.h
sql/item_strfunc.h
+4
-1
sql/sql_yacc.yy
sql/sql_yacc.yy
+275
-36
No files found.
BitKeeper/etc/logging_ok
View file @
c6beb583
...
@@ -3,6 +3,7 @@ Sinisa@sinisa.nasamreza.org
...
@@ -3,6 +3,7 @@ Sinisa@sinisa.nasamreza.org
arjen@fred.bitbike.com
arjen@fred.bitbike.com
bar@bar.mysql.r18.ru
bar@bar.mysql.r18.ru
bar@bar.udmsearch.izhnet.ru
bar@bar.udmsearch.izhnet.ru
bell@sanja.is.com.ua
bk@admin.bk
bk@admin.bk
heikki@donna.mysql.fi
heikki@donna.mysql.fi
heikki@hundin.mysql.fi
heikki@hundin.mysql.fi
...
...
mysql-test/r/group_by.result
View file @
c6beb583
...
@@ -110,3 +110,21 @@ a count(*)
...
@@ -110,3 +110,21 @@ a count(*)
NULL 9
NULL 9
3
3
b 1
b 1
a MAX(b) INTERVAL (MAX(b), 1,3,10,30,39,40,50,60,100,1000)
1 4 2
10 43 6
a MAX(b) CASE MAX(b) when 4 then 4 when 43 then 43 else 0 end
1 4 4
10 43 43
a MAX(b) FIELD(MAX(b), '43', '4', '5')
1 4 2
10 43 1
a MAX(b) CONCAT_WS(MAX(b), '43', '4', '5')
1 4 434445
10 43 43434435
a MAX(b) ELT(MAX(b), 'a', 'b', 'c', 'd', 'e', 'f')
1 4 d
10 43 NULL
a MAX(b) MAKE_SET(MAX(b), 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h')
1 4 c
10 43 a,b,d,f
mysql-test/t/group_by.test
View file @
c6beb583
...
@@ -323,3 +323,26 @@ select a,count(*) from t1 group by a;
...
@@ -323,3 +323,26 @@ select a,count(*) from t1 group by a;
set
option
sql_big_tables
=
1
;
set
option
sql_big_tables
=
1
;
select
a
,
count
(
*
)
from
t1
group
by
a
;
select
a
,
count
(
*
)
from
t1
group
by
a
;
drop
table
t1
;
drop
table
t1
;
#
# group function arguments in some functions
#
create
table
t1
(
a
int
,
b
int
);
insert
into
t1
values
(
1
,
4
);
insert
into
t1
values
(
10
,
40
);
insert
into
t1
values
(
1
,
4
);
insert
into
t1
values
(
10
,
43
);
insert
into
t1
values
(
1
,
4
);
insert
into
t1
values
(
10
,
41
);
insert
into
t1
values
(
1
,
4
);
insert
into
t1
values
(
10
,
43
);
insert
into
t1
values
(
1
,
4
);
select
a
,
MAX
(
b
),
INTERVAL
(
MAX
(
b
),
1
,
3
,
10
,
30
,
39
,
40
,
50
,
60
,
100
,
1000
)
from
t1
group
by
a
;
select
a
,
MAX
(
b
),
CASE
MAX
(
b
)
when
4
then
4
when
43
then
43
else
0
end
from
t1
group
by
a
;
select
a
,
MAX
(
b
),
FIELD
(
MAX
(
b
),
'43'
,
'4'
,
'5'
)
from
t1
group
by
a
;
select
a
,
MAX
(
b
),
CONCAT_WS
(
MAX
(
b
),
'43'
,
'4'
,
'5'
)
from
t1
group
by
a
;
select
a
,
MAX
(
b
),
ELT
(
MAX
(
b
),
'a'
,
'b'
,
'c'
,
'd'
,
'e'
,
'f'
)
from
t1
group
by
a
;
select
a
,
MAX
(
b
),
MAKE_SET
(
MAX
(
b
),
'a'
,
'b'
,
'c'
,
'd'
,
'e'
,
'f'
,
'g'
,
'h'
)
from
t1
group
by
a
;
drop
table
t1
;
sql/item_cmpfunc.cc
View file @
c6beb583
...
@@ -287,6 +287,19 @@ void Item_func_interval::fix_length_and_dec()
...
@@ -287,6 +287,19 @@ void Item_func_interval::fix_length_and_dec()
}
}
maybe_null
=
0
;
max_length
=
2
;
maybe_null
=
0
;
max_length
=
2
;
used_tables_cache
|=
item
->
used_tables
();
used_tables_cache
|=
item
->
used_tables
();
with_sum_func
=
with_sum_func
||
item
->
with_sum_func
;
}
void
Item_func_interval
::
split_sum_func
(
List
<
Item
>
&
fields
)
{
if
(
item
->
with_sum_func
&&
item
->
type
()
!=
SUM_FUNC_ITEM
)
item
->
split_sum_func
(
fields
);
else
if
(
item
->
used_tables
()
||
item
->
type
()
==
SUM_FUNC_ITEM
)
{
fields
.
push_front
(
item
);
item
=
new
Item_ref
((
Item
**
)
fields
.
head_ref
(),
0
,
item
->
name
);
}
Item_int_func
::
split_sum_func
(
fields
);
}
}
/*
/*
...
@@ -739,17 +752,45 @@ Item_func_case::fix_fields(THD *thd,TABLE_LIST *tables)
...
@@ -739,17 +752,45 @@ Item_func_case::fix_fields(THD *thd,TABLE_LIST *tables)
{
{
used_tables_cache
|=
(
first_expr
)
->
used_tables
();
used_tables_cache
|=
(
first_expr
)
->
used_tables
();
const_item_cache
&=
(
first_expr
)
->
const_item
();
const_item_cache
&=
(
first_expr
)
->
const_item
();
with_sum_func
=
with_sum_func
||
(
first_expr
)
->
with_sum_func
;
}
}
if
(
else_expr
)
if
(
else_expr
)
{
{
used_tables_cache
|=
(
else_expr
)
->
used_tables
();
used_tables_cache
|=
(
else_expr
)
->
used_tables
();
const_item_cache
&=
(
else_expr
)
->
const_item
();
const_item_cache
&=
(
else_expr
)
->
const_item
();
with_sum_func
=
with_sum_func
||
(
else_expr
)
->
with_sum_func
;
}
}
if
(
!
else_expr
||
else_expr
->
maybe_null
)
if
(
!
else_expr
||
else_expr
->
maybe_null
)
maybe_null
=
1
;
// The result may be NULL
maybe_null
=
1
;
// The result may be NULL
return
0
;
return
0
;
}
}
void
Item_func_case
::
split_sum_func
(
List
<
Item
>
&
fields
)
{
if
(
first_expr
)
{
if
(
first_expr
->
with_sum_func
&&
first_expr
->
type
()
!=
SUM_FUNC_ITEM
)
first_expr
->
split_sum_func
(
fields
);
else
if
(
first_expr
->
used_tables
()
||
first_expr
->
type
()
==
SUM_FUNC_ITEM
)
{
fields
.
push_front
(
first_expr
);
first_expr
=
new
Item_ref
((
Item
**
)
fields
.
head_ref
(),
0
,
first_expr
->
name
);
}
}
if
(
else_expr
)
{
if
(
else_expr
->
with_sum_func
&&
else_expr
->
type
()
!=
SUM_FUNC_ITEM
)
else_expr
->
split_sum_func
(
fields
);
else
if
(
else_expr
->
used_tables
()
||
else_expr
->
type
()
==
SUM_FUNC_ITEM
)
{
fields
.
push_front
(
else_expr
);
else_expr
=
new
Item_ref
((
Item
**
)
fields
.
head_ref
(),
0
,
else_expr
->
name
);
}
}
Item_func
::
split_sum_func
(
fields
);
}
void
Item_func_case
::
update_used_tables
()
void
Item_func_case
::
update_used_tables
()
{
{
Item_func
::
update_used_tables
();
Item_func
::
update_used_tables
();
...
@@ -1038,7 +1079,7 @@ void Item_func_in::split_sum_func(List<Item> &fields)
...
@@ -1038,7 +1079,7 @@ void Item_func_in::split_sum_func(List<Item> &fields)
else
if
(
item
->
used_tables
()
||
item
->
type
()
==
SUM_FUNC_ITEM
)
else
if
(
item
->
used_tables
()
||
item
->
type
()
==
SUM_FUNC_ITEM
)
{
{
fields
.
push_front
(
item
);
fields
.
push_front
(
item
);
item
=
new
Item_ref
((
Item
**
)
fields
.
head_ref
(),
0
,
item
->
name
);
item
=
new
Item_ref
((
Item
**
)
fields
.
head_ref
(),
0
,
item
->
name
);
}
}
Item_func
::
split_sum_func
(
fields
);
Item_func
::
split_sum_func
(
fields
);
}
}
...
...
sql/item_cmpfunc.h
View file @
c6beb583
...
@@ -180,6 +180,7 @@ class Item_func_interval :public Item_int_func
...
@@ -180,6 +180,7 @@ class Item_func_interval :public Item_int_func
{
{
return
(
item
->
fix_fields
(
thd
,
tlist
)
||
Item_func
::
fix_fields
(
thd
,
tlist
));
return
(
item
->
fix_fields
(
thd
,
tlist
)
||
Item_func
::
fix_fields
(
thd
,
tlist
));
}
}
void
split_sum_func
(
List
<
Item
>
&
fields
);
void
fix_length_and_dec
();
void
fix_length_and_dec
();
~
Item_func_interval
()
{
delete
item
;
}
~
Item_func_interval
()
{
delete
item
;
}
const
char
*
func_name
()
const
{
return
"interval"
;
}
const
char
*
func_name
()
const
{
return
"interval"
;
}
...
@@ -259,6 +260,7 @@ class Item_func_case :public Item_func
...
@@ -259,6 +260,7 @@ class Item_func_case :public Item_func
const
char
*
func_name
()
const
{
return
"case"
;
}
const
char
*
func_name
()
const
{
return
"case"
;
}
void
print
(
String
*
str
);
void
print
(
String
*
str
);
bool
fix_fields
(
THD
*
thd
,
struct
st_table_list
*
tlist
);
bool
fix_fields
(
THD
*
thd
,
struct
st_table_list
*
tlist
);
void
split_sum_func
(
List
<
Item
>
&
fields
);
Item
*
find_item
(
String
*
str
);
Item
*
find_item
(
String
*
str
);
};
};
...
...
sql/item_func.cc
View file @
c6beb583
...
@@ -864,6 +864,17 @@ longlong Item_func_field::val_int()
...
@@ -864,6 +864,17 @@ longlong Item_func_field::val_int()
return
0
;
return
0
;
}
}
void
Item_func_field
::
split_sum_func
(
List
<
Item
>
&
fields
)
{
if
(
item
->
with_sum_func
&&
item
->
type
()
!=
SUM_FUNC_ITEM
)
item
->
split_sum_func
(
fields
);
else
if
(
item
->
used_tables
()
||
item
->
type
()
==
SUM_FUNC_ITEM
)
{
fields
.
push_front
(
item
);
item
=
new
Item_ref
((
Item
**
)
fields
.
head_ref
(),
0
,
item
->
name
);
}
Item_func
::
split_sum_func
(
fields
);
}
longlong
Item_func_ascii
::
val_int
()
longlong
Item_func_ascii
::
val_int
()
{
{
...
...
sql/item_func.h
View file @
c6beb583
...
@@ -517,6 +517,7 @@ class Item_func_field :public Item_int_func
...
@@ -517,6 +517,7 @@ class Item_func_field :public Item_int_func
{
{
return
(
item
->
fix_fields
(
thd
,
tlist
)
||
Item_func
::
fix_fields
(
thd
,
tlist
));
return
(
item
->
fix_fields
(
thd
,
tlist
)
||
Item_func
::
fix_fields
(
thd
,
tlist
));
}
}
void
split_sum_func
(
List
<
Item
>
&
fields
);
void
update_used_tables
()
void
update_used_tables
()
{
{
item
->
update_used_tables
()
;
Item_func
::
update_used_tables
();
item
->
update_used_tables
()
;
Item_func
::
update_used_tables
();
...
...
sql/item_strfunc.cc
View file @
c6beb583
...
@@ -310,6 +310,17 @@ String *Item_func_concat_ws::val_str(String *str)
...
@@ -310,6 +310,17 @@ String *Item_func_concat_ws::val_str(String *str)
return
0
;
return
0
;
}
}
void
Item_func_concat_ws
::
split_sum_func
(
List
<
Item
>
&
fields
)
{
if
(
separator
->
with_sum_func
&&
separator
->
type
()
!=
SUM_FUNC_ITEM
)
separator
->
split_sum_func
(
fields
);
else
if
(
separator
->
used_tables
()
||
separator
->
type
()
==
SUM_FUNC_ITEM
)
{
fields
.
push_front
(
separator
);
separator
=
new
Item_ref
((
Item
**
)
fields
.
head_ref
(),
0
,
separator
->
name
);
}
Item_str_func
::
split_sum_func
(
fields
);
}
void
Item_func_concat_ws
::
fix_length_and_dec
()
void
Item_func_concat_ws
::
fix_length_and_dec
()
{
{
...
@@ -323,6 +334,7 @@ void Item_func_concat_ws::fix_length_and_dec()
...
@@ -323,6 +334,7 @@ void Item_func_concat_ws::fix_length_and_dec()
}
}
used_tables_cache
|=
separator
->
used_tables
();
used_tables_cache
|=
separator
->
used_tables
();
const_item_cache
&=
separator
->
const_item
();
const_item_cache
&=
separator
->
const_item
();
with_sum_func
=
with_sum_func
||
separator
->
with_sum_func
;
}
}
void
Item_func_concat_ws
::
update_used_tables
()
void
Item_func_concat_ws
::
update_used_tables
()
...
@@ -1221,6 +1233,19 @@ void Item_func_elt::fix_length_and_dec()
...
@@ -1221,6 +1233,19 @@ void Item_func_elt::fix_length_and_dec()
}
}
void
Item_func_elt
::
split_sum_func
(
List
<
Item
>
&
fields
)
{
if
(
item
->
with_sum_func
&&
item
->
type
()
!=
SUM_FUNC_ITEM
)
item
->
split_sum_func
(
fields
);
else
if
(
item
->
used_tables
()
||
item
->
type
()
==
SUM_FUNC_ITEM
)
{
fields
.
push_front
(
item
);
item
=
new
Item_ref
((
Item
**
)
fields
.
head_ref
(),
0
,
item
->
name
);
}
Item_str_func
::
split_sum_func
(
fields
);
}
void
Item_func_elt
::
update_used_tables
()
void
Item_func_elt
::
update_used_tables
()
{
{
Item_func
::
update_used_tables
();
Item_func
::
update_used_tables
();
...
@@ -1267,6 +1292,19 @@ String *Item_func_elt::val_str(String *str)
...
@@ -1267,6 +1292,19 @@ String *Item_func_elt::val_str(String *str)
}
}
void
Item_func_make_set
::
split_sum_func
(
List
<
Item
>
&
fields
)
{
if
(
item
->
with_sum_func
&&
item
->
type
()
!=
SUM_FUNC_ITEM
)
item
->
split_sum_func
(
fields
);
else
if
(
item
->
used_tables
()
||
item
->
type
()
==
SUM_FUNC_ITEM
)
{
fields
.
push_front
(
item
);
item
=
new
Item_ref
((
Item
**
)
fields
.
head_ref
(),
0
,
item
->
name
);
}
Item_str_func
::
split_sum_func
(
fields
);
}
void
Item_func_make_set
::
fix_length_and_dec
()
void
Item_func_make_set
::
fix_length_and_dec
()
{
{
max_length
=
arg_count
-
1
;
max_length
=
arg_count
-
1
;
...
@@ -1274,6 +1312,7 @@ void Item_func_make_set::fix_length_and_dec()
...
@@ -1274,6 +1312,7 @@ void Item_func_make_set::fix_length_and_dec()
max_length
+=
args
[
i
]
->
max_length
;
max_length
+=
args
[
i
]
->
max_length
;
used_tables_cache
|=
item
->
used_tables
();
used_tables_cache
|=
item
->
used_tables
();
const_item_cache
&=
item
->
const_item
();
const_item_cache
&=
item
->
const_item
();
with_sum_func
=
with_sum_func
||
item
->
with_sum_func
;
}
}
...
...
sql/item_strfunc.h
View file @
c6beb583
...
@@ -75,7 +75,8 @@ class Item_func_concat_ws :public Item_str_func
...
@@ -75,7 +75,8 @@ class Item_func_concat_ws :public Item_str_func
return
(
separator
->
fix_fields
(
thd
,
tlist
)
return
(
separator
->
fix_fields
(
thd
,
tlist
)
||
Item_func
::
fix_fields
(
thd
,
tlist
));
||
Item_func
::
fix_fields
(
thd
,
tlist
));
}
}
const
char
*
func_name
()
const
{
return
"concat_ws"
;
}
void
split_sum_func
(
List
<
Item
>
&
fields
);
const
char
*
func_name
()
const
{
return
"concat_ws"
;
}
};
};
class
Item_func_reverse
:
public
Item_str_func
class
Item_func_reverse
:
public
Item_str_func
...
@@ -296,6 +297,7 @@ class Item_func_elt :public Item_str_func
...
@@ -296,6 +297,7 @@ class Item_func_elt :public Item_str_func
{
{
return
(
item
->
fix_fields
(
thd
,
tlist
)
||
Item_func
::
fix_fields
(
thd
,
tlist
));
return
(
item
->
fix_fields
(
thd
,
tlist
)
||
Item_func
::
fix_fields
(
thd
,
tlist
));
}
}
void
split_sum_func
(
List
<
Item
>
&
fields
);
void
fix_length_and_dec
();
void
fix_length_and_dec
();
void
update_used_tables
();
void
update_used_tables
();
const
char
*
func_name
()
const
{
return
"elt"
;
}
const
char
*
func_name
()
const
{
return
"elt"
;
}
...
@@ -315,6 +317,7 @@ class Item_func_make_set :public Item_str_func
...
@@ -315,6 +317,7 @@ class Item_func_make_set :public Item_str_func
{
{
return
(
item
->
fix_fields
(
thd
,
tlist
)
||
Item_func
::
fix_fields
(
thd
,
tlist
));
return
(
item
->
fix_fields
(
thd
,
tlist
)
||
Item_func
::
fix_fields
(
thd
,
tlist
));
}
}
void
split_sum_func
(
List
<
Item
>
&
fields
);
void
fix_length_and_dec
();
void
fix_length_and_dec
();
void
update_used_tables
();
void
update_used_tables
();
const
char
*
func_name
()
const
{
return
"make_set"
;
}
const
char
*
func_name
()
const
{
return
"make_set"
;
}
...
...
sql/sql_yacc.yy
View file @
c6beb583
...
@@ -559,6 +559,7 @@ query:
...
@@ -559,6 +559,7 @@ query:
}
}
}
}
| verb_clause END_OF_INPUT {}
| verb_clause END_OF_INPUT {}
;
verb_clause:
verb_clause:
alter
alter
...
@@ -596,6 +597,7 @@ verb_clause:
...
@@ -596,6 +597,7 @@ verb_clause:
| unlock
| unlock
| update
| update
| use
| use
;
/* change master */
/* change master */
...
@@ -606,11 +608,14 @@ change:
...
@@ -606,11 +608,14 @@ change:
lex->sql_command = SQLCOM_CHANGE_MASTER;
lex->sql_command = SQLCOM_CHANGE_MASTER;
memset(&lex->mi, 0, sizeof(lex->mi));
memset(&lex->mi, 0, sizeof(lex->mi));
} master_defs
} master_defs
{}
;
master_defs:
master_defs:
master_def
master_def
|
|
master_defs ',' master_def
master_defs ',' master_def
;
master_def:
master_def:
MASTER_HOST_SYM EQ TEXT_STRING
MASTER_HOST_SYM EQ TEXT_STRING
...
@@ -647,7 +652,7 @@ master_def:
...
@@ -647,7 +652,7 @@ master_def:
{
{
Lex->mi.connect_retry = $3;
Lex->mi.connect_retry = $3;
}
}
;
/* create a table */
/* create a table */
...
@@ -670,7 +675,7 @@ create:
...
@@ -670,7 +675,7 @@ create:
lex->create_info.db_type= default_table_type;
lex->create_info.db_type= default_table_type;
}
}
create2
create2
{}
| CREATE opt_unique_or_fulltext INDEX ident ON table_ident
| CREATE opt_unique_or_fulltext INDEX ident ON table_ident
{
{
Lex->sql_command= SQLCOM_CREATE_INDEX;
Lex->sql_command= SQLCOM_CREATE_INDEX;
...
@@ -704,10 +709,12 @@ create:
...
@@ -704,10 +709,12 @@ create:
Lex->udf.returns=(Item_result) $7;
Lex->udf.returns=(Item_result) $7;
Lex->udf.dl=$9.str;
Lex->udf.dl=$9.str;
}
}
;
create2:
create2:
'(' field_list ')' opt_create_table_options create3 {}
'(' field_list ')' opt_create_table_options create3 {}
| opt_create_table_options create3 {}
| opt_create_table_options create3 {}
;
create3:
create3:
/* empty */ {}
/* empty */ {}
...
@@ -717,33 +724,41 @@ create3:
...
@@ -717,33 +724,41 @@ create3:
mysql_init_select(Lex);
mysql_init_select(Lex);
}
}
select_options select_item_list opt_select_from {}
select_options select_item_list opt_select_from {}
;
opt_as:
opt_as:
/* empty */ {}
/* empty */ {}
| AS {}
| AS {}
;
opt_table_options:
opt_table_options:
/* empty */ { $$= 0; }
/* empty */ { $$= 0; }
| table_options { $$= $1;}
| table_options { $$= $1;}
;
table_options:
table_options:
table_option { $$=$1; }
table_option { $$=$1; }
| table_option table_options { $$= $1 | $2; }
| table_option table_options { $$= $1 | $2; }
;
table_option:
table_option:
TEMPORARY { $$=HA_LEX_CREATE_TMP_TABLE; }
TEMPORARY { $$=HA_LEX_CREATE_TMP_TABLE; }
;
opt_if_not_exists:
opt_if_not_exists:
/* empty */ { $$= 0; }
/* empty */ { $$= 0; }
| IF NOT EXISTS { $$=HA_LEX_CREATE_IF_NOT_EXISTS; }
| IF NOT EXISTS { $$=HA_LEX_CREATE_IF_NOT_EXISTS; }
;
opt_create_table_options:
opt_create_table_options:
/* empty */
/* empty */
| create_table_options
| create_table_options
;
create_table_options:
create_table_options:
create_table_option
create_table_option
| create_table_option create_table_options
| create_table_option create_table_options
;
create_table_option:
create_table_option:
TYPE_SYM EQ table_types { Lex->create_info.db_type= $3; }
TYPE_SYM EQ table_types { Lex->create_info.db_type= $3; }
...
@@ -773,6 +788,7 @@ create_table_option:
...
@@ -773,6 +788,7 @@ create_table_option:
table_list->next=0;
table_list->next=0;
lex->create_info.used_fields|= HA_CREATE_USED_UNION;
lex->create_info.used_fields|= HA_CREATE_USED_UNION;
}
}
;
table_types:
table_types:
ISAM_SYM { $$= DB_TYPE_ISAM; }
ISAM_SYM { $$= DB_TYPE_ISAM; }
...
@@ -782,35 +798,41 @@ table_types:
...
@@ -782,35 +798,41 @@ table_types:
| BERKELEY_DB_SYM { $$= DB_TYPE_BERKELEY_DB; }
| BERKELEY_DB_SYM { $$= DB_TYPE_BERKELEY_DB; }
| INNOBASE_SYM { $$= DB_TYPE_INNOBASE; }
| INNOBASE_SYM { $$= DB_TYPE_INNOBASE; }
| GEMINI_SYM { $$= DB_TYPE_GEMINI; }
| GEMINI_SYM { $$= DB_TYPE_GEMINI; }
;
row_types:
row_types:
DEFAULT { $$= ROW_TYPE_DEFAULT; }
DEFAULT { $$= ROW_TYPE_DEFAULT; }
| FIXED_SYM { $$= ROW_TYPE_FIXED; }
| FIXED_SYM { $$= ROW_TYPE_FIXED; }
| DYNAMIC_SYM { $$= ROW_TYPE_DYNAMIC; }
| DYNAMIC_SYM { $$= ROW_TYPE_DYNAMIC; }
| COMPRESSED_SYM { $$= ROW_TYPE_COMPRESSED; }
| COMPRESSED_SYM { $$= ROW_TYPE_COMPRESSED; }
;
raid_types:
raid_types:
RAID_STRIPED_SYM { $$= RAID_TYPE_0; }
RAID_STRIPED_SYM { $$= RAID_TYPE_0; }
| RAID_0_SYM { $$= RAID_TYPE_0; }
| RAID_0_SYM { $$= RAID_TYPE_0; }
| ULONG_NUM { $$=$1;}
| ULONG_NUM { $$=$1;}
;
opt_select_from:
opt_select_from:
/* empty */
/* empty */
| select_from select_lock_type
| select_from select_lock_type
;
udf_func_type:
udf_func_type:
/* empty */ { $$ = UDFTYPE_FUNCTION; }
/* empty */ { $$ = UDFTYPE_FUNCTION; }
| AGGREGATE_SYM { $$ = UDFTYPE_AGGREGATE; }
| AGGREGATE_SYM { $$ = UDFTYPE_AGGREGATE; }
;
udf_type:
udf_type:
STRING_SYM {$$ = (int) STRING_RESULT; }
STRING_SYM {$$ = (int) STRING_RESULT; }
| REAL {$$ = (int) REAL_RESULT; }
| REAL {$$ = (int) REAL_RESULT; }
| INT_SYM {$$ = (int) INT_RESULT; }
| INT_SYM {$$ = (int) INT_RESULT; }
;
field_list:
field_list:
field_list_item
field_list_item
| field_list ',' field_list_item
| field_list ',' field_list_item
;
field_list_item:
field_list_item:
field_spec
field_spec
...
@@ -831,10 +853,12 @@ field_list_item:
...
@@ -831,10 +853,12 @@ field_list_item:
{
{
Lex->col_list.empty(); /* Alloced by sql_alloc */
Lex->col_list.empty(); /* Alloced by sql_alloc */
}
}
;
opt_constraint:
opt_constraint:
/* empty */
/* empty */
| CONSTRAINT opt_ident
| CONSTRAINT opt_ident
;
field_spec:
field_spec:
field_ident
field_ident
...
@@ -851,6 +875,7 @@ field_spec:
...
@@ -851,6 +875,7 @@ field_spec:
Lex->interval))
Lex->interval))
YYABORT;
YYABORT;
}
}
;
type:
type:
int_type opt_len field_options { Lex->length=$2; $$=$1; }
int_type opt_len field_options { Lex->length=$2; $$=$1; }
...
@@ -908,17 +933,20 @@ type:
...
@@ -908,17 +933,20 @@ type:
Lex->interval=typelib(Lex->interval_list);
Lex->interval=typelib(Lex->interval_list);
$$=FIELD_TYPE_SET;
$$=FIELD_TYPE_SET;
}
}
;
char:
char:
CHAR_SYM {}
CHAR_SYM {}
| NCHAR_SYM {}
| NCHAR_SYM {}
| NATIONAL_SYM CHAR_SYM {}
| NATIONAL_SYM CHAR_SYM {}
;
varchar:
varchar:
char VARYING {}
char VARYING {}
| VARCHAR {}
| VARCHAR {}
| NATIONAL_SYM VARCHAR {}
| NATIONAL_SYM VARCHAR {}
| NCHAR_SYM VARCHAR {}
| NCHAR_SYM VARCHAR {}
;
int_type:
int_type:
INT_SYM { $$=FIELD_TYPE_LONG; }
INT_SYM { $$=FIELD_TYPE_LONG; }
...
@@ -926,46 +954,55 @@ int_type:
...
@@ -926,46 +954,55 @@ int_type:
| SMALLINT { $$=FIELD_TYPE_SHORT; }
| SMALLINT { $$=FIELD_TYPE_SHORT; }
| MEDIUMINT { $$=FIELD_TYPE_INT24; }
| MEDIUMINT { $$=FIELD_TYPE_INT24; }
| BIGINT { $$=FIELD_TYPE_LONGLONG; }
| BIGINT { $$=FIELD_TYPE_LONGLONG; }
;
real_type:
real_type:
REAL { $$= current_thd->sql_mode & MODE_REAL_AS_FLOAT ?
REAL { $$= current_thd->sql_mode & MODE_REAL_AS_FLOAT ?
FIELD_TYPE_FLOAT : FIELD_TYPE_DOUBLE; }
FIELD_TYPE_FLOAT : FIELD_TYPE_DOUBLE; }
| DOUBLE_SYM { $$=FIELD_TYPE_DOUBLE; }
| DOUBLE_SYM { $$=FIELD_TYPE_DOUBLE; }
| DOUBLE_SYM PRECISION { $$=FIELD_TYPE_DOUBLE; }
| DOUBLE_SYM PRECISION { $$=FIELD_TYPE_DOUBLE; }
;
float_options:
float_options:
/* empty */ {}
/* empty */ {}
| '(' NUM ')' { Lex->length=$2.str; }
| '(' NUM ')' { Lex->length=$2.str; }
| '(' NUM ',' NUM ')' { Lex->length=$2.str; Lex->dec=$4.str; }
| '(' NUM ',' NUM ')' { Lex->length=$2.str; Lex->dec=$4.str; }
;
field_options:
field_options:
/* empty */ {}
/* empty */ {}
| field_opt_list {}
| field_opt_list {}
;
field_opt_list:
field_opt_list:
field_opt_list field_option {}
field_opt_list field_option {}
| field_option {}
| field_option {}
;
field_option:
field_option:
UNSIGNED { Lex->type|= UNSIGNED_FLAG;}
UNSIGNED { Lex->type|= UNSIGNED_FLAG;}
| ZEROFILL { Lex->type|= UNSIGNED_FLAG | ZEROFILL_FLAG; }
| ZEROFILL { Lex->type|= UNSIGNED_FLAG | ZEROFILL_FLAG; }
;
opt_len:
opt_len:
/* empty */ { $$=(char*) 0; } /* use default length */
/* empty */ { $$=(char*) 0; } /* use default length */
| '(' NUM ')' { $$=$2.str; }
| '(' NUM ')' { $$=$2.str; }
;
opt_precision:
opt_precision:
/* empty */ {}
/* empty */ {}
| '(' NUM ',' NUM ')' { Lex->length=$2.str; Lex->dec=$4.str; }
| '(' NUM ',' NUM ')' { Lex->length=$2.str; Lex->dec=$4.str; }
;
opt_attribute:
opt_attribute:
/* empty */ {}
/* empty */ {}
| opt_attribute_list {}
| opt_attribute_list {}
;
opt_attribute_list:
opt_attribute_list:
opt_attribute_list attribute {}
opt_attribute_list attribute {}
| attribute
| attribute
;
attribute:
attribute:
NULL_SYM { Lex->type&= ~ NOT_NULL_FLAG; }
NULL_SYM { Lex->type&= ~ NOT_NULL_FLAG; }
...
@@ -975,10 +1012,12 @@ attribute:
...
@@ -975,10 +1012,12 @@ attribute:
| PRIMARY_SYM KEY_SYM { Lex->type|= PRI_KEY_FLAG | NOT_NULL_FLAG; }
| PRIMARY_SYM KEY_SYM { Lex->type|= PRI_KEY_FLAG | NOT_NULL_FLAG; }
| UNIQUE_SYM { Lex->type|= UNIQUE_FLAG; }
| UNIQUE_SYM { Lex->type|= UNIQUE_FLAG; }
| UNIQUE_SYM KEY_SYM { Lex->type|= UNIQUE_KEY_FLAG; }
| UNIQUE_SYM KEY_SYM { Lex->type|= UNIQUE_KEY_FLAG; }
;
opt_binary:
opt_binary:
/* empty */ {}
/* empty */ {}
| BINARY { Lex->type|=BINARY_FLAG; }
| BINARY { Lex->type|=BINARY_FLAG; }
;
references:
references:
REFERENCES table_ident opt_on_delete {}
REFERENCES table_ident opt_on_delete {}
...
@@ -986,21 +1025,24 @@ references:
...
@@ -986,21 +1025,24 @@ references:
{
{
Lex->col_list.empty(); /* Alloced by sql_alloc */
Lex->col_list.empty(); /* Alloced by sql_alloc */
}
}
;
opt_on_delete:
opt_on_delete:
/* empty */ {}
/* empty */ {}
| opt_on_delete_list {}
| opt_on_delete_list {}
;
opt_on_delete_list:
opt_on_delete_list:
opt_on_delete_list opt_on_delete_item {}
opt_on_delete_list opt_on_delete_item {}
| opt_on_delete_item {}
| opt_on_delete_item {}
;
opt_on_delete_item:
opt_on_delete_item:
ON DELETE_SYM delete_option {}
ON DELETE_SYM delete_option {}
| ON UPDATE_SYM delete_option {}
| ON UPDATE_SYM delete_option {}
| MATCH FULL {}
| MATCH FULL {}
| MATCH PARTIAL {}
| MATCH PARTIAL {}
;
delete_option:
delete_option:
RESTRICT {}
RESTRICT {}
...
@@ -1008,6 +1050,7 @@ delete_option:
...
@@ -1008,6 +1050,7 @@ delete_option:
| SET NULL_SYM {}
| SET NULL_SYM {}
| NO_SYM ACTION {}
| NO_SYM ACTION {}
| SET DEFAULT {}
| SET DEFAULT {}
;
key_type:
key_type:
opt_constraint PRIMARY_SYM KEY_SYM { $$= Key::PRIMARY; }
opt_constraint PRIMARY_SYM KEY_SYM { $$= Key::PRIMARY; }
...
@@ -1016,35 +1059,43 @@ key_type:
...
@@ -1016,35 +1059,43 @@ key_type:
| FULLTEXT_SYM key_or_index { $$= Key::FULLTEXT; }
| FULLTEXT_SYM key_or_index { $$= Key::FULLTEXT; }
| opt_constraint UNIQUE_SYM { $$= Key::UNIQUE; }
| opt_constraint UNIQUE_SYM { $$= Key::UNIQUE; }
| opt_constraint UNIQUE_SYM key_or_index { $$= Key::UNIQUE; }
| opt_constraint UNIQUE_SYM key_or_index { $$= Key::UNIQUE; }
;
key_or_index:
key_or_index:
KEY_SYM {}
KEY_SYM {}
| INDEX {}
| INDEX {}
;
keys_or_index:
keys_or_index:
KEYS {}
KEYS {}
| INDEX {}
| INDEX {}
;
opt_unique_or_fulltext:
opt_unique_or_fulltext:
/* empty */ { $$= Key::MULTIPLE; }
/* empty */ { $$= Key::MULTIPLE; }
| UNIQUE_SYM { $$= Key::UNIQUE; }
| UNIQUE_SYM { $$= Key::UNIQUE; }
| FULLTEXT_SYM { $$= Key::FULLTEXT; }
| FULLTEXT_SYM { $$= Key::FULLTEXT; }
;
key_list:
key_list:
key_list ',' key_part order_dir { Lex->col_list.push_back($3); }
key_list ',' key_part order_dir { Lex->col_list.push_back($3); }
| key_part order_dir { Lex->col_list.push_back($1); }
| key_part order_dir { Lex->col_list.push_back($1); }
;
key_part:
key_part:
ident { $$=new key_part_spec($1.str); }
ident { $$=new key_part_spec($1.str); }
| ident '(' NUM ')' { $$=new key_part_spec($1.str,(uint) atoi($3.str)); }
| ident '(' NUM ')' { $$=new key_part_spec($1.str,(uint) atoi($3.str)); }
;
opt_ident:
opt_ident:
/* empty */ { $$=(char*) 0; } /* Defaultlength */
/* empty */ { $$=(char*) 0; } /* Defaultlength */
| field_ident { $$=$1.str; }
| field_ident { $$=$1.str; }
;
string_list:
string_list:
text_string { Lex->interval_list.push_back($1); }
text_string { Lex->interval_list.push_back($1); }
| string_list ',' text_string { Lex->interval_list.push_back($3); }
| string_list ',' text_string { Lex->interval_list.push_back($3); }
;
/*
/*
** Alter table
** Alter table
...
@@ -1072,13 +1123,17 @@ alter:
...
@@ -1072,13 +1123,17 @@ alter:
lex->create_info.db_type= DB_TYPE_DEFAULT;
lex->create_info.db_type= DB_TYPE_DEFAULT;
}
}
alter_list
alter_list
{}
;
alter_list:
alter_list:
| alter_list_item
| alter_list_item
| alter_list ',' alter_list_item
| alter_list ',' alter_list_item
;
add_column:
add_column:
ADD opt_column { Lex->change=0;}
ADD opt_column { Lex->change=0;}
;
alter_list_item:
alter_list_item:
add_column field_list_item opt_place
add_column field_list_item opt_place
...
@@ -1114,29 +1169,35 @@ alter_list_item:
...
@@ -1114,29 +1169,35 @@ alter_list_item:
{ Lex->db=$4->db.str ; Lex->name= $4->table.str; }
{ Lex->db=$4->db.str ; Lex->name= $4->table.str; }
| create_table_options
| create_table_options
| order_clause
| order_clause
;
opt_column:
opt_column:
/* empty */ {}
/* empty */ {}
| COLUMN_SYM {}
| COLUMN_SYM {}
;
opt_ignore:
opt_ignore:
/* empty */ { Lex->duplicates=DUP_ERROR; }
/* empty */ { Lex->duplicates=DUP_ERROR; }
| IGNORE_SYM { Lex->duplicates=DUP_IGNORE; }
| IGNORE_SYM { Lex->duplicates=DUP_IGNORE; }
;
opt_restrict:
opt_restrict:
/* empty */ {}
/* empty */ {}
| RESTRICT {}
| RESTRICT {}
| CASCADE {}
| CASCADE {}
;
opt_place:
opt_place:
/* empty */ {}
/* empty */ {}
| AFTER_SYM ident { store_position_for_column($2.str); }
| AFTER_SYM ident { store_position_for_column($2.str); }
| FIRST_SYM { store_position_for_column(first_keyword); }
| FIRST_SYM { store_position_for_column(first_keyword); }
;
opt_to:
opt_to:
/* empty */ {}
/* empty */ {}
| TO_SYM {}
| TO_SYM {}
| AS {}
| AS {}
;
slave:
slave:
SLAVE START_SYM
SLAVE START_SYM
...
@@ -1149,7 +1210,8 @@ slave:
...
@@ -1149,7 +1210,8 @@ slave:
{
{
Lex->sql_command = SQLCOM_SLAVE_STOP;
Lex->sql_command = SQLCOM_SLAVE_STOP;
Lex->type = 0;
Lex->type = 0;
};
}
;
restore:
restore:
RESTORE_SYM table_or_tables
RESTORE_SYM table_or_tables
...
@@ -1160,6 +1222,8 @@ restore:
...
@@ -1160,6 +1222,8 @@ restore:
{
{
Lex->backup_dir = $6.str;
Lex->backup_dir = $6.str;
}
}
;
backup:
backup:
BACKUP_SYM table_or_tables
BACKUP_SYM table_or_tables
{
{
...
@@ -1169,7 +1233,7 @@ backup:
...
@@ -1169,7 +1233,7 @@ backup:
{
{
Lex->backup_dir = $6.str;
Lex->backup_dir = $6.str;
}
}
;
repair:
repair:
REPAIR table_or_tables
REPAIR table_or_tables
...
@@ -1178,16 +1242,19 @@ repair:
...
@@ -1178,16 +1242,19 @@ repair:
Lex->check_opt.init();
Lex->check_opt.init();
}
}
table_list opt_mi_check_type
table_list opt_mi_check_type
{}
;
opt_mi_check_type:
opt_mi_check_type:
/* empty */ { Lex->check_opt.flags = T_MEDIUM; }
/* empty */ { Lex->check_opt.flags = T_MEDIUM; }
| TYPE_SYM EQ mi_check_types {}
| TYPE_SYM EQ mi_check_types {}
| mi_check_types {}
| mi_check_types {}
;
mi_check_types:
mi_check_types:
mi_check_type {}
mi_check_type {}
| mi_check_type mi_check_types {}
| mi_check_type mi_check_types {}
;
mi_check_type:
mi_check_type:
QUICK { Lex->check_opt.quick = 1; }
QUICK { Lex->check_opt.quick = 1; }
...
@@ -1195,6 +1262,7 @@ mi_check_type:
...
@@ -1195,6 +1262,7 @@ mi_check_type:
| MEDIUM_SYM { Lex->check_opt.flags|= T_MEDIUM; }
| MEDIUM_SYM { Lex->check_opt.flags|= T_MEDIUM; }
| EXTENDED_SYM { Lex->check_opt.flags|= T_EXTEND; }
| EXTENDED_SYM { Lex->check_opt.flags|= T_EXTEND; }
| CHANGED { Lex->check_opt.flags|= T_CHECK_ONLY_CHANGED; }
| CHANGED { Lex->check_opt.flags|= T_CHECK_ONLY_CHANGED; }
;
analyze:
analyze:
ANALYZE_SYM table_or_tables
ANALYZE_SYM table_or_tables
...
@@ -1203,6 +1271,8 @@ analyze:
...
@@ -1203,6 +1271,8 @@ analyze:
Lex->check_opt.init();
Lex->check_opt.init();
}
}
table_list opt_mi_check_type
table_list opt_mi_check_type
{}
;
check:
check:
CHECK_SYM table_or_tables
CHECK_SYM table_or_tables
...
@@ -1211,6 +1281,8 @@ check:
...
@@ -1211,6 +1281,8 @@ check:
Lex->check_opt.init();
Lex->check_opt.init();
}
}
table_list opt_mi_check_type
table_list opt_mi_check_type
{}
;
optimize:
optimize:
OPTIMIZE table_or_tables
OPTIMIZE table_or_tables
...
@@ -1219,6 +1291,8 @@ optimize:
...
@@ -1219,6 +1291,8 @@ optimize:
Lex->check_opt.init();
Lex->check_opt.init();
}
}
table_list opt_mi_check_type
table_list opt_mi_check_type
{}
;
rename:
rename:
RENAME table_or_tables
RENAME table_or_tables
...
@@ -1226,10 +1300,14 @@ rename:
...
@@ -1226,10 +1300,14 @@ rename:
Lex->sql_command=SQLCOM_RENAME_TABLE;
Lex->sql_command=SQLCOM_RENAME_TABLE;
}
}
table_to_table_list
table_to_table_list
{}
;
table_to_table_list:
table_to_table_list:
table_to_table
table_to_table
| table_to_table_list ',' table_to_table
| table_to_table_list ',' table_to_table
{}
;
table_to_table:
table_to_table:
table_ident TO_SYM table_ident
table_ident TO_SYM table_ident
...
@@ -1237,6 +1315,7 @@ table_to_table:
...
@@ -1237,6 +1315,7 @@ table_to_table:
!add_table_to_list($3,NULL,1,TL_IGNORE))
!add_table_to_list($3,NULL,1,TL_IGNORE))
YYABORT;
YYABORT;
}
}
;
/*
/*
Select : retrieve data from table
Select : retrieve data from table
...
@@ -1252,24 +1331,29 @@ select:
...
@@ -1252,24 +1331,29 @@ select:
mysql_init_select(lex);
mysql_init_select(lex);
}
}
select_options select_item_list select_into select_lock_type
select_options select_item_list select_into select_lock_type
{}
;
select_into:
select_into:
/* empty */
/* empty */
| select_from
| select_from
| opt_into select_from
| opt_into select_from
| select_from opt_into
| select_from opt_into
;
select_from:
select_from:
FROM join_table_list where_clause group_clause having_clause opt_order_clause limit_clause procedure_clause
FROM join_table_list where_clause group_clause having_clause opt_order_clause limit_clause procedure_clause
;
select_options:
select_options:
/* empty*/
/* empty*/
| select_option_list
| select_option_list
;
select_option_list:
select_option_list:
select_option_list select_option
select_option_list select_option
| select_option
| select_option
;
select_option:
select_option:
STRAIGHT_JOIN { Lex->options|= SELECT_STRAIGHT_JOIN; }
STRAIGHT_JOIN { Lex->options|= SELECT_STRAIGHT_JOIN; }
...
@@ -1279,6 +1363,7 @@ select_option:
...
@@ -1279,6 +1363,7 @@ select_option:
| SQL_BIG_RESULT { Lex->options|= SELECT_BIG_RESULT; }
| SQL_BIG_RESULT { Lex->options|= SELECT_BIG_RESULT; }
| SQL_BUFFER_RESULT { Lex->options|= OPTION_BUFFER_RESULT; }
| SQL_BUFFER_RESULT { Lex->options|= OPTION_BUFFER_RESULT; }
| ALL {}
| ALL {}
;
select_lock_type:
select_lock_type:
/* empty */
/* empty */
...
@@ -1286,6 +1371,7 @@ select_lock_type:
...
@@ -1286,6 +1371,7 @@ select_lock_type:
{ Lex->lock_option= TL_WRITE; }
{ Lex->lock_option= TL_WRITE; }
| LOCK_SYM IN_SYM SHARE_SYM MODE_SYM
| LOCK_SYM IN_SYM SHARE_SYM MODE_SYM
{ Lex->lock_option= TL_READ_WITH_SHARED_LOCKS; }
{ Lex->lock_option= TL_READ_WITH_SHARED_LOCKS; }
;
select_item_list:
select_item_list:
select_item_list ',' select_item
select_item_list ',' select_item
...
@@ -1295,7 +1381,7 @@ select_item_list:
...
@@ -1295,7 +1381,7 @@ select_item_list:
if (add_item_to_list(new Item_field(NULL,NULL,"*")))
if (add_item_to_list(new Item_field(NULL,NULL,"*")))
YYABORT;
YYABORT;
}
}
;
select_item:
select_item:
remember_name select_item2 remember_end select_alias
remember_name select_item2 remember_end select_alias
...
@@ -1307,16 +1393,20 @@ select_item:
...
@@ -1307,16 +1393,20 @@ select_item:
else if (!$2->name)
else if (!$2->name)
$2->set_name($1,(uint) ($3 - $1));
$2->set_name($1,(uint) ($3 - $1));
}
}
;
remember_name:
remember_name:
{ $$=(char*) Lex->tok_start; }
{ $$=(char*) Lex->tok_start; }
;
remember_end:
remember_end:
{ $$=(char*) Lex->tok_end; }
{ $$=(char*) Lex->tok_end; }
;
select_item2:
select_item2:
table_wild { $$=$1; } /* table.* */
table_wild { $$=$1; } /* table.* */
| expr { $$=$1; }
| expr { $$=$1; }
;
select_alias:
select_alias:
{ $$.str=0;}
{ $$.str=0;}
...
@@ -1324,14 +1414,17 @@ select_alias:
...
@@ -1324,14 +1414,17 @@ select_alias:
| AS TEXT_STRING { $$=$2; }
| AS TEXT_STRING { $$=$2; }
| ident { $$=$1; }
| ident { $$=$1; }
| TEXT_STRING { $$=$1; }
| TEXT_STRING { $$=$1; }
;
optional_braces:
optional_braces:
/* empty */ {}
/* empty */ {}
| '(' ')' {}
| '(' ')' {}
;
/* all possible expressions */
/* all possible expressions */
expr: expr_expr {$$ = $1; }
expr: expr_expr {$$ = $1; }
| simple_expr {$$ = $1; }
| simple_expr {$$ = $1; }
;
/* expressions that begin with 'expr' */
/* expressions that begin with 'expr' */
expr_expr:
expr_expr:
...
@@ -1372,6 +1465,7 @@ expr_expr:
...
@@ -1372,6 +1465,7 @@ expr_expr:
{ $$= new Item_date_add_interval($1,$4,$5,0); }
{ $$= new Item_date_add_interval($1,$4,$5,0); }
| expr '-' INTERVAL_SYM expr interval
| expr '-' INTERVAL_SYM expr interval
{ $$= new Item_date_add_interval($1,$4,$5,1); }
{ $$= new Item_date_add_interval($1,$4,$5,1); }
;
/* expressions that begin with 'expr' that do NOT follow IN_SYM */
/* expressions that begin with 'expr' that do NOT follow IN_SYM */
no_in_expr:
no_in_expr:
...
@@ -1409,6 +1503,7 @@ no_in_expr:
...
@@ -1409,6 +1503,7 @@ no_in_expr:
| no_in_expr '-' INTERVAL_SYM expr interval
| no_in_expr '-' INTERVAL_SYM expr interval
{ $$= new Item_date_add_interval($1,$4,$5,1); }
{ $$= new Item_date_add_interval($1,$4,$5,1); }
| simple_expr
| simple_expr
;
/* expressions that begin with 'expr' that does NOT follow AND */
/* expressions that begin with 'expr' that does NOT follow AND */
no_and_expr:
no_and_expr:
...
@@ -1449,6 +1544,7 @@ no_and_expr:
...
@@ -1449,6 +1544,7 @@ no_and_expr:
| no_and_expr '-' INTERVAL_SYM expr interval
| no_and_expr '-' INTERVAL_SYM expr interval
{ $$= new Item_date_add_interval($1,$4,$5,1); }
{ $$= new Item_date_add_interval($1,$4,$5,1); }
| simple_expr
| simple_expr
;
simple_expr:
simple_expr:
simple_ident
simple_ident
...
@@ -1668,10 +1764,12 @@ simple_expr:
...
@@ -1668,10 +1764,12 @@ simple_expr:
{ $$=new Item_func_benchmark($3,$5); }
{ $$=new Item_func_benchmark($3,$5); }
| EXTRACT_SYM '(' interval FROM expr ')'
| EXTRACT_SYM '(' interval FROM expr ')'
{ $$=new Item_extract( $3, $5); }
{ $$=new Item_extract( $3, $5); }
;
udf_expr_list:
udf_expr_list:
/* empty */ { $$= NULL; }
/* empty */ { $$= NULL; }
| expr_list { $$= $1;}
| expr_list { $$= $1;}
;
sum_expr:
sum_expr:
AVG_SYM '(' in_sum_expr ')'
AVG_SYM '(' in_sum_expr ')'
...
@@ -1696,6 +1794,7 @@ sum_expr:
...
@@ -1696,6 +1794,7 @@ sum_expr:
{ $$=new Item_sum_std($3); }
{ $$=new Item_sum_std($3); }
| SUM_SYM '(' in_sum_expr ')'
| SUM_SYM '(' in_sum_expr ')'
{ $$=new Item_sum_sum($3); }
{ $$=new Item_sum_sum($3); }
;
in_sum_expr:
in_sum_expr:
{ Lex->in_sum_expr++; }
{ Lex->in_sum_expr++; }
...
@@ -1704,37 +1803,45 @@ in_sum_expr:
...
@@ -1704,37 +1803,45 @@ in_sum_expr:
Lex->in_sum_expr--;
Lex->in_sum_expr--;
$$=$2;
$$=$2;
}
}
;
expr_list:
expr_list:
{ Lex->expr_list.push_front(new List<Item>); }
{ Lex->expr_list.push_front(new List<Item>); }
expr_list2
expr_list2
{ $$= Lex->expr_list.pop(); }
{ $$= Lex->expr_list.pop(); }
;
expr_list2:
expr_list2:
expr { Lex->expr_list.head()->push_back($1); }
expr { Lex->expr_list.head()->push_back($1); }
| expr_list2 ',' expr { Lex->expr_list.head()->push_back($3); }
| expr_list2 ',' expr { Lex->expr_list.head()->push_back($3); }
;
ident_list:
ident_list:
{ Lex->expr_list.push_front(new List<Item>); }
{ Lex->expr_list.push_front(new List<Item>); }
ident_list2
ident_list2
{ $$= Lex->expr_list.pop(); }
{ $$= Lex->expr_list.pop(); }
;
ident_list2:
ident_list2:
simple_ident { Lex->expr_list.head()->push_back($1); }
simple_ident { Lex->expr_list.head()->push_back($1); }
| ident_list2 ',' simple_ident { Lex->expr_list.head()->push_back($3); }
| ident_list2 ',' simple_ident { Lex->expr_list.head()->push_back($3); }
;
opt_expr:
opt_expr:
/* empty */ { $$= NULL; }
/* empty */ { $$= NULL; }
| expr { $$= $1; }
| expr { $$= $1; }
;
opt_else:
opt_else:
/* empty */ { $$= NULL; }
/* empty */ { $$= NULL; }
| ELSE expr { $$= $2; }
| ELSE expr { $$= $2; }
;
when_list:
when_list:
{ Lex->when_list.push_front(new List<Item>); }
{ Lex->when_list.push_front(new List<Item>); }
when_list2
when_list2
{ $$= Lex->when_list.pop(); }
{ $$= Lex->when_list.pop(); }
;
when_list2:
when_list2:
expr THEN_SYM expr
expr THEN_SYM expr
...
@@ -1747,10 +1854,12 @@ when_list2:
...
@@ -1747,10 +1854,12 @@ when_list2:
Lex->when_list.head()->push_back($3);
Lex->when_list.head()->push_back($3);
Lex->when_list.head()->push_back($5);
Lex->when_list.head()->push_back($5);
}
}
;
opt_pad:
opt_pad:
/* empty */ { $$=new Item_string(" ",1); }
/* empty */ { $$=new Item_string(" ",1); }
| expr { $$=$1; }
| expr { $$=$1; }
;
join_table_list:
join_table_list:
'(' join_table_list ')' { $$=$2; }
'(' join_table_list ')' { $$=$2; }
...
@@ -1784,11 +1893,13 @@ join_table_list:
...
@@ -1784,11 +1893,13 @@ join_table_list:
{ add_join_natural($6,$1); $1->outer_join|=JOIN_TYPE_RIGHT; $$=$1; }
{ add_join_natural($6,$1); $1->outer_join|=JOIN_TYPE_RIGHT; $$=$1; }
| join_table_list NATURAL JOIN_SYM join_table
| join_table_list NATURAL JOIN_SYM join_table
{ add_join_natural($1,$4); $$=$4; }
{ add_join_natural($1,$4); $$=$4; }
;
normal_join:
normal_join:
',' {}
',' {}
| JOIN_SYM {}
| JOIN_SYM {}
| CROSS JOIN_SYM {}
| CROSS JOIN_SYM {}
;
join_table:
join_table:
{ Lex->use_index_ptr=Lex->ignore_index_ptr=0; }
{ Lex->use_index_ptr=Lex->ignore_index_ptr=0; }
...
@@ -1797,10 +1908,12 @@ join_table:
...
@@ -1797,10 +1908,12 @@ join_table:
Lex->ignore_index_ptr))) YYABORT; }
Lex->ignore_index_ptr))) YYABORT; }
| '{' ident join_table LEFT OUTER JOIN_SYM join_table ON expr '}'
| '{' ident join_table LEFT OUTER JOIN_SYM join_table ON expr '}'
{ add_join_on($7,$9); $7->outer_join|=JOIN_TYPE_LEFT; $$=$7; }
{ add_join_on($7,$9); $7->outer_join|=JOIN_TYPE_LEFT; $$=$7; }
;
opt_outer:
opt_outer:
/* empty */ {}
/* empty */ {}
| OUTER {}
| OUTER {}
;
opt_key_definition:
opt_key_definition:
/* empty */ {}
/* empty */ {}
...
@@ -1808,10 +1921,12 @@ opt_key_definition:
...
@@ -1808,10 +1921,12 @@ opt_key_definition:
{ Lex->use_index= *$2; Lex->use_index_ptr= &Lex->use_index; }
{ Lex->use_index= *$2; Lex->use_index_ptr= &Lex->use_index; }
| IGNORE_SYM key_usage_list
| IGNORE_SYM key_usage_list
{ Lex->ignore_index= *$2; Lex->ignore_index_ptr= &Lex->ignore_index;}
{ Lex->ignore_index= *$2; Lex->ignore_index_ptr= &Lex->ignore_index;}
;
key_usage_list:
key_usage_list:
key_or_index { Lex->interval_list.empty(); } '(' key_usage_list2 ')'
key_or_index { Lex->interval_list.empty(); } '(' key_usage_list2 ')'
{ $$= &Lex->interval_list; }
{ $$= &Lex->interval_list; }
;
key_usage_list2:
key_usage_list2:
key_usage_list2 ',' ident
key_usage_list2 ',' ident
...
@@ -1820,6 +1935,7 @@ key_usage_list2:
...
@@ -1820,6 +1935,7 @@ key_usage_list2:
{ Lex->interval_list.push_back(new String((const char*) $1.str,$1.length)); }
{ Lex->interval_list.push_back(new String((const char*) $1.str,$1.length)); }
| PRIMARY_SYM
| PRIMARY_SYM
{ Lex->interval_list.push_back(new String("PRIMARY",7)); }
{ Lex->interval_list.push_back(new String("PRIMARY",7)); }
;
using_list:
using_list:
ident
ident
...
@@ -1831,6 +1947,7 @@ using_list:
...
@@ -1831,6 +1947,7 @@ using_list:
if (!($$= new Item_cond_and(new Item_func_eq(new Item_field(Lex->db1,Lex->table1,$3.str), new Item_field(Lex->db2,Lex->table2,$3.str)), $1)))
if (!($$= new Item_cond_and(new Item_func_eq(new Item_field(Lex->db1,Lex->table1,$3.str), new Item_field(Lex->db2,Lex->table2,$3.str)), $1)))
YYABORT;
YYABORT;
}
}
;
interval:
interval:
DAY_HOUR_SYM { $$=INTERVAL_DAY_HOUR; }
DAY_HOUR_SYM { $$=INTERVAL_DAY_HOUR; }
...
@@ -1846,31 +1963,35 @@ interval:
...
@@ -1846,31 +1963,35 @@ interval:
| SECOND_SYM { $$=INTERVAL_SECOND; }
| SECOND_SYM { $$=INTERVAL_SECOND; }
| YEAR_MONTH_SYM { $$=INTERVAL_YEAR_MONTH; }
| YEAR_MONTH_SYM { $$=INTERVAL_YEAR_MONTH; }
| YEAR_SYM { $$=INTERVAL_YEAR; }
| YEAR_SYM { $$=INTERVAL_YEAR; }
;
table_alias:
table_alias:
/* empty */
/* empty */
| AS
| AS
| EQ
| EQ
;
opt_table_alias:
opt_table_alias:
/* empty */ { $$=0; }
/* empty */ { $$=0; }
| table_alias ident
| table_alias ident
{ $$= (LEX_STRING*) sql_memdup(&$2,sizeof(LEX_STRING)); }
{ $$= (LEX_STRING*) sql_memdup(&$2,sizeof(LEX_STRING)); }
;
where_clause:
where_clause:
/* empty */ { Lex->where= 0; }
/* empty */ { Lex->where= 0; }
| WHERE expr { Lex->where= $2; }
| WHERE expr { Lex->where= $2; }
;
having_clause:
having_clause:
/* empty */
/* empty */
| HAVING { Lex->create_refs=1; } expr
| HAVING { Lex->create_refs=1; } expr
{ Lex->having= $3; Lex->create_refs=0; }
{ Lex->having= $3; Lex->create_refs=0; }
;
opt_escape:
opt_escape:
ESCAPE_SYM TEXT_STRING { $$= $2.str; }
ESCAPE_SYM TEXT_STRING { $$= $2.str; }
| /* empty */ { $$= (char*) "\\"; }
| /* empty */ { $$= (char*) "\\"; }
;
/*
/*
group by statement in select
group by statement in select
...
@@ -1879,12 +2000,14 @@ opt_escape:
...
@@ -1879,12 +2000,14 @@ opt_escape:
group_clause:
group_clause:
/* empty */
/* empty */
| GROUP BY group_list
| GROUP BY group_list
;
group_list:
group_list:
group_list ',' order_ident order_dir
group_list ',' order_ident order_dir
{ if (add_group_to_list($3,(bool) $4)) YYABORT; }
{ if (add_group_to_list($3,(bool) $4)) YYABORT; }
| order_ident order_dir
| order_ident order_dir
{ if (add_group_to_list($1,(bool) $2)) YYABORT; }
{ if (add_group_to_list($1,(bool) $2)) YYABORT; }
;
/*
/*
Order by statement in select
Order by statement in select
...
@@ -1893,21 +2016,24 @@ group_list:
...
@@ -1893,21 +2016,24 @@ group_list:
opt_order_clause:
opt_order_clause:
/* empty */
/* empty */
| order_clause
| order_clause
;
order_clause:
order_clause:
ORDER_SYM BY order_list
ORDER_SYM BY order_list
;
order_list:
order_list:
order_list ',' order_ident order_dir
order_list ',' order_ident order_dir
{ if (add_order_to_list($3,(bool) $4)) YYABORT; }
{ if (add_order_to_list($3,(bool) $4)) YYABORT; }
| order_ident order_dir
| order_ident order_dir
{ if (add_order_to_list($1,(bool) $2)) YYABORT; }
{ if (add_order_to_list($1,(bool) $2)) YYABORT; }
;
order_dir:
order_dir:
/* empty */ { $$ = 1; }
/* empty */ { $$ = 1; }
| ASC { $$ =1; }
| ASC { $$ =1; }
| DESC { $$ =0; }
| DESC { $$ =0; }
;
limit_clause:
limit_clause:
/* empty */
/* empty */
...
@@ -1919,6 +2045,7 @@ limit_clause:
...
@@ -1919,6 +2045,7 @@ limit_clause:
{ Lex->select_limit= $2; Lex->offset_limit=0L; }
{ Lex->select_limit= $2; Lex->offset_limit=0L; }
| LIMIT ULONG_NUM ',' ULONG_NUM
| LIMIT ULONG_NUM ',' ULONG_NUM
{ Lex->select_limit= $4; Lex->offset_limit=$2; }
{ Lex->select_limit= $4; Lex->offset_limit=$2; }
;
delete_limit_clause:
delete_limit_clause:
/* empty */
/* empty */
...
@@ -1927,17 +2054,20 @@ delete_limit_clause:
...
@@ -1927,17 +2054,20 @@ delete_limit_clause:
}
}
| LIMIT ULONGLONG_NUM
| LIMIT ULONGLONG_NUM
{ Lex->select_limit= (ha_rows) $2; }
{ Lex->select_limit= (ha_rows) $2; }
;
ULONG_NUM:
ULONG_NUM:
NUM { $$= strtoul($1.str,NULL,10); }
NUM { $$= strtoul($1.str,NULL,10); }
| REAL_NUM { $$= strtoul($1.str,NULL,10); }
| REAL_NUM { $$= strtoul($1.str,NULL,10); }
| FLOAT_NUM { $$= strtoul($1.str,NULL,10); }
| FLOAT_NUM { $$= strtoul($1.str,NULL,10); }
;
ULONGLONG_NUM:
ULONGLONG_NUM:
NUM { $$= (ulonglong) strtoul($1.str,NULL,10); }
NUM { $$= (ulonglong) strtoul($1.str,NULL,10); }
| LONG_NUM { $$= strtoull($1.str,NULL,10); }
| LONG_NUM { $$= strtoull($1.str,NULL,10); }
| REAL_NUM { $$= strtoull($1.str,NULL,10); }
| REAL_NUM { $$= strtoull($1.str,NULL,10); }
| FLOAT_NUM { $$= strtoull($1.str,NULL,10); }
| FLOAT_NUM { $$= strtoull($1.str,NULL,10); }
;
procedure_clause:
procedure_clause:
/* empty */
/* empty */
...
@@ -1951,15 +2081,17 @@ procedure_clause:
...
@@ -1951,15 +2081,17 @@ procedure_clause:
YYABORT;
YYABORT;
}
}
'(' procedure_list ')'
'(' procedure_list ')'
;
procedure_list:
procedure_list:
/* empty */ {}
/* empty */ {}
| procedure_list2 {}
| procedure_list2 {}
;
procedure_list2:
procedure_list2:
procedure_list2 ',' procedure_item
procedure_list2 ',' procedure_item
| procedure_item
| procedure_item
;
procedure_item:
procedure_item:
remember_name expr
remember_name expr
...
@@ -1969,6 +2101,7 @@ procedure_item:
...
@@ -1969,6 +2101,7 @@ procedure_item:
if (!$2->name)
if (!$2->name)
$2->set_name($1,(uint) ((char*) Lex->tok_end - $1));
$2->set_name($1,(uint) ((char*) Lex->tok_end - $1));
}
}
;
opt_into:
opt_into:
INTO OUTFILE TEXT_STRING
INTO OUTFILE TEXT_STRING
...
@@ -1982,6 +2115,7 @@ opt_into:
...
@@ -1982,6 +2115,7 @@ opt_into:
if (!(Lex->exchange= new sql_exchange($3.str,1)))
if (!(Lex->exchange= new sql_exchange($3.str,1)))
YYABORT;
YYABORT;
}
}
;
/*
/*
DO statement
DO statement
...
@@ -1995,6 +2129,9 @@ do: DO_SYM
...
@@ -1995,6 +2129,9 @@ do: DO_SYM
YYABORT;
YYABORT;
}
}
values
values
{}
;
/*
/*
Drop : delete tables or index
Drop : delete tables or index
*/
*/
...
@@ -2025,19 +2162,22 @@ drop:
...
@@ -2025,19 +2162,22 @@ drop:
Lex->sql_command = SQLCOM_DROP_FUNCTION;
Lex->sql_command = SQLCOM_DROP_FUNCTION;
Lex->udf.name=$3.str;
Lex->udf.name=$3.str;
}
}
;
table_list:
table_list:
table
table
| table_list ',' table
| table_list ',' table
;
table:
table:
table_ident
table_ident
{ if (!add_table_to_list($1,NULL,1)) YYABORT; }
{ if (!add_table_to_list($1,NULL,1)) YYABORT; }
;
if_exists:
if_exists:
/* empty */ { $$=0; }
/* empty */ { $$=0; }
| IF EXISTS { $$= 1; }
| IF EXISTS { $$= 1; }
;
/*
/*
** Insert : add new data to table
** Insert : add new data to table
...
@@ -2045,23 +2185,30 @@ if_exists:
...
@@ -2045,23 +2185,30 @@ if_exists:
insert:
insert:
INSERT { Lex->sql_command = SQLCOM_INSERT; } insert_lock_option opt_ignore insert2 insert_field_spec
INSERT { Lex->sql_command = SQLCOM_INSERT; } insert_lock_option opt_ignore insert2 insert_field_spec
{}
;
replace:
replace:
REPLACE { Lex->sql_command = SQLCOM_REPLACE; } replace_lock_option insert2 insert_field_spec
REPLACE { Lex->sql_command = SQLCOM_REPLACE; } replace_lock_option insert2 insert_field_spec
{}
;
insert_lock_option:
insert_lock_option:
/* empty */ { Lex->lock_option= TL_WRITE_CONCURRENT_INSERT; }
/* empty */ { Lex->lock_option= TL_WRITE_CONCURRENT_INSERT; }
| LOW_PRIORITY { Lex->lock_option= TL_WRITE_LOW_PRIORITY; }
| LOW_PRIORITY { Lex->lock_option= TL_WRITE_LOW_PRIORITY; }
| DELAYED_SYM { Lex->lock_option= TL_WRITE_DELAYED; }
| DELAYED_SYM { Lex->lock_option= TL_WRITE_DELAYED; }
| HIGH_PRIORITY { Lex->lock_option= TL_WRITE; }
| HIGH_PRIORITY { Lex->lock_option= TL_WRITE; }
;
replace_lock_option:
replace_lock_option:
opt_low_priority {}
opt_low_priority {}
| DELAYED_SYM { Lex->lock_option= TL_WRITE_DELAYED; }
| DELAYED_SYM { Lex->lock_option= TL_WRITE_DELAYED; }
;
insert2:
insert2:
INTO insert_table {}
INTO insert_table {}
| insert_table {}
| insert_table {}
;
insert_table:
insert_table:
table
table
...
@@ -2070,6 +2217,7 @@ insert_table:
...
@@ -2070,6 +2217,7 @@ insert_table:
Lex->many_values.empty();
Lex->many_values.empty();
Lex->insert_list=0;
Lex->insert_list=0;
}
}
;
insert_field_spec:
insert_field_spec:
opt_field_spec insert_values {}
opt_field_spec insert_values {}
...
@@ -2080,15 +2228,18 @@ insert_field_spec:
...
@@ -2080,15 +2228,18 @@ insert_field_spec:
YYABORT;
YYABORT;
}
}
ident_eq_list
ident_eq_list
;
opt_field_spec:
opt_field_spec:
/* empty */ { }
/* empty */ { }
| '(' fields ')' { }
| '(' fields ')' { }
| '(' ')' { }
| '(' ')' { }
;
fields:
fields:
fields ',' insert_ident { Lex->field_list.push_back($3); }
fields ',' insert_ident { Lex->field_list.push_back($3); }
| insert_ident { Lex->field_list.push_back($1); }
| insert_ident { Lex->field_list.push_back($1); }
;
insert_values:
insert_values:
VALUES values_list {}
VALUES values_list {}
...
@@ -2101,15 +2252,18 @@ insert_values:
...
@@ -2101,15 +2252,18 @@ insert_values:
mysql_init_select(lex);
mysql_init_select(lex);
}
}
select_options select_item_list select_from select_lock_type {}
select_options select_item_list select_from select_lock_type {}
;
values_list:
values_list:
values_list ',' no_braces
values_list ',' no_braces
| no_braces
| no_braces
;
ident_eq_list:
ident_eq_list:
ident_eq_list ',' ident_eq_value
ident_eq_list ',' ident_eq_value
|
|
ident_eq_value
ident_eq_value
;
ident_eq_value:
ident_eq_value:
simple_ident equal expr
simple_ident equal expr
...
@@ -2118,9 +2272,11 @@ ident_eq_value:
...
@@ -2118,9 +2272,11 @@ ident_eq_value:
Lex->insert_list->push_back($3))
Lex->insert_list->push_back($3))
YYABORT;
YYABORT;
}
}
;
equal: EQ {}
equal: EQ {}
| SET_VAR {}
| SET_VAR {}
;
no_braces:
no_braces:
'('
'('
...
@@ -2133,10 +2289,12 @@ no_braces:
...
@@ -2133,10 +2289,12 @@ no_braces:
if (Lex->many_values.push_back(Lex->insert_list))
if (Lex->many_values.push_back(Lex->insert_list))
YYABORT;
YYABORT;
}
}
;
opt_values:
opt_values:
/* empty */ {}
/* empty */ {}
| values
| values
;
values:
values:
values ',' expr
values ',' expr
...
@@ -2149,12 +2307,14 @@ values:
...
@@ -2149,12 +2307,14 @@ values:
if (Lex->insert_list->push_back($1))
if (Lex->insert_list->push_back($1))
YYABORT;
YYABORT;
}
}
;
/* Update rows in a table */
/* Update rows in a table */
update:
update:
UPDATE_SYM opt_low_priority opt_ignore table SET update_list where_clause delete_limit_clause
UPDATE_SYM opt_low_priority opt_ignore table SET update_list where_clause delete_limit_clause
{ Lex->sql_command = SQLCOM_UPDATE; }
{ Lex->sql_command = SQLCOM_UPDATE; }
;
update_list:
update_list:
update_list ',' simple_ident equal expr
update_list ',' simple_ident equal expr
...
@@ -2167,10 +2327,12 @@ update_list:
...
@@ -2167,10 +2327,12 @@ update_list:
if (add_item_to_list($1) || add_value_to_list($3))
if (add_item_to_list($1) || add_value_to_list($3))
YYABORT;
YYABORT;
}
}
;
opt_low_priority:
opt_low_priority:
/* empty */ { Lex->lock_option= current_thd->update_lock_default; }
/* empty */ { Lex->lock_option= current_thd->update_lock_default; }
| LOW_PRIORITY { Lex->lock_option= TL_WRITE_LOW_PRIORITY; }
| LOW_PRIORITY { Lex->lock_option= TL_WRITE_LOW_PRIORITY; }
;
/* Delete rows from a table */
/* Delete rows from a table */
...
@@ -2182,28 +2344,35 @@ delete:
...
@@ -2182,28 +2344,35 @@ delete:
}
}
opt_delete_options FROM table
opt_delete_options FROM table
where_clause delete_limit_clause
where_clause delete_limit_clause
{}
;
opt_delete_options:
opt_delete_options:
/* empty */ {}
/* empty */ {}
| opt_delete_option opt_delete_options {}
| opt_delete_option opt_delete_options {}
;
opt_delete_option:
opt_delete_option:
QUICK { Lex->options|= OPTION_QUICK; }
QUICK { Lex->options|= OPTION_QUICK; }
| LOW_PRIORITY { Lex->lock_option= TL_WRITE_LOW_PRIORITY; }
| LOW_PRIORITY { Lex->lock_option= TL_WRITE_LOW_PRIORITY; }
;
truncate:
truncate:
TRUNCATE_SYM opt_table_sym table
TRUNCATE_SYM opt_table_sym table
{ Lex->sql_command= SQLCOM_TRUNCATE; Lex->options=0;
{ Lex->sql_command= SQLCOM_TRUNCATE; Lex->options=0;
Lex->lock_option= current_thd->update_lock_default; }
Lex->lock_option= current_thd->update_lock_default; }
;
opt_table_sym:
opt_table_sym:
/* empty */
/* empty */
| TABLE_SYM
| TABLE_SYM
;
/* Show things */
/* Show things */
show: SHOW { Lex->wild=0;} show_param
show: SHOW { Lex->wild=0;} show_param
{}
;
show_param:
show_param:
DATABASES wild
DATABASES wild
...
@@ -2267,18 +2436,22 @@ show_param:
...
@@ -2267,18 +2436,22 @@ show_param:
{
{
Lex->sql_command = SQLCOM_SHOW_SLAVE_STAT;
Lex->sql_command = SQLCOM_SHOW_SLAVE_STAT;
}
}
;
opt_db:
opt_db:
/* empty */ { $$= 0; }
/* empty */ { $$= 0; }
| FROM ident { $$= $2.str; }
| FROM ident { $$= $2.str; }
;
wild:
wild:
/* empty */
/* empty */
| LIKE text_string { Lex->wild= $2; }
| LIKE text_string { Lex->wild= $2; }
;
opt_full:
opt_full:
/* empty */ { Lex->verbose=0; }
/* empty */ { Lex->verbose=0; }
| FULL { Lex->verbose=1; }
| FULL { Lex->verbose=1; }
;
/* A Oracle compatible synonym for show */
/* A Oracle compatible synonym for show */
describe:
describe:
...
@@ -2290,31 +2463,35 @@ describe:
...
@@ -2290,31 +2463,35 @@ describe:
if (!add_table_to_list($2, NULL,0))
if (!add_table_to_list($2, NULL,0))
YYABORT;
YYABORT;
}
}
opt_describe_column
opt_describe_column
{}
| describe_command select { Lex->options|= SELECT_DESCRIBE; }
;
| describe_command select { Lex->options|= SELECT_DESCRIBE; }
;
describe_command:
describe_command:
DESC
DESC
| DESCRIBE
| DESCRIBE
;
opt_describe_column:
opt_describe_column:
/* empty */ {}
/* empty */ {}
| text_string { Lex->wild= $1; }
| text_string { Lex->wild= $1; }
| ident { Lex->wild= new String((const char*) $1.str,$1.length); }
| ident { Lex->wild= new String((const char*) $1.str,$1.length); }
;
/* flush things */
/* flush things */
flush:
flush:
FLUSH_SYM {Lex->sql_command= SQLCOM_FLUSH; Lex->type=0; } flush_options
FLUSH_SYM {Lex->sql_command= SQLCOM_FLUSH; Lex->type=0; } flush_options
{}
;
flush_options:
flush_options:
flush_options ',' flush_option
flush_options ',' flush_option
| flush_option
| flush_option
;
flush_option:
flush_option:
table_or_tables { Lex->type|= REFRESH_TABLES; } opt_table_list
table_or_tables { Lex->type|= REFRESH_TABLES; } opt_table_list
{}
| TABLES WITH READ_SYM LOCK_SYM { Lex->type|= REFRESH_TABLES | REFRESH_READ_LOCK; }
| TABLES WITH READ_SYM LOCK_SYM { Lex->type|= REFRESH_TABLES | REFRESH_READ_LOCK; }
| HOSTS_SYM { Lex->type|= REFRESH_HOSTS; }
| HOSTS_SYM { Lex->type|= REFRESH_HOSTS; }
| PRIVILEGES { Lex->type|= REFRESH_GRANT; }
| PRIVILEGES { Lex->type|= REFRESH_GRANT; }
...
@@ -2322,21 +2499,27 @@ flush_option:
...
@@ -2322,21 +2499,27 @@ flush_option:
| STATUS_SYM { Lex->type|= REFRESH_STATUS; }
| STATUS_SYM { Lex->type|= REFRESH_STATUS; }
| SLAVE { Lex->type|= REFRESH_SLAVE; }
| SLAVE { Lex->type|= REFRESH_SLAVE; }
| MASTER_SYM { Lex->type|= REFRESH_MASTER; }
| MASTER_SYM { Lex->type|= REFRESH_MASTER; }
;
opt_table_list:
opt_table_list:
/* empty */ {}
/* empty */ {}
| table_list {}
| table_list {}
;
reset:
reset:
RESET_SYM {Lex->sql_command= SQLCOM_RESET; Lex->type=0; } reset_options
RESET_SYM {Lex->sql_command= SQLCOM_RESET; Lex->type=0; } reset_options
{}
;
reset_options:
reset_options:
reset_options ',' reset_option
reset_options ',' reset_option
| reset_option
| reset_option
;
reset_option:
reset_option:
SLAVE { Lex->type|= REFRESH_SLAVE; }
SLAVE { Lex->type|= REFRESH_SLAVE; }
| MASTER_SYM { Lex->type|= REFRESH_MASTER; }
| MASTER_SYM { Lex->type|= REFRESH_MASTER; }
;
purge:
purge:
PURGE { Lex->sql_command = SQLCOM_PURGE; Lex->type=0;}
PURGE { Lex->sql_command = SQLCOM_PURGE; Lex->type=0;}
...
@@ -2344,6 +2527,7 @@ purge:
...
@@ -2344,6 +2527,7 @@ purge:
{
{
Lex->to_log = $6.str;
Lex->to_log = $6.str;
}
}
;
/* kill threads */
/* kill threads */
...
@@ -2358,11 +2542,13 @@ kill:
...
@@ -2358,11 +2542,13 @@ kill:
Lex->sql_command=SQLCOM_KILL;
Lex->sql_command=SQLCOM_KILL;
Lex->thread_id= (ulong) $2->val_int();
Lex->thread_id= (ulong) $2->val_int();
}
}
;
/* change database */
/* change database */
use: USE_SYM ident
use: USE_SYM ident
{ Lex->sql_command=SQLCOM_CHANGE_DB; Lex->db= $2.str; }
{ Lex->sql_command=SQLCOM_CHANGE_DB; Lex->db= $2.str; }
;
/* import, export of files */
/* import, export of files */
...
@@ -2389,29 +2575,34 @@ load: LOAD DATA_SYM load_data_lock opt_local INFILE TEXT_STRING
...
@@ -2389,29 +2575,34 @@ load: LOAD DATA_SYM load_data_lock opt_local INFILE TEXT_STRING
YYABORT;
YYABORT;
}
}
;
opt_local:
opt_local:
/* empty */ { $$=0;}
/* empty */ { $$=0;}
| LOCAL_SYM { $$=1;}
| LOCAL_SYM { $$=1;}
;
load_data_lock:
load_data_lock:
/* empty */ { Lex->lock_option= current_thd->update_lock_default; }
/* empty */ { Lex->lock_option= current_thd->update_lock_default; }
| CONCURRENT { Lex->lock_option= TL_WRITE_CONCURRENT_INSERT ; }
| CONCURRENT { Lex->lock_option= TL_WRITE_CONCURRENT_INSERT ; }
| LOW_PRIORITY { Lex->lock_option= TL_WRITE_LOW_PRIORITY; }
| LOW_PRIORITY { Lex->lock_option= TL_WRITE_LOW_PRIORITY; }
;
opt_duplicate:
opt_duplicate:
/* empty */ { Lex->duplicates=DUP_ERROR; }
/* empty */ { Lex->duplicates=DUP_ERROR; }
| REPLACE { Lex->duplicates=DUP_REPLACE; }
| REPLACE { Lex->duplicates=DUP_REPLACE; }
| IGNORE_SYM { Lex->duplicates=DUP_IGNORE; }
| IGNORE_SYM { Lex->duplicates=DUP_IGNORE; }
;
opt_field_term:
opt_field_term:
/* empty */
/* empty */
| COLUMNS field_term_list
| COLUMNS field_term_list
;
field_term_list:
field_term_list:
field_term_list field_term
field_term_list field_term
| field_term
| field_term
;
field_term:
field_term:
TERMINATED BY text_string { Lex->exchange->field_term= $3;}
TERMINATED BY text_string { Lex->exchange->field_term= $3;}
...
@@ -2419,23 +2610,28 @@ field_term:
...
@@ -2419,23 +2610,28 @@ field_term:
{ Lex->exchange->enclosed= $4; Lex->exchange->opt_enclosed=1;}
{ Lex->exchange->enclosed= $4; Lex->exchange->opt_enclosed=1;}
| ENCLOSED BY text_string { Lex->exchange->enclosed= $3;}
| ENCLOSED BY text_string { Lex->exchange->enclosed= $3;}
| ESCAPED BY text_string { Lex->exchange->escaped= $3;}
| ESCAPED BY text_string { Lex->exchange->escaped= $3;}
;
opt_line_term:
opt_line_term:
/* empty */
/* empty */
| LINES line_term_list
| LINES line_term_list
;
line_term_list:
line_term_list:
line_term_list line_term
line_term_list line_term
| line_term
| line_term
;
line_term:
line_term:
TERMINATED BY text_string { Lex->exchange->line_term= $3;}
TERMINATED BY text_string { Lex->exchange->line_term= $3;}
| STARTING BY text_string { Lex->exchange->line_start= $3;}
| STARTING BY text_string { Lex->exchange->line_start= $3;}
;
opt_ignore_lines:
opt_ignore_lines:
/* empty */
/* empty */
| IGNORE_SYM NUM LINES
| IGNORE_SYM NUM LINES
{ Lex->exchange->skip_lines=atol($2.str); }
{ Lex->exchange->skip_lines=atol($2.str); }
;
/* Common definitions */
/* Common definitions */
...
@@ -2443,6 +2639,7 @@ text_literal:
...
@@ -2443,6 +2639,7 @@ text_literal:
TEXT_STRING { $$ = new Item_string($1.str,$1.length); }
TEXT_STRING { $$ = new Item_string($1.str,$1.length); }
| text_literal TEXT_STRING
| text_literal TEXT_STRING
{ ((Item_string*) $1)->append($2.str,$2.length); }
{ ((Item_string*) $1)->append($2.str,$2.length); }
;
text_string:
text_string:
TEXT_STRING { $$= new String($1.str,$1.length); }
TEXT_STRING { $$= new String($1.str,$1.length); }
...
@@ -2451,6 +2648,7 @@ text_string:
...
@@ -2451,6 +2648,7 @@ text_string:
Item *tmp = new Item_varbinary($1.str,$1.length);
Item *tmp = new Item_varbinary($1.str,$1.length);
$$= tmp ? tmp->val_str((String*) 0) : (String*) 0;
$$= tmp ? tmp->val_str((String*) 0) : (String*) 0;
}
}
;
literal:
literal:
text_literal { $$ = $1; }
text_literal { $$ = $1; }
...
@@ -2464,6 +2662,7 @@ literal:
...
@@ -2464,6 +2662,7 @@ literal:
| DATE_SYM text_literal { $$ = $2; }
| DATE_SYM text_literal { $$ = $2; }
| TIME_SYM text_literal { $$ = $2; }
| TIME_SYM text_literal { $$ = $2; }
| TIMESTAMP text_literal { $$ = $2; }
| TIMESTAMP text_literal { $$ = $2; }
;
/**********************************************************************
/**********************************************************************
** Createing different items.
** Createing different items.
...
@@ -2472,14 +2671,17 @@ literal:
...
@@ -2472,14 +2671,17 @@ literal:
insert_ident:
insert_ident:
simple_ident { $$=$1; }
simple_ident { $$=$1; }
| table_wild { $$=$1; }
| table_wild { $$=$1; }
;
table_wild:
table_wild:
ident '.' '*' { $$ = new Item_field(NullS,$1.str,"*"); }
ident '.' '*' { $$ = new Item_field(NullS,$1.str,"*"); }
| ident '.' ident '.' '*'
| ident '.' ident '.' '*'
{ $$ = new Item_field((current_thd->client_capabilities & CLIENT_NO_SCHEMA ? NullS : $1.str),$3.str,"*"); }
{ $$ = new Item_field((current_thd->client_capabilities & CLIENT_NO_SCHEMA ? NullS : $1.str),$3.str,"*"); }
;
order_ident:
order_ident:
expr { $$=$1; }
expr { $$=$1; }
;
simple_ident:
simple_ident:
ident
ident
...
@@ -2490,17 +2692,19 @@ simple_ident:
...
@@ -2490,17 +2692,19 @@ simple_ident:
{ $$ = !Lex->create_refs || Lex->in_sum_expr > 0 ? (Item*) new Item_field(NullS,$2.str,$4.str) : (Item*) new Item_ref(NullS,$2.str,$4.str); }
{ $$ = !Lex->create_refs || Lex->in_sum_expr > 0 ? (Item*) new Item_field(NullS,$2.str,$4.str) : (Item*) new Item_ref(NullS,$2.str,$4.str); }
| ident '.' ident '.' ident
| ident '.' ident '.' ident
{ $$ = !Lex->create_refs || Lex->in_sum_expr > 0 ? (Item*) new Item_field((current_thd->client_capabilities & CLIENT_NO_SCHEMA ? NullS :$1.str),$3.str,$5.str) : (Item*) new Item_ref((current_thd->client_capabilities & CLIENT_NO_SCHEMA ? NullS :$1.str),$3.str,$5.str); }
{ $$ = !Lex->create_refs || Lex->in_sum_expr > 0 ? (Item*) new Item_field((current_thd->client_capabilities & CLIENT_NO_SCHEMA ? NullS :$1.str),$3.str,$5.str) : (Item*) new Item_ref((current_thd->client_capabilities & CLIENT_NO_SCHEMA ? NullS :$1.str),$3.str,$5.str); }
;
field_ident:
field_ident:
ident { $$=$1;}
ident { $$=$1;}
| ident '.' ident { $$=$3;} /* Skipp schema name in create*/
| ident '.' ident { $$=$3;} /* Skipp schema name in create*/
| '.' ident { $$=$2;} /* For Delphi */
| '.' ident { $$=$2;} /* For Delphi */
;
table_ident:
table_ident:
ident { $$=new Table_ident($1); }
ident { $$=new Table_ident($1); }
| ident '.' ident { $$=new Table_ident($1,$3,0);}
| ident '.' ident { $$=new Table_ident($1,$3,0);}
| '.' ident { $$=new Table_ident($2);} /* For Delphi */
| '.' ident { $$=new Table_ident($2);} /* For Delphi */
;
ident:
ident:
IDENT { $$=$1; }
IDENT { $$=$1; }
...
@@ -2511,11 +2715,13 @@ ident:
...
@@ -2511,11 +2715,13 @@ ident:
if (Lex->next_state != STATE_END)
if (Lex->next_state != STATE_END)
Lex->next_state=STATE_OPERATOR_OR_IDENT;
Lex->next_state=STATE_OPERATOR_OR_IDENT;
}
}
;
ident_or_text:
ident_or_text:
ident { $$=$1;}
ident { $$=$1;}
| TEXT_STRING { $$=$1;}
| TEXT_STRING { $$=$1;}
| LEX_HOSTNAME { $$=$1;}
| LEX_HOSTNAME { $$=$1;}
;
user:
user:
ident_or_text
ident_or_text
...
@@ -2530,6 +2736,7 @@ user:
...
@@ -2530,6 +2736,7 @@ user:
YYABORT;
YYABORT;
$$->user = $1; $$->host=$3;
$$->user = $1; $$->host=$3;
}
}
;
/* Keyword that we allow for identifiers */
/* Keyword that we allow for identifiers */
...
@@ -2651,6 +2858,7 @@ keyword:
...
@@ -2651,6 +2858,7 @@ keyword:
| WORK_SYM {}
| WORK_SYM {}
| YEAR_SYM {}
| YEAR_SYM {}
| SLAVE {}
| SLAVE {}
;
/* Option functions */
/* Option functions */
...
@@ -2666,14 +2874,18 @@ set:
...
@@ -2666,14 +2874,18 @@ set:
lex->tx_isolation=thd->tx_isolation;
lex->tx_isolation=thd->tx_isolation;
}
}
option_value_list
option_value_list
{}
;
opt_option:
opt_option:
/* empty */ {}
/* empty */ {}
| OPTION {}
| OPTION {}
;
option_value_list:
option_value_list:
option_value
option_value
| option_value_list ',' option_value
| option_value_list ',' option_value
;
option_value:
option_value:
set_option equal NUM
set_option equal NUM
...
@@ -2791,6 +3003,7 @@ option_value:
...
@@ -2791,6 +3003,7 @@ option_value:
else
else
Lex->options&= ~(OPTION_RELAXED_UNIQUE_CHECKS);
Lex->options&= ~(OPTION_RELAXED_UNIQUE_CHECKS);
}
}
;
text_or_password:
text_or_password:
TEXT_STRING { $$=$1.str;}
TEXT_STRING { $$=$1.str;}
...
@@ -2805,6 +3018,7 @@ text_or_password:
...
@@ -2805,6 +3018,7 @@ text_or_password:
$$=buff;
$$=buff;
}
}
}
}
;
set_option:
set_option:
SQL_BIG_TABLES { $$= OPTION_BIG_TABLES; }
SQL_BIG_TABLES { $$= OPTION_BIG_TABLES; }
...
@@ -2828,7 +3042,7 @@ set_option:
...
@@ -2828,7 +3042,7 @@ set_option:
| SQL_SAFE_UPDATES { $$= OPTION_SAFE_UPDATES; }
| SQL_SAFE_UPDATES { $$= OPTION_SAFE_UPDATES; }
| SQL_BUFFER_RESULT { $$= OPTION_BUFFER_RESULT; }
| SQL_BUFFER_RESULT { $$= OPTION_BUFFER_RESULT; }
| SQL_QUOTE_SHOW_CREATE { $$= OPTION_QUOTE_SHOW_CREATE; }
| SQL_QUOTE_SHOW_CREATE { $$= OPTION_QUOTE_SHOW_CREATE; }
;
set_isolation:
set_isolation:
GLOBAL_SYM tx_isolation
GLOBAL_SYM tx_isolation
...
@@ -2842,15 +3056,18 @@ set_isolation:
...
@@ -2842,15 +3056,18 @@ set_isolation:
{ current_thd->session_tx_isolation= Lex->tx_isolation= $2; }
{ current_thd->session_tx_isolation= Lex->tx_isolation= $2; }
| tx_isolation
| tx_isolation
{ Lex->tx_isolation= $1; }
{ Lex->tx_isolation= $1; }
;
tx_isolation:
tx_isolation:
TRANSACTION_SYM ISOLATION LEVEL_SYM isolation_types { $$=$4; }
TRANSACTION_SYM ISOLATION LEVEL_SYM isolation_types { $$=$4; }
;
isolation_types:
isolation_types:
READ_SYM UNCOMMITTED_SYM { $$= ISO_READ_UNCOMMITTED; }
READ_SYM UNCOMMITTED_SYM { $$= ISO_READ_UNCOMMITTED; }
| READ_SYM COMMITTED_SYM { $$= ISO_READ_COMMITTED; }
| READ_SYM COMMITTED_SYM { $$= ISO_READ_COMMITTED; }
| REPEATABLE_SYM READ_SYM { $$= ISO_REPEATABLE_READ; }
| REPEATABLE_SYM READ_SYM { $$= ISO_REPEATABLE_READ; }
| SERIALIZABLE_SYM { $$= ISO_SERIALIZABLE; }
| SERIALIZABLE_SYM { $$= ISO_SERIALIZABLE; }
;
/* Lock function */
/* Lock function */
...
@@ -2860,28 +3077,34 @@ lock:
...
@@ -2860,28 +3077,34 @@ lock:
Lex->sql_command=SQLCOM_LOCK_TABLES;
Lex->sql_command=SQLCOM_LOCK_TABLES;
}
}
table_lock_list
table_lock_list
{}
;
table_or_tables:
table_or_tables:
TABLE_SYM
TABLE_SYM
| TABLES
| TABLES
;
table_lock_list:
table_lock_list:
table_lock
table_lock
| table_lock_list ',' table_lock
| table_lock_list ',' table_lock
;
table_lock:
table_lock:
table_ident opt_table_alias lock_option
table_ident opt_table_alias lock_option
{ if (!add_table_to_list($1,$2,0,(thr_lock_type) $3)) YYABORT; }
{ if (!add_table_to_list($1,$2,0,(thr_lock_type) $3)) YYABORT; }
;
lock_option:
lock_option:
READ_SYM { $$=TL_READ_NO_INSERT; }
READ_SYM { $$=TL_READ_NO_INSERT; }
| WRITE_SYM { $$=current_thd->update_lock_default; }
| WRITE_SYM { $$=current_thd->update_lock_default; }
| LOW_PRIORITY WRITE_SYM { $$=TL_WRITE_LOW_PRIORITY; }
| LOW_PRIORITY WRITE_SYM { $$=TL_WRITE_LOW_PRIORITY; }
| READ_SYM LOCAL_SYM { $$= TL_READ; }
| READ_SYM LOCAL_SYM { $$= TL_READ; }
;
unlock:
unlock:
UNLOCK_SYM table_or_tables { Lex->sql_command=SQLCOM_UNLOCK_TABLES; }
UNLOCK_SYM table_or_tables { Lex->sql_command=SQLCOM_UNLOCK_TABLES; }
;
/* GRANT / REVOKE */
/* GRANT / REVOKE */
...
@@ -2895,6 +3118,8 @@ revoke:
...
@@ -2895,6 +3118,8 @@ revoke:
Lex->db=0;
Lex->db=0;
}
}
grant_privileges ON opt_table FROM user_list
grant_privileges ON opt_table FROM user_list
{}
;
grant:
grant:
GRANT
GRANT
...
@@ -2907,28 +3132,33 @@ grant:
...
@@ -2907,28 +3132,33 @@ grant:
}
}
grant_privileges ON opt_table TO_SYM user_list
grant_privileges ON opt_table TO_SYM user_list
grant_option
grant_option
{}
;
grant_privileges:
grant_privileges:
grant_privilege_list {}
grant_privilege_list {}
| ALL PRIVILEGES { Lex->grant = UINT_MAX;}
| ALL PRIVILEGES { Lex->grant = UINT_MAX;}
| ALL { Lex->grant = UINT_MAX;}
| ALL { Lex->grant = UINT_MAX;}
;
grant_privilege_list:
grant_privilege_list:
grant_privilege
grant_privilege
| grant_privilege_list ',' grant_privilege
| grant_privilege_list ',' grant_privilege
{}
;
grant_privilege:
grant_privilege:
SELECT_SYM
SELECT_SYM
{ Lex->which_columns = SELECT_ACL;}
{ Lex->which_columns = SELECT_ACL;}
opt_column_list
opt_column_list
{}
| INSERT
| INSERT
{ Lex->which_columns = INSERT_ACL; }
{ Lex->which_columns = INSERT_ACL; }
opt_column_list
opt_column_list
{}
| UPDATE_SYM
| UPDATE_SYM
{ Lex->which_columns = UPDATE_ACL; }
{ Lex->which_columns = UPDATE_ACL; }
opt_column_list
opt_column_list
{}
| DELETE_SYM { Lex->grant |= DELETE_ACL;}
| DELETE_SYM { Lex->grant |= DELETE_ACL;}
| REFERENCES { Lex->which_columns = REFERENCES_ACL;} opt_column_list
| REFERENCES { Lex->which_columns = REFERENCES_ACL;} opt_column_list
{}
| USAGE {}
| USAGE {}
| INDEX { Lex->grant |= INDEX_ACL;}
| INDEX { Lex->grant |= INDEX_ACL;}
| ALTER { Lex->grant |= ALTER_ACL;}
| ALTER { Lex->grant |= ALTER_ACL;}
...
@@ -2939,6 +3169,7 @@ grant_privilege:
...
@@ -2939,6 +3169,7 @@ grant_privilege:
| PROCESS { Lex->grant |= PROCESS_ACL;}
| PROCESS { Lex->grant |= PROCESS_ACL;}
| FILE_SYM { Lex->grant |= FILE_ACL;}
| FILE_SYM { Lex->grant |= FILE_ACL;}
| GRANT OPTION { Lex->grant |= GRANT_ACL;}
| GRANT OPTION { Lex->grant |= GRANT_ACL;}
;
opt_table:
opt_table:
'*'
'*'
...
@@ -2981,12 +3212,12 @@ opt_table:
...
@@ -2981,12 +3212,12 @@ opt_table:
if (Lex->grant == UINT_MAX)
if (Lex->grant == UINT_MAX)
Lex->grant = TABLE_ACLS & ~GRANT_ACL;
Lex->grant = TABLE_ACLS & ~GRANT_ACL;
}
}
;
user_list:
user_list:
grant_user { if (Lex->users_list.push_back($1)) YYABORT;}
grant_user { if (Lex->users_list.push_back($1)) YYABORT;}
| user_list ',' grant_user { if (Lex->users_list.push_back($3)) YYABORT;}
| user_list ',' grant_user { if (Lex->users_list.push_back($3)) YYABORT;}
;
grant_user:
grant_user:
user IDENTIFIED_SYM BY TEXT_STRING
user IDENTIFIED_SYM BY TEXT_STRING
...
@@ -3007,15 +3238,17 @@ grant_user:
...
@@ -3007,15 +3238,17 @@ grant_user:
{ $$=$1; $1->password=$5 ; }
{ $$=$1; $1->password=$5 ; }
| user
| user
{ $$=$1; $1->password.str=NullS; }
{ $$=$1; $1->password.str=NullS; }
;
opt_column_list:
opt_column_list:
/* empty */ { Lex->grant |= Lex->which_columns; }
/* empty */ { Lex->grant |= Lex->which_columns; }
| '(' column_list ')'
| '(' column_list ')'
;
column_list:
column_list:
column_list ',' column_list_id
column_list ',' column_list_id
| column_list_id
| column_list_id
;
column_list_id:
column_list_id:
ident
ident
...
@@ -3034,20 +3267,26 @@ column_list_id:
...
@@ -3034,20 +3267,26 @@ column_list_id:
else
else
Lex->columns.push_back(new LEX_COLUMN (*new_str,Lex->which_columns));
Lex->columns.push_back(new LEX_COLUMN (*new_str,Lex->which_columns));
}
}
;
grant_option:
grant_option:
/* empty */ {}
/* empty */ {}
| WITH GRANT OPTION { Lex->grant |= GRANT_ACL;}
| WITH GRANT OPTION { Lex->grant |= GRANT_ACL;}
;
begin:
begin:
BEGIN_SYM { Lex->sql_command = SQLCOM_BEGIN;} opt_work
BEGIN_SYM { Lex->sql_command = SQLCOM_BEGIN;} opt_work {}
;
opt_work:
opt_work:
/* empty */ {}
/* empty */ {}
| WORK_SYM {}
| WORK_SYM {}
;
commit:
commit:
COMMIT_SYM { Lex->sql_command = SQLCOM_COMMIT;}
COMMIT_SYM { Lex->sql_command = SQLCOM_COMMIT;}
;
rollback:
rollback:
ROLLBACK_SYM { Lex->sql_command = SQLCOM_ROLLBACK;}
ROLLBACK_SYM { Lex->sql_command = SQLCOM_ROLLBACK;}
;
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