mariadb/sql/item_create.cc
unknown 4ad51359c1 Merge with 4.1
(Includes merge of arena code in 4.1 and 5.0)



BitKeeper/etc/ignore:
  auto-union
BitKeeper/etc/logging_ok:
  auto-union
VC++Files/sql/mysqld.dsp:
  Auto merged
client/mysql.cc:
  Auto merged
client/mysqltest.c:
  Auto merged
include/my_global.h:
  Auto merged
include/my_sys.h:
  Auto merged
include/mysql.h:
  Auto merged
include/mysql_com.h:
  Auto merged
innobase/row/row0sel.c:
  Auto merged
libmysql/client_settings.h:
  Auto merged
libmysql/libmysql.c:
  Auto merged
libmysqld/Makefile.am:
  Auto merged
libmysqld/examples/Makefile.am:
  Auto merged
libmysqld/lib_sql.cc:
  Auto merged
myisam/mi_check.c:
  Auto merged
myisam/myisamchk.c:
  Auto merged
myisam/sort.c:
  Auto merged
mysql-test/r/connect.result:
  Auto merged
mysql-test/r/ctype_recoding.result:
  Auto merged
mysql-test/r/ctype_ucs.result:
  Auto merged
mysql-test/r/func_in.result:
  Auto merged
mysql-test/r/func_like.result:
  Auto merged
mysql-test/r/gis.result:
  Auto merged
mysql-test/r/having.result:
  Auto merged
mysql-test/r/heap.result:
  Auto merged
mysql-test/r/join.result:
  Auto merged
mysql-test/r/key.result:
  Auto merged
mysql-test/r/lowercase_table.result:
  Auto merged
mysql-test/r/ndb_autodiscover.result:
  Auto merged
mysql-test/r/null.result:
  Auto merged
mysql-test/r/olap.result:
  Auto merged
mysql-test/r/order_by.result:
  Auto merged
mysql-test/r/ps_1general.result:
  Auto merged
mysql-test/r/ps_2myisam.result:
  Auto merged
mysql-test/r/ps_3innodb.result:
  Auto merged
mysql-test/r/ps_4heap.result:
  Auto merged
mysql-test/r/ps_5merge.result:
  Auto merged
mysql-test/r/ps_6bdb.result:
  Auto merged
mysql-test/r/range.result:
  Auto merged
mysql-test/r/rename.result:
  Auto merged
mysql-test/r/show_check.result:
  Auto merged
mysql-test/r/subselect.result:
  Auto merged
mysql-test/r/union.result:
  Auto merged
mysql-test/r/variables.result:
  Auto merged
mysql-test/t/alter_table.test:
  Auto merged
mysql-test/t/null.test:
  Auto merged
mysql-test/t/ps_1general.test:
  Auto merged
mysql-test/t/rpl_charset.test:
  Auto merged
mysql-test/t/rpl_heap.test:
  Auto merged
mysql-test/t/rpl_relayrotate.test:
  Auto merged
mysql-test/t/subselect.test:
  Auto merged
mysql-test/t/variables.test:
  Auto merged
netware/mysql_test_run.c:
  Auto merged
scripts/make_binary_distribution.sh:
  Auto merged
scripts/mysql_create_system_tables.sh:
  Auto merged
scripts/mysql_fix_privilege_tables.sql:
  Auto merged
scripts/mysql_install_db.sh:
  Auto merged
sql/ha_berkeley.cc:
  Auto merged
sql/ha_innodb.cc:
  Auto merged
sql/ha_innodb.h:
  Auto merged
sql/ha_myisam.cc:
  Auto merged
sql/handler.cc:
  Auto merged
sql/handler.h:
  Auto merged
sql/item.h:
  Auto merged
sql/item_cmpfunc.h:
  Auto merged
sql/item_create.cc:
  Auto merged
sql/item_create.h:
  Auto merged
sql/item_func.cc:
  Auto merged
sql/item_func.h:
  Auto merged
sql/item_timefunc.cc:
  Auto merged
sql/item_timefunc.h:
  Auto merged
sql/lex.h:
  Auto merged
sql/lock.cc:
  Auto merged
sql/log_event.cc:
  Auto merged
sql/mysql_priv.h:
  Auto merged
sql/opt_sum.cc:
  Auto merged
sql/protocol.cc:
  Auto merged
sql/records.cc:
  Auto merged
sql/repl_failsafe.cc:
  Auto merged
sql/set_var.cc:
  Auto merged
sql/set_var.h:
  Auto merged
sql/slave.cc:
  Auto merged
sql/sql_acl.cc:
  Auto merged
sql/sql_acl.h:
  Auto merged
sql/sql_db.cc:
  Auto merged
sql/sql_delete.cc:
  Auto merged
sql/sql_insert.cc:
  Auto merged
sql/sql_list.h:
  Auto merged
sql/sql_load.cc:
  Auto merged
sql/sql_rename.cc:
  Auto merged
sql/sql_select.h:
  Auto merged
sql/sql_show.cc:
  Auto merged
sql/sql_string.h:
  Auto merged
sql/table.cc:
  Auto merged
sql-common/client.c:
  Auto merged
client/mysqlbinlog.cc:
  Merge with 4.1
configure.in:
  Merge with 4.1
include/mysqld_error.h:
  Add new error message (1) from 4.1
mysql-test/mysql-test-run.sh:
  Merge with 4.1
mysql-test/r/func_gconcat.result:
  Merge with 4.1
mysql-test/r/func_if.result:
  Merge with 4.1
mysql-test/r/grant.result:
  Merge with 4.1
mysql-test/r/join_outer.result:
  Merge with 4.1
mysql-test/r/rpl_charset.result:
  Merge with 4.1 (This has to be fixed before pushing)
mysql-test/r/system_mysql_db.result:
  Merge with 4.1.
  Added collation to new privileges
mysql-test/t/grant.test:
  Merge with 4.1
mysql-test/t/grant_cache.test:
  Merge with 4.1
mysql-test/t/show_check.test:
  Merge with 4.1
sql/Makefile.am:
  Merge with 4.1
sql/item.cc:
  Merge with 4.1
sql/item_cmpfunc.cc:
  Merge with 4.1 (arena code)
sql/item_subselect.cc:
  Merge with 4.1
sql/item_subselect.h:
  Merge with 4.1
sql/item_sum.cc:
  Merge with 4.1
sql/item_sum.h:
  Merge with 4.1
sql/log.cc:
  Merge with 4.1 (Remove code that is not relevant for 5.0)
sql/mysqld.cc:
  Merge with 4.1
sql/opt_range.cc:
  Merge with 4.1
sql/share/czech/errmsg.txt:
  Merge with 4.1
sql/share/danish/errmsg.txt:
  Merge with 4.1
sql/share/dutch/errmsg.txt:
  Merge with 4.1
sql/share/english/errmsg.txt:
  Merge with 4.1
sql/share/estonian/errmsg.txt:
  Merge with 4.1
sql/share/french/errmsg.txt:
  Merge with 4.1
sql/share/german/errmsg.txt:
  Merge with 4.1
sql/share/greek/errmsg.txt:
  Merge with 4.1
sql/share/hungarian/errmsg.txt:
  Merge with 4.1
sql/share/italian/errmsg.txt:
  Merge with 4.1
sql/share/japanese/errmsg.txt:
  Merge with 4.1
sql/share/korean/errmsg.txt:
  Merge with 4.1
sql/share/norwegian-ny/errmsg.txt:
  Merge with 4.1
sql/share/norwegian/errmsg.txt:
  Merge with 4.1
sql/share/polish/errmsg.txt:
  Merge with 4.1
sql/share/portuguese/errmsg.txt:
  Merge with 4.1
sql/share/romanian/errmsg.txt:
  Merge with 4.1
sql/share/russian/errmsg.txt:
  Merge with 4.1
sql/share/serbian/errmsg.txt:
  Merge with 4.1
sql/share/slovak/errmsg.txt:
  Merge with 4.1
sql/share/spanish/errmsg.txt:
  Merge with 4.1
sql/share/swedish/errmsg.txt:
  Merge with 4.1
sql/share/ukrainian/errmsg.txt:
  Merge with 4.1
sql/sql_base.cc:
  Merge with 4.1
sql/sql_class.cc:
  Merge with 4.1
  Use arena code from 4.1
sql/sql_class.h:
  Merge with 4.1
  Use arena code from 4.1
sql/sql_derived.cc:
  Merge with 4.1
sql/sql_lex.cc:
  Merge with 4.1
sql/sql_lex.h:
  Merge with 4.1
sql/sql_parse.cc:
  Merge with 4.1
sql/sql_prepare.cc:
  Merge with 4.1
sql/sql_select.cc:
  Merge with 4.1
sql/sql_table.cc:
  Merge with 4.1
sql/sql_union.cc:
  Merge with 4.1
sql/sql_yacc.yy:
  Merge with 4.1
sql/tztime.cc:
  Merge with 4.1
tests/client_test.c:
  Merge with 4.1
2004-09-06 15:14:10 +03:00

720 lines
14 KiB
C++

/* Copyright (C) 2000-2003 MySQL AB
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
/* Functions to create an item. Used by lex.h */
#include "mysql_priv.h"
Item *create_func_abs(Item* a)
{
return new Item_func_abs(a);
}
Item *create_func_acos(Item* a)
{
return new Item_func_acos(a);
}
Item *create_func_aes_encrypt(Item* a, Item* b)
{
return new Item_func_aes_encrypt(a, b);
}
Item *create_func_aes_decrypt(Item* a, Item* b)
{
return new Item_func_aes_decrypt(a, b);
}
Item *create_func_ascii(Item* a)
{
return new Item_func_ascii(a);
}
Item *create_func_ord(Item* a)
{
return new Item_func_ord(a);
}
Item *create_func_asin(Item* a)
{
return new Item_func_asin(a);
}
Item *create_func_bin(Item* a)
{
return new Item_func_conv(a,new Item_int((int32) 10,2),
new Item_int((int32) 2,1));
}
Item *create_func_bit_count(Item* a)
{
return new Item_func_bit_count(a);
}
Item *create_func_ceiling(Item* a)
{
return new Item_func_ceiling(a);
}
Item *create_func_connection_id(void)
{
THD *thd=current_thd;
thd->lex->safe_to_cache_query= 0;
return new Item_static_int_func("connection_id()",
(longlong)
((thd->slave_thread) ?
thd->variables.pseudo_thread_id :
thd->thread_id),
10);
}
Item *create_func_conv(Item* a, Item *b, Item *c)
{
return new Item_func_conv(a,b,c);
}
Item *create_func_cos(Item* a)
{
return new Item_func_cos(a);
}
Item *create_func_cot(Item* a)
{
return new Item_func_div(new Item_int((char*) "1",1,1),
new Item_func_tan(a));
}
Item *create_func_date_format(Item* a,Item *b)
{
return new Item_func_date_format(a,b,0);
}
Item *create_func_dayofmonth(Item* a)
{
return new Item_func_dayofmonth(a);
}
Item *create_func_dayofweek(Item* a)
{
return new Item_func_weekday(new Item_func_to_days(a),1);
}
Item *create_func_dayofyear(Item* a)
{
return new Item_func_dayofyear(a);
}
Item *create_func_dayname(Item* a)
{
return new Item_func_dayname(new Item_func_to_days(a));
}
Item *create_func_degrees(Item *a)
{
return new Item_func_units((char*) "degrees",a,180/M_PI,0.0);
}
Item *create_func_exp(Item* a)
{
return new Item_func_exp(a);
}
Item *create_func_find_in_set(Item* a, Item *b)
{
return new Item_func_find_in_set(a, b);
}
Item *create_func_floor(Item* a)
{
return new Item_func_floor(a);
}
Item *create_func_found_rows(void)
{
THD *thd=current_thd;
thd->lex->safe_to_cache_query= 0;
return new Item_func_found_rows();
}
Item *create_func_from_days(Item* a)
{
return new Item_func_from_days(a);
}
Item *create_func_get_lock(Item* a, Item *b)
{
current_thd->lex->uncacheable(UNCACHEABLE_SIDEEFFECT);
return new Item_func_get_lock(a, b);
}
Item *create_func_hex(Item *a)
{
return new Item_func_hex(a);
}
Item *create_func_inet_ntoa(Item* a)
{
return new Item_func_inet_ntoa(a);
}
Item *create_func_inet_aton(Item* a)
{
return new Item_func_inet_aton(a);
}
Item *create_func_ifnull(Item* a, Item *b)
{
return new Item_func_ifnull(a,b);
}
Item *create_func_nullif(Item* a, Item *b)
{
return new Item_func_nullif(a,b);
}
Item *create_func_locate(Item* a, Item *b)
{
return new Item_func_locate(b,a);
}
Item *create_func_instr(Item* a, Item *b)
{
return new Item_func_locate(a,b);
}
Item *create_func_isnull(Item* a)
{
return new Item_func_isnull(a);
}
Item *create_func_lcase(Item* a)
{
return new Item_func_lcase(a);
}
Item *create_func_length(Item* a)
{
return new Item_func_length(a);
}
Item *create_func_bit_length(Item* a)
{
return new Item_func_bit_length(a);
}
Item *create_func_coercibility(Item* a)
{
return new Item_func_coercibility(a);
}
Item *create_func_char_length(Item* a)
{
return new Item_func_char_length(a);
}
Item *create_func_ln(Item* a)
{
return new Item_func_ln(a);
}
Item *create_func_log2(Item* a)
{
return new Item_func_log2(a);
}
Item *create_func_log10(Item* a)
{
return new Item_func_log10(a);
}
Item *create_func_lpad(Item* a, Item *b, Item *c)
{
return new Item_func_lpad(a,b,c);
}
Item *create_func_ltrim(Item* a)
{
return new Item_func_ltrim(a);
}
Item *create_func_md5(Item* a)
{
return new Item_func_md5(a);
}
Item *create_func_mod(Item* a, Item *b)
{
return new Item_func_mod(a,b);
}
Item *create_func_monthname(Item* a)
{
return new Item_func_monthname(a);
}
Item *create_func_month(Item* a)
{
return new Item_func_month(a);
}
Item *create_func_oct(Item *a)
{
return new Item_func_conv(a,new Item_int((int32) 10,2),
new Item_int((int32) 8,1));
}
Item *create_func_period_add(Item* a, Item *b)
{
return new Item_func_period_add(a,b);
}
Item *create_func_period_diff(Item* a, Item *b)
{
return new Item_func_period_diff(a,b);
}
Item *create_func_pi(void)
{
return new Item_static_real_func("pi()", M_PI, 6, 8);
}
Item *create_func_pow(Item* a, Item *b)
{
return new Item_func_pow(a,b);
}
Item *create_func_current_user()
{
THD *thd=current_thd;
char buff[HOSTNAME_LENGTH+USERNAME_LENGTH+2];
uint length;
length= (uint) (strxmov(buff, thd->priv_user, "@", thd->priv_host, NullS) -
buff);
return new Item_static_string_func("current_user()",
thd->memdup(buff, length), length,
system_charset_info);
}
Item *create_func_radians(Item *a)
{
return new Item_func_units((char*) "radians",a,M_PI/180,0.0);
}
Item *create_func_release_lock(Item* a)
{
current_thd->lex->uncacheable(UNCACHEABLE_SIDEEFFECT);
return new Item_func_release_lock(a);
}
Item *create_func_repeat(Item* a, Item *b)
{
return new Item_func_repeat(a,b);
}
Item *create_func_reverse(Item* a)
{
return new Item_func_reverse(a);
}
Item *create_func_rpad(Item* a, Item *b, Item *c)
{
return new Item_func_rpad(a,b,c);
}
Item *create_func_rtrim(Item* a)
{
return new Item_func_rtrim(a);
}
Item *create_func_sec_to_time(Item* a)
{
return new Item_func_sec_to_time(a);
}
Item *create_func_sign(Item* a)
{
return new Item_func_sign(a);
}
Item *create_func_sin(Item* a)
{
return new Item_func_sin(a);
}
Item *create_func_sha(Item* a)
{
return new Item_func_sha(a);
}
Item *create_func_space(Item *a)
{
CHARSET_INFO *cs= current_thd->variables.collation_connection;
Item *sp;
if (cs->mbminlen > 1)
{
sp= new Item_string("",0,cs);
if (sp)
sp->str_value.copy(" ",1,&my_charset_latin1,cs);
}
else
{
sp= new Item_string(" ",1,cs);
}
return new Item_func_repeat(sp, a);
}
Item *create_func_soundex(Item* a)
{
return new Item_func_soundex(a);
}
Item *create_func_sqrt(Item* a)
{
return new Item_func_sqrt(a);
}
Item *create_func_strcmp(Item* a, Item *b)
{
return new Item_func_strcmp(a,b);
}
Item *create_func_tan(Item* a)
{
return new Item_func_tan(a);
}
Item *create_func_time_format(Item *a, Item *b)
{
return new Item_func_date_format(a,b,1);
}
Item *create_func_time_to_sec(Item* a)
{
return new Item_func_time_to_sec(a);
}
Item *create_func_to_days(Item* a)
{
return new Item_func_to_days(a);
}
Item *create_func_ucase(Item* a)
{
return new Item_func_ucase(a);
}
Item *create_func_unhex(Item* a)
{
return new Item_func_unhex(a);
}
Item *create_func_uuid(void)
{
return new Item_func_uuid();
}
Item *create_func_version(void)
{
return new Item_static_string_func("version()", server_version,
(uint) strlen(server_version),
system_charset_info, DERIVATION_IMPLICIT);
}
Item *create_func_weekday(Item* a)
{
return new Item_func_weekday(new Item_func_to_days(a),0);
}
Item *create_func_year(Item* a)
{
return new Item_func_year(a);
}
Item *create_load_file(Item* a)
{
current_thd->lex->uncacheable(UNCACHEABLE_SIDEEFFECT);
return new Item_load_file(a);
}
Item *create_func_cast(Item *a, Cast_target cast_type, int len,
CHARSET_INFO *cs)
{
Item *res;
LINT_INIT(res);
switch (cast_type) {
case ITEM_CAST_BINARY: res= new Item_func_binary(a); break;
case ITEM_CAST_SIGNED_INT: res= new Item_func_signed(a); break;
case ITEM_CAST_UNSIGNED_INT: res= new Item_func_unsigned(a); break;
case ITEM_CAST_DATE: res= new Item_date_typecast(a); break;
case ITEM_CAST_TIME: res= new Item_time_typecast(a); break;
case ITEM_CAST_DATETIME: res= new Item_datetime_typecast(a); break;
case ITEM_CAST_CHAR:
res= new Item_char_typecast(a, len, cs ? cs :
current_thd->variables.collation_connection);
break;
}
return res;
}
Item *create_func_is_free_lock(Item* a)
{
current_thd->lex->uncacheable(UNCACHEABLE_SIDEEFFECT);
return new Item_func_is_free_lock(a);
}
Item *create_func_is_used_lock(Item* a)
{
current_thd->lex->uncacheable(UNCACHEABLE_SIDEEFFECT);
return new Item_func_is_used_lock(a);
}
Item *create_func_quote(Item* a)
{
return new Item_func_quote(a);
}
#ifdef HAVE_SPATIAL
Item *create_func_as_wkt(Item *a)
{
return new Item_func_as_wkt(a);
}
Item *create_func_as_wkb(Item *a)
{
return new Item_func_as_wkb(a);
}
Item *create_func_srid(Item *a)
{
return new Item_func_srid(a);
}
Item *create_func_startpoint(Item *a)
{
return new Item_func_spatial_decomp(a, Item_func::SP_STARTPOINT);
}
Item *create_func_endpoint(Item *a)
{
return new Item_func_spatial_decomp(a, Item_func::SP_ENDPOINT);
}
Item *create_func_exteriorring(Item *a)
{
return new Item_func_spatial_decomp(a, Item_func::SP_EXTERIORRING);
}
Item *create_func_pointn(Item *a, Item *b)
{
return new Item_func_spatial_decomp_n(a, b, Item_func::SP_POINTN);
}
Item *create_func_interiorringn(Item *a, Item *b)
{
return new Item_func_spatial_decomp_n(a, b, Item_func::SP_INTERIORRINGN);
}
Item *create_func_geometryn(Item *a, Item *b)
{
return new Item_func_spatial_decomp_n(a, b, Item_func::SP_GEOMETRYN);
}
Item *create_func_centroid(Item *a)
{
return new Item_func_centroid(a);
}
Item *create_func_envelope(Item *a)
{
return new Item_func_envelope(a);
}
Item *create_func_equals(Item *a, Item *b)
{
return new Item_func_spatial_rel(a, b, Item_func::SP_EQUALS_FUNC);
}
Item *create_func_disjoint(Item *a, Item *b)
{
return new Item_func_spatial_rel(a, b, Item_func::SP_DISJOINT_FUNC);
}
Item *create_func_intersects(Item *a, Item *b)
{
return new Item_func_spatial_rel(a, b, Item_func::SP_INTERSECTS_FUNC);
}
Item *create_func_touches(Item *a, Item *b)
{
return new Item_func_spatial_rel(a, b, Item_func::SP_TOUCHES_FUNC);
}
Item *create_func_crosses(Item *a, Item *b)
{
return new Item_func_spatial_rel(a, b, Item_func::SP_CROSSES_FUNC);
}
Item *create_func_within(Item *a, Item *b)
{
return new Item_func_spatial_rel(a, b, Item_func::SP_WITHIN_FUNC);
}
Item *create_func_contains(Item *a, Item *b)
{
return new Item_func_spatial_rel(a, b, Item_func::SP_CONTAINS_FUNC);
}
Item *create_func_overlaps(Item *a, Item *b)
{
return new Item_func_spatial_rel(a, b, Item_func::SP_OVERLAPS_FUNC);
}
Item *create_func_isempty(Item *a)
{
return new Item_func_isempty(a);
}
Item *create_func_issimple(Item *a)
{
return new Item_func_issimple(a);
}
Item *create_func_isclosed(Item *a)
{
return new Item_func_isclosed(a);
}
Item *create_func_geometry_type(Item *a)
{
return new Item_func_geometry_type(a);
}
Item *create_func_dimension(Item *a)
{
return new Item_func_dimension(a);
}
Item *create_func_x(Item *a)
{
return new Item_func_x(a);
}
Item *create_func_y(Item *a)
{
return new Item_func_y(a);
}
Item *create_func_numpoints(Item *a)
{
return new Item_func_numpoints(a);
}
Item *create_func_numinteriorring(Item *a)
{
return new Item_func_numinteriorring(a);
}
Item *create_func_numgeometries(Item *a)
{
return new Item_func_numgeometries(a);
}
Item *create_func_area(Item *a)
{
return new Item_func_area(a);
}
Item *create_func_glength(Item *a)
{
return new Item_func_glength(a);
}
Item *create_func_point(Item *a, Item *b)
{
return new Item_func_point(a, b);
}
#endif /*HAVE_SPATIAL*/
Item *create_func_crc32(Item* a)
{
return new Item_func_crc32(a);
}
Item *create_func_compress(Item* a)
{
return new Item_func_compress(a);
}
Item *create_func_uncompress(Item* a)
{
return new Item_func_uncompress(a);
}
Item *create_func_uncompressed_length(Item* a)
{
return new Item_func_uncompressed_length(a);
}
Item *create_func_datediff(Item *a, Item *b)
{
return new Item_func_minus(new Item_func_to_days(a),
new Item_func_to_days(b));
}
Item *create_func_weekofyear(Item *a)
{
return new Item_func_week(a, new Item_int((char*) "0", 3, 1));
}
Item *create_func_makedate(Item* a,Item* b)
{
return new Item_func_makedate(a, b);
}
Item *create_func_addtime(Item* a,Item* b)
{
return new Item_func_add_time(a, b, 0, 0);
}
Item *create_func_subtime(Item* a,Item* b)
{
return new Item_func_add_time(a, b, 0, 1);
}
Item *create_func_timediff(Item* a,Item* b)
{
return new Item_func_timediff(a, b);
}
Item *create_func_maketime(Item* a,Item* b,Item* c)
{
return new Item_func_maketime(a, b, c);
}
Item *create_func_str_to_date(Item* a,Item* b)
{
return new Item_func_str_to_date(a, b);
}
Item *create_func_last_day(Item *a)
{
return new Item_func_last_day(a);
}