mirror of
https://github.com/MariaDB/server.git
synced 2025-07-29 05:21:33 +03:00
Fix for MyISAM records > 16M
Docs/manual.texi: ChangeLog innobase/os/os0file.c: Removed compiler warnings myisam/mi_check.c: Fix for records > 16M myisam/mi_dynrec.c: Fix for records > 16M myisam/myisamdef.h: Fix for records > 16M sql/sql_select.cc: Cleanup sql/sql_yacc.yy: F
This commit is contained in:
@ -46167,6 +46167,9 @@ Our TODO section contains what we plan to have in 4.0. @xref{TODO MySQL 4.0}.
|
|||||||
|
|
||||||
@itemize @bullet
|
@itemize @bullet
|
||||||
@item
|
@item
|
||||||
|
Changed @code{SELECT ... IN SHARE MODE} to
|
||||||
|
@code{SELECT .. LOCK IN SHARE MODE} (as in MySQL 3.23).
|
||||||
|
@item
|
||||||
A new query cache to cache results from identical @code{SELECT} queries.
|
A new query cache to cache results from identical @code{SELECT} queries.
|
||||||
@item
|
@item
|
||||||
Fixed core dump bug on 64 bit machines when it got a wrong communication
|
Fixed core dump bug on 64 bit machines when it got a wrong communication
|
||||||
|
@ -457,14 +457,13 @@ os_file_get_size(
|
|||||||
|
|
||||||
offs = lseek(file, 0, SEEK_END);
|
offs = lseek(file, 0, SEEK_END);
|
||||||
|
|
||||||
if (sizeof(off_t) > 4) {
|
#if SIZEOF_OFF_T > 4
|
||||||
*size = (ulint)(offs & 0xFFFFFFFF);
|
*size = (ulint)(offs & 0xFFFFFFFF);
|
||||||
*size_high = (ulint)(offs >> 32);
|
*size_high = (ulint)(offs >> 32);
|
||||||
} else {
|
#else
|
||||||
*size = (ulint) offs;
|
*size = (ulint) offs;
|
||||||
*size_high = 0;
|
*size_high = 0;
|
||||||
}
|
#endif
|
||||||
|
|
||||||
return(TRUE);
|
return(TRUE);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
@ -614,18 +613,16 @@ os_file_pread(
|
|||||||
/* If off_t is > 4 bytes in size, then we assume we can pass a
|
/* If off_t is > 4 bytes in size, then we assume we can pass a
|
||||||
64-bit address */
|
64-bit address */
|
||||||
|
|
||||||
if (sizeof(off_t) > 4) {
|
#if SIZEOF_OFF_T > 4
|
||||||
offs = (off_t)offset + (((off_t)offset_high) << 32);
|
offs = (off_t)offset + (((off_t)offset_high) << 32);
|
||||||
|
#else
|
||||||
} else {
|
offs = (off_t)offset;
|
||||||
offs = (off_t)offset;
|
|
||||||
|
|
||||||
if (offset_high > 0) {
|
if (offset_high > 0) {
|
||||||
fprintf(stderr,
|
fprintf(stderr,
|
||||||
"InnoDB: Error: file read at offset > 4 GB\n");
|
"InnoDB: Error: file read at offset > 4 GB\n");
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
os_n_file_reads++;
|
os_n_file_reads++;
|
||||||
|
|
||||||
#ifdef HAVE_PREAD
|
#ifdef HAVE_PREAD
|
||||||
|
@ -1288,8 +1288,6 @@ int mi_repair(MI_CHECK *param, register MI_INFO *info,
|
|||||||
my_close(info->dfile,MYF(0));
|
my_close(info->dfile,MYF(0));
|
||||||
info->dfile=new_file;
|
info->dfile=new_file;
|
||||||
info->state->data_file_length=sort_info->filepos;
|
info->state->data_file_length=sort_info->filepos;
|
||||||
/* Only whole records */
|
|
||||||
share->state.split=info->state->records+info->state->del;
|
|
||||||
share->state.version=(ulong) time((time_t*) 0); /* Force reopen */
|
share->state.version=(ulong) time((time_t*) 0); /* Force reopen */
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@ -1962,7 +1960,6 @@ int mi_repair_by_sort(MI_CHECK *param, register MI_INFO *info,
|
|||||||
share->state.state.data_file_length = info->state->data_file_length
|
share->state.state.data_file_length = info->state->data_file_length
|
||||||
= sort_info->filepos;
|
= sort_info->filepos;
|
||||||
/* Only whole records */
|
/* Only whole records */
|
||||||
share->state.split=info->state->records+info->state->del;
|
|
||||||
share->state.version=(ulong) time((time_t*) 0);
|
share->state.version=(ulong) time((time_t*) 0);
|
||||||
my_close(info->dfile,MYF(0));
|
my_close(info->dfile,MYF(0));
|
||||||
info->dfile=new_file;
|
info->dfile=new_file;
|
||||||
@ -2183,9 +2180,11 @@ static int sort_get_next_record(SORT_INFO *sort_info)
|
|||||||
}
|
}
|
||||||
sort_info->start_recpos=sort_info->pos;
|
sort_info->start_recpos=sort_info->pos;
|
||||||
if (!sort_info->fix_datafile)
|
if (!sort_info->fix_datafile)
|
||||||
|
{
|
||||||
sort_info->filepos=sort_info->pos;
|
sort_info->filepos=sort_info->pos;
|
||||||
|
share->state.split++;
|
||||||
|
}
|
||||||
sort_info->max_pos=(sort_info->pos+=share->base.pack_reclength);
|
sort_info->max_pos=(sort_info->pos+=share->base.pack_reclength);
|
||||||
share->state.split++;
|
|
||||||
if (*sort_info->record)
|
if (*sort_info->record)
|
||||||
{
|
{
|
||||||
if (param->calc_checksum)
|
if (param->calc_checksum)
|
||||||
@ -2356,7 +2355,8 @@ static int sort_get_next_record(SORT_INFO *sort_info)
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
share->state.split++;
|
if (!sort_info->fix_datafile && (b_type & BLOCK_DELETED))
|
||||||
|
share->state.split++;
|
||||||
if (! found_record++)
|
if (! found_record++)
|
||||||
{
|
{
|
||||||
sort_info->find_length=left_length=block_info.rec_len;
|
sort_info->find_length=left_length=block_info.rec_len;
|
||||||
@ -2494,10 +2494,12 @@ static int sort_get_next_record(SORT_INFO *sort_info)
|
|||||||
}
|
}
|
||||||
info->checksum=mi_checksum(info,sort_info->record);
|
info->checksum=mi_checksum(info,sort_info->record);
|
||||||
if (!sort_info->fix_datafile)
|
if (!sort_info->fix_datafile)
|
||||||
|
{
|
||||||
sort_info->filepos=sort_info->pos;
|
sort_info->filepos=sort_info->pos;
|
||||||
|
share->state.split++;
|
||||||
|
}
|
||||||
sort_info->max_pos=(sort_info->pos=block_info.filepos+
|
sort_info->max_pos=(sort_info->pos=block_info.filepos+
|
||||||
block_info.rec_len);
|
block_info.rec_len);
|
||||||
share->state.split++;
|
|
||||||
info->packed_length=block_info.rec_len;
|
info->packed_length=block_info.rec_len;
|
||||||
if (param->calc_checksum)
|
if (param->calc_checksum)
|
||||||
param->glob_crc+= info->checksum;
|
param->glob_crc+= info->checksum;
|
||||||
@ -2535,6 +2537,7 @@ int sort_write_record(SORT_INFO *sort_info)
|
|||||||
DBUG_RETURN(1);
|
DBUG_RETURN(1);
|
||||||
}
|
}
|
||||||
sort_info->filepos+=share->base.pack_reclength;
|
sort_info->filepos+=share->base.pack_reclength;
|
||||||
|
info->s->state.split++;
|
||||||
/* sort_info->param->glob_crc+=mi_static_checksum(info, sort_info->record); */
|
/* sort_info->param->glob_crc+=mi_static_checksum(info, sort_info->record); */
|
||||||
break;
|
break;
|
||||||
case DYNAMIC_RECORD:
|
case DYNAMIC_RECORD:
|
||||||
@ -2559,20 +2562,28 @@ int sort_write_record(SORT_INFO *sort_info)
|
|||||||
}
|
}
|
||||||
info->checksum=mi_checksum(info,sort_info->record);
|
info->checksum=mi_checksum(info,sort_info->record);
|
||||||
reclength=_mi_rec_pack(info,from,sort_info->record);
|
reclength=_mi_rec_pack(info,from,sort_info->record);
|
||||||
/* sort_info->param->glob_crc+=info->checksum; */
|
|
||||||
block_length=reclength+ 3 + test(reclength >= (65520-3));
|
|
||||||
if (block_length < share->base.min_block_length)
|
|
||||||
block_length=share->base.min_block_length;
|
|
||||||
flag=0;
|
flag=0;
|
||||||
info->update|=HA_STATE_WRITE_AT_END;
|
/* sort_info->param->glob_crc+=info->checksum; */
|
||||||
block_length=MY_ALIGN(block_length,MI_DYN_ALIGN_SIZE);
|
|
||||||
if (_mi_write_part_record(info,0L,block_length,HA_OFFSET_ERROR,
|
do
|
||||||
&from,&reclength,&flag))
|
|
||||||
{
|
{
|
||||||
mi_check_print_error(param,"%d when writing to datafile",my_errno);
|
block_length=reclength+ 3 + test(reclength >= (65520-3));
|
||||||
DBUG_RETURN(1);
|
if (block_length < share->base.min_block_length)
|
||||||
}
|
block_length=share->base.min_block_length;
|
||||||
sort_info->filepos+=block_length;
|
info->update|=HA_STATE_WRITE_AT_END;
|
||||||
|
block_length=MY_ALIGN(block_length,MI_DYN_ALIGN_SIZE);
|
||||||
|
if (block_length > MI_MAX_BLOCK_LENGTH)
|
||||||
|
block_length=MI_MAX_BLOCK_LENGTH;
|
||||||
|
if (_mi_write_part_record(info,0L,block_length,
|
||||||
|
sort_info->filepos+block_length,
|
||||||
|
&from,&reclength,&flag))
|
||||||
|
{
|
||||||
|
mi_check_print_error(param,"%d when writing to datafile",my_errno);
|
||||||
|
DBUG_RETURN(1);
|
||||||
|
}
|
||||||
|
sort_info->filepos+=block_length;
|
||||||
|
info->s->state.split++;
|
||||||
|
} while (reclength);
|
||||||
/* sort_info->param->glob_crc+=info->checksum; */
|
/* sort_info->param->glob_crc+=info->checksum; */
|
||||||
break;
|
break;
|
||||||
case COMPRESSED_RECORD:
|
case COMPRESSED_RECORD:
|
||||||
@ -2588,6 +2599,7 @@ int sort_write_record(SORT_INFO *sort_info)
|
|||||||
}
|
}
|
||||||
/* sort_info->param->glob_crc+=info->checksum; */
|
/* sort_info->param->glob_crc+=info->checksum; */
|
||||||
sort_info->filepos+=reclength+length;
|
sort_info->filepos+=reclength+length;
|
||||||
|
info->s->state.split++;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -64,11 +64,13 @@ int _mi_write_blob_record(MI_INFO *info, const byte *record)
|
|||||||
MI_DYN_DELETE_BLOCK_HEADER+1;
|
MI_DYN_DELETE_BLOCK_HEADER+1;
|
||||||
reclength=info->s->base.pack_reclength+
|
reclength=info->s->base.pack_reclength+
|
||||||
_my_calc_total_blob_length(info,record)+ extra;
|
_my_calc_total_blob_length(info,record)+ extra;
|
||||||
|
#ifdef NOT_USED /* We now support big rows */
|
||||||
if (reclength > MI_DYN_MAX_ROW_LENGTH)
|
if (reclength > MI_DYN_MAX_ROW_LENGTH)
|
||||||
{
|
{
|
||||||
my_errno=HA_ERR_TO_BIG_ROW;
|
my_errno=HA_ERR_TO_BIG_ROW;
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
if (!(rec_buff=(byte*) my_alloca(reclength)))
|
if (!(rec_buff=(byte*) my_alloca(reclength)))
|
||||||
{
|
{
|
||||||
my_errno=ENOMEM;
|
my_errno=ENOMEM;
|
||||||
@ -93,11 +95,13 @@ int _mi_update_blob_record(MI_INFO *info, my_off_t pos, const byte *record)
|
|||||||
MI_DYN_DELETE_BLOCK_HEADER;
|
MI_DYN_DELETE_BLOCK_HEADER;
|
||||||
reclength=info->s->base.pack_reclength+
|
reclength=info->s->base.pack_reclength+
|
||||||
_my_calc_total_blob_length(info,record)+ extra;
|
_my_calc_total_blob_length(info,record)+ extra;
|
||||||
|
#ifdef NOT_USED /* We now support big rows */
|
||||||
if (reclength > MI_DYN_MAX_ROW_LENGTH)
|
if (reclength > MI_DYN_MAX_ROW_LENGTH)
|
||||||
{
|
{
|
||||||
my_errno=HA_ERR_TO_BIG_ROW;
|
my_errno=HA_ERR_TO_BIG_ROW;
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
if (!(rec_buff=(byte*) my_alloca(reclength)))
|
if (!(rec_buff=(byte*) my_alloca(reclength)))
|
||||||
{
|
{
|
||||||
my_errno=ENOMEM;
|
my_errno=ENOMEM;
|
||||||
@ -130,14 +134,14 @@ static int write_dynamic_record(MI_INFO *info, const byte *record,
|
|||||||
DBUG_ENTER("write_dynamic_record");
|
DBUG_ENTER("write_dynamic_record");
|
||||||
|
|
||||||
flag=0;
|
flag=0;
|
||||||
while (reclength)
|
do
|
||||||
{
|
{
|
||||||
if (_mi_find_writepos(info,reclength,&filepos,&length))
|
if (_mi_find_writepos(info,reclength,&filepos,&length))
|
||||||
goto err;
|
goto err;
|
||||||
if (_mi_write_part_record(info,filepos,length,info->s->state.dellink,
|
if (_mi_write_part_record(info,filepos,length,info->s->state.dellink,
|
||||||
(byte**) &record,&reclength,&flag))
|
(byte**) &record,&reclength,&flag))
|
||||||
goto err;
|
goto err;
|
||||||
}
|
} while (reclength);
|
||||||
|
|
||||||
DBUG_RETURN(0);
|
DBUG_RETURN(0);
|
||||||
err:
|
err:
|
||||||
@ -377,7 +381,7 @@ int _mi_write_part_record(MI_INFO *info,
|
|||||||
head_length= 16;
|
head_length= 16;
|
||||||
temp[0]=13;
|
temp[0]=13;
|
||||||
mi_int4store(temp+1,*reclength);
|
mi_int4store(temp+1,*reclength);
|
||||||
mi_int3store(temp+4,length-head_length);
|
mi_int3store(temp+5,length-head_length);
|
||||||
mi_sizestore((byte*) temp+8,next_filepos);
|
mi_sizestore((byte*) temp+8,next_filepos);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@ -1441,7 +1445,7 @@ uint _mi_get_block_info(MI_BLOCK_INFO *info, File file, my_off_t filepos)
|
|||||||
DBUG_DUMP("header",(byte*) header,MI_BLOCK_INFO_HEADER_LENGTH);
|
DBUG_DUMP("header",(byte*) header,MI_BLOCK_INFO_HEADER_LENGTH);
|
||||||
if (info->second_read)
|
if (info->second_read)
|
||||||
{
|
{
|
||||||
if (info->header[0] <= 6)
|
if (info->header[0] <= 6 || info->header[0] == 13)
|
||||||
return_val=BLOCK_SYNC_ERROR;
|
return_val=BLOCK_SYNC_ERROR;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -359,7 +359,7 @@ struct st_myisam_info {
|
|||||||
#define MI_DYN_MAX_ROW_LENGTH (MI_DYN_MAX_BLOCK_LENGTH - MI_SPLIT_LENGTH)
|
#define MI_DYN_MAX_ROW_LENGTH (MI_DYN_MAX_BLOCK_LENGTH - MI_SPLIT_LENGTH)
|
||||||
#define MI_DYN_ALIGN_SIZE 4 /* Align blocks on this */
|
#define MI_DYN_ALIGN_SIZE 4 /* Align blocks on this */
|
||||||
#define MI_MAX_DYN_HEADER_BYTE 13 /* max header byte for dynamic rows */
|
#define MI_MAX_DYN_HEADER_BYTE 13 /* max header byte for dynamic rows */
|
||||||
#define MI_MAX_BLOCK_LENGTH (((ulong) 1 << 24)-1)
|
#define MI_MAX_BLOCK_LENGTH ((((ulong) 1 << 24)-1) & (~ (ulong) (MI_DYN_ALIGN_SIZE-1)))
|
||||||
|
|
||||||
#define MEMMAP_EXTRA_MARGIN 7 /* Write this as a suffix for file */
|
#define MEMMAP_EXTRA_MARGIN 7 /* Write this as a suffix for file */
|
||||||
|
|
||||||
|
@ -480,7 +480,9 @@ mysql_select(THD *thd,TABLE_LIST *tables,List<Item> &fields,COND *conds,
|
|||||||
(thd->select_limit == HA_POS_ERROR ||
|
(thd->select_limit == HA_POS_ERROR ||
|
||||||
(join.select_options & OPTION_FOUND_ROWS) ||
|
(join.select_options & OPTION_FOUND_ROWS) ||
|
||||||
order &&
|
order &&
|
||||||
!(skip_sort_order=test_if_skip_sort_order(&join.join_tab[join.const_tables], order, thd->select_limit,1))))
|
!(skip_sort_order=
|
||||||
|
test_if_skip_sort_order(&join.join_tab[join.const_tables],
|
||||||
|
order, thd->select_limit,1))))
|
||||||
{
|
{
|
||||||
if ((group=create_distinct_group(order,fields)))
|
if ((group=create_distinct_group(order,fields)))
|
||||||
{
|
{
|
||||||
@ -5272,13 +5274,6 @@ static uint find_shortest_key(TABLE *table, key_map usable_keys)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/*****************************************************************************
|
|
||||||
** If not selecting by given key, create an index how records should be read
|
|
||||||
** return: 0 ok
|
|
||||||
** -1 some fatal error
|
|
||||||
** 1 no records
|
|
||||||
*****************************************************************************/
|
|
||||||
|
|
||||||
/* Return 1 if we don't have to do file sorting */
|
/* Return 1 if we don't have to do file sorting */
|
||||||
|
|
||||||
static bool
|
static bool
|
||||||
@ -5391,6 +5386,14 @@ test_if_skip_sort_order(JOIN_TAB *tab,ORDER *order,ha_rows select_limit,
|
|||||||
DBUG_RETURN(0); // Can't use index.
|
DBUG_RETURN(0); // Can't use index.
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*****************************************************************************
|
||||||
|
If not selecting by given key, create an index how records should be read
|
||||||
|
return: 0 ok
|
||||||
|
-1 some fatal error
|
||||||
|
1 no records
|
||||||
|
*****************************************************************************/
|
||||||
|
|
||||||
static int
|
static int
|
||||||
create_sort_index(JOIN_TAB *tab,ORDER *order,ha_rows select_limit)
|
create_sort_index(JOIN_TAB *tab,ORDER *order,ha_rows select_limit)
|
||||||
{
|
{
|
||||||
|
@ -1394,7 +1394,7 @@ select_lock_type:
|
|||||||
/* empty */
|
/* empty */
|
||||||
| FOR_SYM UPDATE_SYM
|
| FOR_SYM UPDATE_SYM
|
||||||
{ Lex->lock_option= TL_WRITE; current_thd->safe_to_cache_query=0; }
|
{ Lex->lock_option= TL_WRITE; current_thd->safe_to_cache_query=0; }
|
||||||
| IN_SYM SHARE_SYM MODE_SYM
|
| LOCK_SYM IN_SYM SHARE_SYM MODE_SYM
|
||||||
{ Lex->lock_option= TL_READ_WITH_SHARED_LOCKS; current_thd->safe_to_cache_query=0; }
|
{ Lex->lock_option= TL_READ_WITH_SHARED_LOCKS; current_thd->safe_to_cache_query=0; }
|
||||||
|
|
||||||
select_item_list:
|
select_item_list:
|
||||||
|
72
tests/myisam-big-rows.tst
Normal file
72
tests/myisam-big-rows.tst
Normal file
@ -0,0 +1,72 @@
|
|||||||
|
#
|
||||||
|
# Test rows with length above > 16M
|
||||||
|
# Note that for this to work, you should start mysqld with
|
||||||
|
# -O max_allowed_packet=32M
|
||||||
|
#
|
||||||
|
|
||||||
|
drop table if exists t1;
|
||||||
|
create table t1 (a tinyint not null auto_increment, b longblob not null, primary key (a)) checksum=1;
|
||||||
|
|
||||||
|
insert into t1 (b) values(repeat(char(65),10));
|
||||||
|
insert into t1 (b) values(repeat(char(66),10));
|
||||||
|
insert into t1 (b) values(repeat(char(67),10));
|
||||||
|
update t1 set b=repeat(char(68),16777216) where a=1;
|
||||||
|
check table t1;
|
||||||
|
update t1 set b=repeat(char(69),16777000) where a=2;
|
||||||
|
update t1 set b=repeat(char(70),167) where a=3;
|
||||||
|
update t1 set b=repeat(char(71),16778000) where a=1;
|
||||||
|
update t1 set b=repeat(char(72),16778000) where a=3;
|
||||||
|
select a,length(b) from t1;
|
||||||
|
set @a=1;
|
||||||
|
insert into t1 (b) values (repeat(char(73+@a),16777200+@a));
|
||||||
|
set @a=@a+1;
|
||||||
|
insert into t1 (b) values (repeat(char(73+@a),16777200+@a));
|
||||||
|
set @a=@a+1;
|
||||||
|
insert into t1 (b) values (repeat(char(73+@a),16777200+@a));
|
||||||
|
set @a=@a+1;
|
||||||
|
insert into t1 (b) values (repeat(char(73+@a),16777200+@a));
|
||||||
|
set @a=@a+1;
|
||||||
|
insert into t1 (b) values (repeat(char(73+@a),16777200+@a));
|
||||||
|
set @a=@a+1;
|
||||||
|
insert into t1 (b) values (repeat(char(73+@a),16777200+@a));
|
||||||
|
set @a=@a+1;
|
||||||
|
insert into t1 (b) values (repeat(char(73+@a),16777200+@a));
|
||||||
|
set @a=@a+1;
|
||||||
|
insert into t1 (b) values (repeat(char(73+@a),16777200+@a));
|
||||||
|
set @a=@a+1;
|
||||||
|
insert into t1 (b) values (repeat(char(73+@a),16777200+@a));
|
||||||
|
set @a=@a+1;
|
||||||
|
insert into t1 (b) values (repeat(char(73+@a),16777200+@a));
|
||||||
|
set @a=@a+1;
|
||||||
|
insert into t1 (b) values (repeat(char(73+@a),16777200+@a));
|
||||||
|
set @a=@a+1;
|
||||||
|
insert into t1 (b) values (repeat(char(73+@a),16777200+@a));
|
||||||
|
set @a=@a+1;
|
||||||
|
insert into t1 (b) values (repeat(char(73+@a),16777200+@a));
|
||||||
|
set @a=@a+1;
|
||||||
|
insert into t1 (b) values (repeat(char(73+@a),16777200+@a));
|
||||||
|
set @a=@a+1;
|
||||||
|
insert into t1 (b) values (repeat(char(73+@a),16777200+@a));
|
||||||
|
set @a=@a+1;
|
||||||
|
insert into t1 (b) values (repeat(char(73+@a),16777200+@a));
|
||||||
|
set @a=@a+1;
|
||||||
|
insert into t1 (b) values (repeat(char(73+@a),16777200+@a));
|
||||||
|
set @a=@a+1;
|
||||||
|
insert into t1 (b) values (repeat(char(73+@a),16777200+@a));
|
||||||
|
update t1 set b=('A') where a=5;
|
||||||
|
delete from t1 where a=7;
|
||||||
|
set @a=@a+1;
|
||||||
|
insert into t1 (b) values (repeat(char(73+@a),16777200+@a));
|
||||||
|
update t1 set b=repeat(char(73+@a+1),17000000+@a) where a=last_insert_id();
|
||||||
|
|
||||||
|
select a,mid(b,1,5),length(b) from t1;
|
||||||
|
check table t1;
|
||||||
|
repair table t1;
|
||||||
|
check table t1;
|
||||||
|
select a from table where b<>repeat(mid(b,1,1),length(b));
|
||||||
|
delete from t1 where (a & 1);
|
||||||
|
select a from table where b<>repeat(mid(b,1,1),length(b));
|
||||||
|
check table t1;
|
||||||
|
repair table t1;
|
||||||
|
check table t1;
|
||||||
|
drop table t1;
|
Reference in New Issue
Block a user