1
/* Copyright (C) 2000 MySQL AB & MySQL Finland AB & TCX DataKonsult AB
3
This program is free software; you can redistribute it and/or modify
4
it under the terms of the GNU General Public License as published by
5
the Free Software Foundation; either version 2 of the License, or
6
(at your option) any later version.
8
This program is distributed in the hope that it will be useful,
9
but WITHOUT ANY WARRANTY; without even the implied warranty of
10
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11
GNU General Public License for more details.
13
You should have received a copy of the GNU General Public License
14
along with this program; if not, write to the Free Software
15
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
17
/* Functions to create an item. Used by lex.h */
19
#include "mysql_priv.h"
22
#define M_PI 3.14159265358979323846
25
Item *create_func_abs(Item* a)
27
return new Item_func_abs(a);
30
Item *create_func_acos(Item* a)
32
return new Item_func_acos(a);
35
Item *create_func_ascii(Item* a)
37
return new Item_func_ascii(a);
40
Item *create_func_ord(Item* a)
42
return new Item_func_ord(a);
45
Item *create_func_asin(Item* a)
47
return new Item_func_asin(a);
50
Item *create_func_bin(Item* a)
52
return new Item_func_conv(a,new Item_int((int32) 10,2),
53
new Item_int((int32) 2,1));
56
Item *create_func_bit_count(Item* a)
58
return new Item_func_bit_count(a);
61
Item *create_func_ceiling(Item* a)
63
return new Item_func_ceiling(a);
66
Item *create_func_connection_id(void)
68
return new Item_int("CONNECTION_ID()",(longlong) current_thd->thread_id,10);
71
Item *create_func_conv(Item* a, Item *b, Item *c)
73
return new Item_func_conv(a,b,c);
76
Item *create_func_cos(Item* a)
78
return new Item_func_cos(a);
81
Item *create_func_cot(Item* a)
83
return new Item_func_div(new Item_int((char*) "1",1,1),
84
new Item_func_tan(a));
87
Item *create_func_date_format(Item* a,Item *b)
89
return new Item_func_date_format(a,b,0);
92
Item *create_func_dayofmonth(Item* a)
94
return new Item_func_dayofmonth(a);
97
Item *create_func_dayofweek(Item* a)
99
return new Item_func_weekday(new Item_func_to_days(a),1);
102
Item *create_func_dayofyear(Item* a)
104
return new Item_func_dayofyear(a);
107
Item *create_func_dayname(Item* a)
109
return new Item_func_dayname(new Item_func_to_days(a));
112
Item *create_func_degrees(Item *a)
114
return new Item_func_units((char*) "degrees",a,180/M_PI,0.0);
117
Item *create_func_exp(Item* a)
119
return new Item_func_exp(a);
122
Item *create_func_find_in_set(Item* a, Item *b)
124
return new Item_func_find_in_set(a, b);
127
Item *create_func_floor(Item* a)
129
return new Item_func_floor(a);
132
Item *create_func_from_days(Item* a)
134
return new Item_func_from_days(a);
137
Item *create_func_get_lock(Item* a, Item *b)
139
return new Item_func_get_lock(a, b);
142
Item *create_func_hex(Item *a)
144
return new Item_func_conv(a,new Item_int((int32) 10,2),
145
new Item_int((int32) 16,2));
148
Item *create_func_inet_ntoa(Item* a)
150
return new Item_func_inet_ntoa(a);
153
Item *create_func_inet_aton(Item* a)
155
return new Item_func_inet_aton(a);
159
Item *create_func_ifnull(Item* a, Item *b)
161
return new Item_func_ifnull(a,b);
164
Item *create_func_nullif(Item* a, Item *b)
166
return new Item_func_nullif(a,b);
169
Item *create_func_locate(Item* a, Item *b)
171
return new Item_func_locate(b,a);
174
Item *create_func_instr(Item* a, Item *b)
176
return new Item_func_locate(a,b);
179
Item *create_func_isnull(Item* a)
181
return new Item_func_isnull(a);
184
Item *create_func_lcase(Item* a)
186
return new Item_func_lcase(a);
189
Item *create_func_length(Item* a)
191
return new Item_func_length(a);
194
Item *create_func_char_length(Item* a)
196
return new Item_func_char_length(a);
199
Item *create_func_log(Item* a)
201
return new Item_func_log(a);
204
Item *create_func_log10(Item* a)
206
return new Item_func_log10(a);
209
Item *create_func_lpad(Item* a, Item *b, Item *c)
211
return new Item_func_lpad(a,b,c);
214
Item *create_func_ltrim(Item* a)
216
return new Item_func_ltrim(a,new Item_string(" ",1));
219
Item *create_func_md5(Item* a)
221
return new Item_func_md5(a);
224
Item *create_func_mod(Item* a, Item *b)
226
return new Item_func_mod(a,b);
229
Item *create_func_monthname(Item* a)
231
return new Item_func_monthname(a);
234
Item *create_func_month(Item* a)
236
return new Item_func_month(a);
239
Item *create_func_oct(Item *a)
241
return new Item_func_conv(a,new Item_int((int32) 10,2),
242
new Item_int((int32) 8,1));
245
Item *create_func_period_add(Item* a, Item *b)
247
return new Item_func_period_add(a,b);
250
Item *create_func_period_diff(Item* a, Item *b)
252
return new Item_func_period_diff(a,b);
255
Item *create_func_pi(void)
257
return new Item_real("PI()",M_PI,6,8);
260
Item *create_func_pow(Item* a, Item *b)
262
return new Item_func_pow(a,b);
265
Item *create_func_quarter(Item* a)
267
return new Item_func_quarter(a);
270
Item *create_func_radians(Item *a)
272
return new Item_func_units((char*) "radians",a,M_PI/180,0.0);
275
Item *create_func_release_lock(Item* a)
277
return new Item_func_release_lock(a);
280
Item *create_func_repeat(Item* a, Item *b)
282
return new Item_func_repeat(a,b);
285
Item *create_func_reverse(Item* a)
287
return new Item_func_reverse(a);
290
Item *create_func_rpad(Item* a, Item *b, Item *c)
292
return new Item_func_rpad(a,b,c);
295
Item *create_func_rtrim(Item* a)
297
return new Item_func_rtrim(a,new Item_string(" ",1));
300
Item *create_func_sec_to_time(Item* a)
302
return new Item_func_sec_to_time(a);
305
Item *create_func_sign(Item* a)
307
return new Item_func_sign(a);
310
Item *create_func_sin(Item* a)
312
return new Item_func_sin(a);
315
Item *create_func_space(Item *a)
317
return new Item_func_repeat(new Item_string(" ",1),a);
320
Item *create_func_soundex(Item* a)
322
return new Item_func_soundex(a);
325
Item *create_func_sqrt(Item* a)
327
return new Item_func_sqrt(a);
330
Item *create_func_strcmp(Item* a, Item *b)
332
return new Item_func_strcmp(a,b);
335
Item *create_func_tan(Item* a)
337
return new Item_func_tan(a);
340
Item *create_func_time_format(Item *a, Item *b)
342
return new Item_func_date_format(a,b,1);
345
Item *create_func_time_to_sec(Item* a)
347
return new Item_func_time_to_sec(a);
350
Item *create_func_to_days(Item* a)
352
return new Item_func_to_days(a);
355
Item *create_func_truncate (Item *a, Item *b)
357
return new Item_func_round(a,b,1);
360
Item *create_func_ucase(Item* a)
362
return new Item_func_ucase(a);
365
Item *create_func_version(void)
367
return new Item_string(NullS,server_version, strlen(server_version));
370
Item *create_func_weekday(Item* a)
372
return new Item_func_weekday(new Item_func_to_days(a),0);
375
Item *create_func_year(Item* a)
377
return new Item_func_year(a);
380
Item *create_load_file(Item* a)
382
return new Item_load_file(a);