diff options
author | unknown <evgen@moonbone.local> | 2007-03-10 19:53:59 +0300 |
---|---|---|
committer | unknown <evgen@moonbone.local> | 2007-03-10 19:53:59 +0300 |
commit | c0a0543545bc7b3e2ce9aec787452e7bd619f3d3 (patch) | |
tree | 2bd4a38243a497e5b2768e5e3860cb5c54de471e /sql/item.cc | |
parent | 4d6ad7ac60a0b4b0c5f38f7d415430553f74279b (diff) | |
parent | 944030aef7828911a38ed69d89709f778ca64d46 (diff) | |
download | mariadb-git-c0a0543545bc7b3e2ce9aec787452e7bd619f3d3.tar.gz |
Merge epotemkin@bk-internal.mysql.com:/home/bk/mysql-5.0-opt
into moonbone.local:/mnt/gentoo64/work/25373-bug-5.0-opt-mysql
mysql-test/r/func_str.result:
Auto merged
mysql-test/r/subselect.result:
Auto merged
mysql-test/r/union.result:
Auto merged
sql/item.cc:
Auto merged
Diffstat (limited to 'sql/item.cc')
-rw-r--r-- | sql/item.cc | 21 |
1 files changed, 19 insertions, 2 deletions
diff --git a/sql/item.cc b/sql/item.cc index d3850fb8c00..ec33bf1ddc7 100644 --- a/sql/item.cc +++ b/sql/item.cc @@ -1758,9 +1758,10 @@ void Item_ident::print(String *str) } } - if (!table_name || !field_name) + if (!table_name || !field_name || !field_name[0]) { - const char *nm= field_name ? field_name : name ? name : "tmp_field"; + const char *nm= (field_name && field_name[0]) ? + field_name : name ? name : "tmp_field"; append_identifier(thd, str, nm, (uint) strlen(nm)); return; } @@ -4916,6 +4917,22 @@ Item *Item_field::update_value_transformer(byte *select_arg) } +void Item_field::print(String *str) +{ + if (field && field->table->const_table) + { + char buff[MAX_FIELD_WIDTH]; + String tmp(buff,sizeof(buff),str->charset()); + field->val_str(&tmp); + str->append('\''); + str->append(tmp); + str->append('\''); + return; + } + Item_ident::print(str); +} + + Item_ref::Item_ref(Name_resolution_context *context_arg, Item **item, const char *table_name_arg, const char *field_name_arg, |