18
18
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
21
#ifdef USE_PRAGMA_IMPLEMENTATION
22
#pragma implementation // gcc: Class implementation
25
#include <drizzled/server_includes.h>
23
26
#include <drizzled/field/varstring.h>
24
#include <drizzled/table.h>
25
#include <drizzled/session.h>
26
#include "plugin/myisam/myisam.h"
35
28
/****************************************************************************
51
44
const uint32_t Field_varstring::MAX_SIZE= UINT16_MAX;
53
Field_varstring::Field_varstring(unsigned char *ptr_arg,
55
uint32_t length_bytes_arg,
56
unsigned char *null_ptr_arg,
57
unsigned char null_bit_arg,
58
const char *field_name_arg,
59
const CHARSET_INFO * const cs) :
65
length_bytes(length_bytes_arg)
69
Field_varstring::Field_varstring(uint32_t len_arg,
71
const char *field_name_arg,
72
const CHARSET_INFO * const cs) :
73
Field_str((unsigned char*) 0,
75
maybe_null_arg ? (unsigned char*) "": 0,
79
length_bytes(len_arg < 256 ? 1 :2)
47
Save the field metadata for varstring fields.
49
Saves the field length in the first byte. Note: may consume
50
2 bytes. Caller must ensure second byte is contiguous with
51
first byte (e.g. array index 0,1).
53
@param metadata_ptr First byte of field metadata
55
@returns number of bytes written to metadata_ptr
57
int Field_varstring::do_save_field_metadata(unsigned char *metadata_ptr)
59
char *ptr= (char *)metadata_ptr;
60
assert(field_length <= 65535);
61
int2store(ptr, field_length);
83
65
int Field_varstring::store(const char *from,uint32_t length, const CHARSET_INFO * const cs)
144
121
char *end_not_used;
147
ASSERT_COLUMN_MARKED_FOR_READ;
149
length= length_bytes == 1 ? (uint32_t) *ptr : uint2korr(ptr);
122
uint32_t length= length_bytes == 1 ? (uint) *ptr : uint2korr(ptr);
151
123
return my_strntoll(field_charset, (char*) ptr+length_bytes, length, 10,
152
124
&end_not_used, ¬_used);
155
String *Field_varstring::val_str(String *,
127
String *Field_varstring::val_str(String *val_buffer __attribute__((unused)),
158
uint32_t length= length_bytes == 1 ? (uint32_t) *ptr : uint2korr(ptr);
160
ASSERT_COLUMN_MARKED_FOR_READ;
130
uint32_t length= length_bytes == 1 ? (uint) *ptr : uint2korr(ptr);
162
131
val_ptr->set((const char*) ptr+length_bytes, length, field_charset);
168
136
my_decimal *Field_varstring::val_decimal(my_decimal *decimal_value)
172
ASSERT_COLUMN_MARKED_FOR_READ;
174
length= length_bytes == 1 ? (uint32_t) *ptr : uint2korr(ptr);
138
uint32_t length= length_bytes == 1 ? (uint) *ptr : uint2korr(ptr);
176
139
str2my_decimal(E_DEC_FATAL_ERROR, (char*) ptr+length_bytes, length,
177
140
charset(), decimal_value);
178
141
return decimal_value;
216
179
int Field_varstring::key_cmp(const unsigned char *key_ptr, uint32_t max_key_length)
218
uint32_t length= length_bytes == 1 ? (uint32_t) *ptr : uint2korr(ptr);
181
uint32_t length= length_bytes == 1 ? (uint) *ptr : uint2korr(ptr);
219
182
uint32_t local_char_length= max_key_length / field_charset->mbmaxlen;
221
184
local_char_length= my_charpos(field_charset, ptr + length_bytes,
222
ptr + length_bytes + length, local_char_length);
185
ptr + length_bytes + length, local_char_length);
223
186
set_if_smaller(length, local_char_length);
224
return field_charset->coll->strnncollsp(field_charset,
187
return field_charset->coll->strnncollsp(field_charset,
225
188
ptr + length_bytes,
262
225
mi_int2store(to+length-2, tot_length);
263
226
length-= length_bytes;
266
229
tot_length= my_strnxfrm(field_charset,
267
to, length, ptr + length_bytes,
230
to, length, ptr + length_bytes,
269
232
assert(tot_length == length);
298
Field_varstring::pack_key(unsigned char *to, const unsigned char *key, uint32_t max_length,
299
bool low_byte_first __attribute__((unused)))
301
uint32_t length= length_bytes == 1 ? (uint) *key : uint2korr(key);
302
uint32_t local_char_length= ((field_charset->mbmaxlen > 1) ?
303
max_length/field_charset->mbmaxlen : max_length);
305
if (length > local_char_length)
307
local_char_length= my_charpos(field_charset, key, key+length,
309
set_if_smaller(length, local_char_length);
311
*to++= (char) (length & 255);
312
if (max_length > 255)
313
*to++= (char) (length >> 8);
315
memcpy(to, key, length);
321
Unpack a key into a record buffer.
323
A VARCHAR key has a maximum size of 64K-1.
324
In its packed form, the length field is one or two bytes long,
325
depending on 'max_length'.
327
@param to Pointer into the record buffer.
328
@param key Pointer to the packed key.
329
@param max_length Key length limit from key description.
332
Pointer to end of 'key' (To the next key part if multi-segment key)
335
const unsigned char *
336
Field_varstring::unpack_key(unsigned char *to __attribute__((unused)),
337
const unsigned char *key, uint32_t max_length,
338
bool low_byte_first __attribute__((unused)))
340
/* get length of the blob key */
341
uint32_t length= *key++;
342
if (max_length > 255)
343
length+= (*key++) << 8;
345
/* put the length into the record buffer */
346
if (length_bytes == 1)
347
*ptr= (unsigned char) length;
349
int2store(ptr, length);
350
memcpy(ptr + length_bytes, key, length);
355
Create a packed key that will be used for storage in the index tree.
357
@param to Store packed key segment here
358
@param from Key segment (as given to index_read())
359
@param max_length Max length of key
366
Field_varstring::pack_key_from_key_image(unsigned char *to, const unsigned char *from, uint32_t max_length,
367
bool low_byte_first __attribute__((unused)))
369
/* Key length is always stored as 2 bytes */
370
uint32_t length= uint2korr(from);
371
if (length > max_length)
373
*to++= (char) (length & 255);
374
if (max_length > 255)
375
*to++= (char) (length >> 8);
377
memcpy(to, from+HA_KEY_BLOB_LENGTH, length);
330
383
Unpack a varstring field from row data.
424
int Field_varstring::pack_cmp(const unsigned char *a, const unsigned char *b,
425
uint32_t key_length_arg,
426
bool insert_or_update)
428
uint32_t a_length, b_length;
429
if (key_length_arg > 255)
431
a_length=uint2korr(a); a+= 2;
432
b_length=uint2korr(b); b+= 2;
436
a_length= (uint) *a++;
437
b_length= (uint) *b++;
439
return field_charset->coll->strnncollsp(field_charset,
446
int Field_varstring::pack_cmp(const unsigned char *b, uint32_t key_length_arg,
447
bool insert_or_update)
449
unsigned char *a= ptr+ length_bytes;
450
uint32_t a_length= length_bytes == 1 ? (uint) *ptr : uint2korr(ptr);
452
uint32_t local_char_length= ((field_charset->mbmaxlen > 1) ?
453
key_length_arg / field_charset->mbmaxlen :
456
if (key_length_arg > 255)
458
b_length=uint2korr(b); b+= HA_KEY_BLOB_LENGTH;
461
b_length= (uint) *b++;
463
if (a_length > local_char_length)
465
local_char_length= my_charpos(field_charset, a, a+a_length,
467
set_if_smaller(a_length, local_char_length);
470
return field_charset->coll->strnncollsp(field_charset,
477
uint32_t Field_varstring::packed_col_length(const unsigned char *data_ptr, uint32_t length)
480
return uint2korr(data_ptr)+2;
481
return (uint) *data_ptr + 1;
371
485
uint32_t Field_varstring::max_packed_col_length(uint32_t max_length)
373
487
return (max_length > 255 ? 2 : 1)+max_length;
376
uint32_t Field_varstring::get_key_image(basic_string<unsigned char> &buff, uint32_t length)
378
/* Key is always stored with 2 bytes */
379
const uint32_t key_len= 2;
380
uint32_t f_length= length_bytes == 1 ? (uint32_t) *ptr : uint2korr(ptr);
381
uint32_t local_char_length= length / field_charset->mbmaxlen;
382
unsigned char *pos= ptr+length_bytes;
383
local_char_length= my_charpos(field_charset, pos, pos + f_length,
385
set_if_smaller(f_length, local_char_length);
386
unsigned char len_buff[key_len];
387
int2store(len_buff,f_length);
388
buff.append(len_buff);
389
buff.append(pos, f_length);
390
if (f_length < length)
393
Must clear this as we do a memcmp in optimizer/range.cc to detect
396
buff.append(length-f_length, 0);
398
return key_len+f_length;
402
uint32_t Field_varstring::get_key_image(unsigned char *buff, uint32_t length)
404
uint32_t f_length= length_bytes == 1 ? (uint32_t) *ptr : uint2korr(ptr);
490
uint32_t Field_varstring::get_key_image(unsigned char *buff,
492
imagetype type __attribute__((unused)))
494
uint32_t f_length= length_bytes == 1 ? (uint) *ptr : uint2korr(ptr);
405
495
uint32_t local_char_length= length / field_charset->mbmaxlen;
406
496
unsigned char *pos= ptr+length_bytes;
407
497
local_char_length= my_charpos(field_charset, pos, pos + f_length,
421
511
return HA_KEY_BLOB_LENGTH+f_length;
424
void Field_varstring::set_key_image(const unsigned char *buff, uint32_t length)
515
void Field_varstring::set_key_image(const unsigned char *buff,uint32_t length)
426
517
length= uint2korr(buff); // Real length is here
427
(void) Field_varstring::store((const char*) buff+HA_KEY_BLOB_LENGTH, length, field_charset);
518
(void) Field_varstring::store((const char*) buff+HA_KEY_BLOB_LENGTH, length,
430
int Field_varstring::cmp_binary(const unsigned char *a_ptr,
431
const unsigned char *b_ptr,
523
int Field_varstring::cmp_binary(const unsigned char *a_ptr, const unsigned char *b_ptr,
432
524
uint32_t max_length)
434
526
uint32_t a_length,b_length;
436
528
if (length_bytes == 1)
438
a_length= (uint32_t) *a_ptr;
439
b_length= (uint32_t) *b_ptr;
530
a_length= (uint) *a_ptr;
531
b_length= (uint) *b_ptr;
482
} /* namespace drizzled */
575
uint32_t Field_varstring::is_equal(Create_field *new_field)
577
if (new_field->sql_type == real_type() &&
578
new_field->charset == field_charset)
580
if (new_field->length == max_display_length())
582
if (new_field->length > max_display_length() &&
583
((new_field->length <= 255 && max_display_length() <= 255) ||
584
(new_field->length > 255 && max_display_length() > 255)))
585
return IS_EQUAL_PACK_LENGTH; // VARCHAR, longer variable length
591
void Field_varstring::hash(uint32_t *nr, uint32_t *nr2)
595
*nr^= (*nr << 1) | 1;
599
uint32_t len= length_bytes == 1 ? (uint) *ptr : uint2korr(ptr);
600
const CHARSET_INFO * const cs= charset();
601
cs->coll->hash_sort(cs, ptr + length_bytes, len, nr, nr2);