You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

824 lines
25 KiB
SQL

/**
ATTENTION!!!
Please make sure to create a backup of your live data before running this update.
This update is rather complicated and although I have tried my best I cannot guarantee that I did not make any mistake. [Lemongrass]
We would also advise you to check the data in the temporary table after the insert statement and before the update statements.
You could do so by running
select * from `tmp_randomoptionfix` where `new_index` <> `old_index`;
to see where changes happen and options will be moved.
For executing this update your user needs create table and drop table permissions. Either run the update with another user [admin or root for example] or give your database user these permissions temporarily.
Do not forget to remove these permissions again, as they are usually not necessary and it is rather dangerous, if someone gets access to your database user.
Additionally if you have more than one storage table (see conf/inter_server.yml) make sure to also update those tables (see instructions at the bottom of this script).
Comment the line below to really run the script, this is a safeguard that you confirm you have read and understood what was written above.
**/
cancel;
-- Create a temporary table to store the data for the update
create table `tmp_randomoptionfix` (
`id` int(11) unsigned NOT NULL,
`new_index` smallint(5) NOT NULL,
`old_index` smallint(5) NOT NULL,
`option_id` smallint(5) NOT NULL,
`option_val` smallint(5) NOT NULL,
`option_parm` tinyint(3) NOT NULL,
PRIMARY KEY ( `id`, `old_index` )
);
-- Create auction data
insert into `tmp_randomoptionfix` ( `id`, `new_index`, `old_index`, `option_id`, `option_val`, `option_parm` )
select
`id`,
row_number() over( partition by `id` order by `old_index` asc ) - 1 as `new_index`,
`old_index`,
`option_id`,
`option_val`,
`option_parm`
from (
select * from (
select
`auction_id` as `id`,
0 as `old_index`,
`option_id0` as `option_id`,
`option_val0` as `option_val`,
`option_parm0` as `option_parm`
from `auction`
where `option_id0` <> 0
union
select
`auction_id` as `id`,
1 as `old_index`,
`option_id1` as `option_id`,
`option_val1` as `option_val`,
`option_parm1` as `option_parm`
from `auction`
where `option_id1` <> 0
union
select
`auction_id` as `id`,
2 as `old_index`,
`option_id2` as `option_id`,
`option_val2` as `option_val`,
`option_parm2` as `option_parm`
from `auction`
where `option_id2` <> 0
union
select
`auction_id` as `id`,
3 as `old_index`,
`option_id3` as `option_id`,
`option_val3` as `option_val`,
`option_parm3` as `option_parm`
from `auction`
where `option_id3` <> 0
union
select
`auction_id` as `id`,
4 as `old_index`,
`option_id4` as `option_id`,
`option_val4` as `option_val`,
`option_parm4` as `option_parm`
from `auction`
where `option_id4` <> 0
) t2
order by `id`, `old_index`
) t ;
-- Fix option 0
update `auction`
left join `tmp_randomoptionfix`
on `auction`.`auction_id` = `tmp_randomoptionfix`.`id` and `tmp_randomoptionfix`.`new_index` = 0
set
`option_id0` = coalesce( `tmp_randomoptionfix`.`option_id`, 0 ),
`option_val0` = coalesce( `tmp_randomoptionfix`.`option_val`, 0 ),
`option_parm0` = coalesce( `tmp_randomoptionfix`.`option_parm`, 0 )
;
-- Fix option 1
update `auction`
left join `tmp_randomoptionfix`
on `auction`.`auction_id` = `tmp_randomoptionfix`.`id` and `tmp_randomoptionfix`.`new_index` = 1
set
`option_id1` = coalesce( `tmp_randomoptionfix`.`option_id`, 0 ),
`option_val1` = coalesce( `tmp_randomoptionfix`.`option_val`, 0 ),
`option_parm1` = coalesce( `tmp_randomoptionfix`.`option_parm`, 0 )
;
-- Fix option 2
update `auction`
left join `tmp_randomoptionfix`
on `auction`.`auction_id` = `tmp_randomoptionfix`.`id` and `tmp_randomoptionfix`.`new_index` = 2
set
`option_id2` = coalesce( `tmp_randomoptionfix`.`option_id`, 0 ),
`option_val2` = coalesce( `tmp_randomoptionfix`.`option_val`, 0 ),
`option_parm2` = coalesce( `tmp_randomoptionfix`.`option_parm`, 0 )
;
-- Fix option 3
update `auction`
left join `tmp_randomoptionfix`
on `auction`.`auction_id` = `tmp_randomoptionfix`.`id` and `tmp_randomoptionfix`.`new_index` = 3
set
`option_id3` = coalesce( `tmp_randomoptionfix`.`option_id`, 0 ),
`option_val3` = coalesce( `tmp_randomoptionfix`.`option_val`, 0 ),
`option_parm3` = coalesce( `tmp_randomoptionfix`.`option_parm`, 0 )
;
-- Fix option 4
update `auction`
left join `tmp_randomoptionfix`
on `auction`.`auction_id` = `tmp_randomoptionfix`.`id` and `tmp_randomoptionfix`.`new_index` = 4
set
`option_id4` = coalesce( `tmp_randomoptionfix`.`option_id`, 0 ),
`option_val4` = coalesce( `tmp_randomoptionfix`.`option_val`, 0 ),
`option_parm4` = coalesce( `tmp_randomoptionfix`.`option_parm`, 0 )
;
-- Delete the data to have a clean table for the next run
delete from `tmp_randomoptionfix`;
-- Create cart_inventory data
insert into `tmp_randomoptionfix` ( `id`, `new_index`, `old_index`, `option_id`, `option_val`, `option_parm` )
select
`id`,
row_number() over( partition by `id` order by `old_index` asc ) - 1 as `new_index`,
`old_index`,
`option_id`,
`option_val`,
`option_parm`
from (
select * from (
select
`id`,
0 as `old_index`,
`option_id0` as `option_id`,
`option_val0` as `option_val`,
`option_parm0` as `option_parm`
from `cart_inventory`
where `option_id0` <> 0
union
select
`id`,
1 as `old_index`,
`option_id1` as `option_id`,
`option_val1` as `option_val`,
`option_parm1` as `option_parm`
from `cart_inventory`
where `option_id1` <> 0
union
select
`id`,
2 as `old_index`,
`option_id2` as `option_id`,
`option_val2` as `option_val`,
`option_parm2` as `option_parm`
from `cart_inventory`
where `option_id2` <> 0
union
select
`id`,
3 as `old_index`,
`option_id3` as `option_id`,
`option_val3` as `option_val`,
`option_parm3` as `option_parm`
from `cart_inventory`
where `option_id3` <> 0
union
select
`id`,
4 as `old_index`,
`option_id4` as `option_id`,
`option_val4` as `option_val`,
`option_parm4` as `option_parm`
from `cart_inventory`
where `option_id4` <> 0
) t2
order by `id`, `old_index`
) t ;
-- Fix option 0
update `cart_inventory`
left join `tmp_randomoptionfix`
on `cart_inventory`.`id` = `tmp_randomoptionfix`.`id` and `tmp_randomoptionfix`.`new_index` = 0
set
`option_id0` = coalesce( `tmp_randomoptionfix`.`option_id`, 0 ),
`option_val0` = coalesce( `tmp_randomoptionfix`.`option_val`, 0 ),
`option_parm0` = coalesce( `tmp_randomoptionfix`.`option_parm`, 0 )
;
-- Fix option 1
update `cart_inventory`
left join `tmp_randomoptionfix`
on `cart_inventory`.`id` = `tmp_randomoptionfix`.`id` and `tmp_randomoptionfix`.`new_index` = 1
set
`option_id1` = coalesce( `tmp_randomoptionfix`.`option_id`, 0 ),
`option_val1` = coalesce( `tmp_randomoptionfix`.`option_val`, 0 ),
`option_parm1` = coalesce( `tmp_randomoptionfix`.`option_parm`, 0 )
;
-- Fix option 2
update `cart_inventory`
left join `tmp_randomoptionfix`
on `cart_inventory`.`id` = `tmp_randomoptionfix`.`id` and `tmp_randomoptionfix`.`new_index` = 2
set
`option_id2` = coalesce( `tmp_randomoptionfix`.`option_id`, 0 ),
`option_val2` = coalesce( `tmp_randomoptionfix`.`option_val`, 0 ),
`option_parm2` = coalesce( `tmp_randomoptionfix`.`option_parm`, 0 )
;
-- Fix option 3
update `cart_inventory`
left join `tmp_randomoptionfix`
on `cart_inventory`.`id` = `tmp_randomoptionfix`.`id` and `tmp_randomoptionfix`.`new_index` = 3
set
`option_id3` = coalesce( `tmp_randomoptionfix`.`option_id`, 0 ),
`option_val3` = coalesce( `tmp_randomoptionfix`.`option_val`, 0 ),
`option_parm3` = coalesce( `tmp_randomoptionfix`.`option_parm`, 0 )
;
-- Fix option 4
update `cart_inventory`
left join `tmp_randomoptionfix`
on `cart_inventory`.`id` = `tmp_randomoptionfix`.`id` and `tmp_randomoptionfix`.`new_index` = 4
set
`option_id4` = coalesce( `tmp_randomoptionfix`.`option_id`, 0 ),
`option_val4` = coalesce( `tmp_randomoptionfix`.`option_val`, 0 ),
`option_parm4` = coalesce( `tmp_randomoptionfix`.`option_parm`, 0 )
;
-- Delete the data to have a clean table for the next run
delete from `tmp_randomoptionfix`;
-- Create guild_storage data
insert into `tmp_randomoptionfix` ( `id`, `new_index`, `old_index`, `option_id`, `option_val`, `option_parm` )
select
`id`,
row_number() over( partition by `id` order by `old_index` asc ) - 1 as `new_index`,
`old_index`,
`option_id`,
`option_val`,
`option_parm`
from (
select * from (
select
`id`,
0 as `old_index`,
`option_id0` as `option_id`,
`option_val0` as `option_val`,
`option_parm0` as `option_parm`
from `guild_storage`
where `option_id0` <> 0
union
select
`id`,
1 as `old_index`,
`option_id1` as `option_id`,
`option_val1` as `option_val`,
`option_parm1` as `option_parm`
from `guild_storage`
where `option_id1` <> 0
union
select
`id`,
2 as `old_index`,
`option_id2` as `option_id`,
`option_val2` as `option_val`,
`option_parm2` as `option_parm`
from `guild_storage`
where `option_id2` <> 0
union
select
`id`,
3 as `old_index`,
`option_id3` as `option_id`,
`option_val3` as `option_val`,
`option_parm3` as `option_parm`
from `guild_storage`
where `option_id3` <> 0
union
select
`id`,
4 as `old_index`,
`option_id4` as `option_id`,
`option_val4` as `option_val`,
`option_parm4` as `option_parm`
from `guild_storage`
where `option_id4` <> 0
) t2
order by `id`, `old_index`
) t ;
-- Fix option 0
update `guild_storage`
left join `tmp_randomoptionfix`
on `guild_storage`.`id` = `tmp_randomoptionfix`.`id` and `tmp_randomoptionfix`.`new_index` = 0
set
`option_id0` = coalesce( `tmp_randomoptionfix`.`option_id`, 0 ),
`option_val0` = coalesce( `tmp_randomoptionfix`.`option_val`, 0 ),
`option_parm0` = coalesce( `tmp_randomoptionfix`.`option_parm`, 0 )
;
-- Fix option 1
update `guild_storage`
left join `tmp_randomoptionfix`
on `guild_storage`.`id` = `tmp_randomoptionfix`.`id` and `tmp_randomoptionfix`.`new_index` = 1
set
`option_id1` = coalesce( `tmp_randomoptionfix`.`option_id`, 0 ),
`option_val1` = coalesce( `tmp_randomoptionfix`.`option_val`, 0 ),
`option_parm1` = coalesce( `tmp_randomoptionfix`.`option_parm`, 0 )
;
-- Fix option 2
update `guild_storage`
left join `tmp_randomoptionfix`
on `guild_storage`.`id` = `tmp_randomoptionfix`.`id` and `tmp_randomoptionfix`.`new_index` = 2
set
`option_id2` = coalesce( `tmp_randomoptionfix`.`option_id`, 0 ),
`option_val2` = coalesce( `tmp_randomoptionfix`.`option_val`, 0 ),
`option_parm2` = coalesce( `tmp_randomoptionfix`.`option_parm`, 0 )
;
-- Fix option 3
update `guild_storage`
left join `tmp_randomoptionfix`
on `guild_storage`.`id` = `tmp_randomoptionfix`.`id` and `tmp_randomoptionfix`.`new_index` = 3
set
`option_id3` = coalesce( `tmp_randomoptionfix`.`option_id`, 0 ),
`option_val3` = coalesce( `tmp_randomoptionfix`.`option_val`, 0 ),
`option_parm3` = coalesce( `tmp_randomoptionfix`.`option_parm`, 0 )
;
-- Fix option 4
update `guild_storage`
left join `tmp_randomoptionfix`
on `guild_storage`.`id` = `tmp_randomoptionfix`.`id` and `tmp_randomoptionfix`.`new_index` = 4
set
`option_id4` = coalesce( `tmp_randomoptionfix`.`option_id`, 0 ),
`option_val4` = coalesce( `tmp_randomoptionfix`.`option_val`, 0 ),
`option_parm4` = coalesce( `tmp_randomoptionfix`.`option_parm`, 0 )
;
-- Delete the data to have a clean table for the next run
delete from `tmp_randomoptionfix`;
-- Create inventory data
insert into `tmp_randomoptionfix` ( `id`, `new_index`, `old_index`, `option_id`, `option_val`, `option_parm` )
select
`id`,
row_number() over( partition by `id` order by `old_index` asc ) - 1 as `new_index`,
`old_index`,
`option_id`,
`option_val`,
`option_parm`
from (
select * from (
select
`id`,
0 as `old_index`,
`option_id0` as `option_id`,
`option_val0` as `option_val`,
`option_parm0` as `option_parm`
from `inventory`
where `option_id0` <> 0
union
select
`id`,
1 as `old_index`,
`option_id1` as `option_id`,
`option_val1` as `option_val`,
`option_parm1` as `option_parm`
from `inventory`
where `option_id1` <> 0
union
select
`id`,
2 as `old_index`,
`option_id2` as `option_id`,
`option_val2` as `option_val`,
`option_parm2` as `option_parm`
from `inventory`
where `option_id2` <> 0
union
select
`id`,
3 as `old_index`,
`option_id3` as `option_id`,
`option_val3` as `option_val`,
`option_parm3` as `option_parm`
from `inventory`
where `option_id3` <> 0
union
select
`id`,
4 as `old_index`,
`option_id4` as `option_id`,
`option_val4` as `option_val`,
`option_parm4` as `option_parm`
from `inventory`
where `option_id4` <> 0
) t2
order by `id`, `old_index`
) t ;
-- Fix option 0
update `inventory`
left join `tmp_randomoptionfix`
on `inventory`.`id` = `tmp_randomoptionfix`.`id` and `tmp_randomoptionfix`.`new_index` = 0
set
`option_id0` = coalesce( `tmp_randomoptionfix`.`option_id`, 0 ),
`option_val0` = coalesce( `tmp_randomoptionfix`.`option_val`, 0 ),
`option_parm0` = coalesce( `tmp_randomoptionfix`.`option_parm`, 0 )
;
-- Fix option 1
update `inventory`
left join `tmp_randomoptionfix`
on `inventory`.`id` = `tmp_randomoptionfix`.`id` and `tmp_randomoptionfix`.`new_index` = 1
set
`option_id1` = coalesce( `tmp_randomoptionfix`.`option_id`, 0 ),
`option_val1` = coalesce( `tmp_randomoptionfix`.`option_val`, 0 ),
`option_parm1` = coalesce( `tmp_randomoptionfix`.`option_parm`, 0 )
;
-- Fix option 2
update `inventory`
left join `tmp_randomoptionfix`
on `inventory`.`id` = `tmp_randomoptionfix`.`id` and `tmp_randomoptionfix`.`new_index` = 2
set
`option_id2` = coalesce( `tmp_randomoptionfix`.`option_id`, 0 ),
`option_val2` = coalesce( `tmp_randomoptionfix`.`option_val`, 0 ),
`option_parm2` = coalesce( `tmp_randomoptionfix`.`option_parm`, 0 )
;
-- Fix option 3
update `inventory`
left join `tmp_randomoptionfix`
on `inventory`.`id` = `tmp_randomoptionfix`.`id` and `tmp_randomoptionfix`.`new_index` = 3
set
`option_id3` = coalesce( `tmp_randomoptionfix`.`option_id`, 0 ),
`option_val3` = coalesce( `tmp_randomoptionfix`.`option_val`, 0 ),
`option_parm3` = coalesce( `tmp_randomoptionfix`.`option_parm`, 0 )
;
-- Fix option 4
update `inventory`
left join `tmp_randomoptionfix`
on `inventory`.`id` = `tmp_randomoptionfix`.`id` and `tmp_randomoptionfix`.`new_index` = 4
set
`option_id4` = coalesce( `tmp_randomoptionfix`.`option_id`, 0 ),
`option_val4` = coalesce( `tmp_randomoptionfix`.`option_val`, 0 ),
`option_parm4` = coalesce( `tmp_randomoptionfix`.`option_parm`, 0 )
;
-- Delete the data to have a clean table for the next run
delete from `tmp_randomoptionfix`;
-- Create mail_attachments data
insert into `tmp_randomoptionfix` ( `id`, `new_index`, `old_index`, `option_id`, `option_val`, `option_parm` )
select
`id`,
row_number() over( partition by `id` order by `old_index` asc ) - 1 as `new_index`,
`old_index`,
`option_id`,
`option_val`,
`option_parm`
from (
select * from (
select
`id`,
0 as `old_index`,
`option_id0` as `option_id`,
`option_val0` as `option_val`,
`option_parm0` as `option_parm`
from `mail_attachments`
where `option_id0` <> 0
union
select
`id`,
1 as `old_index`,
`option_id1` as `option_id`,
`option_val1` as `option_val`,
`option_parm1` as `option_parm`
from `mail_attachments`
where `option_id1` <> 0
union
select
`id`,
2 as `old_index`,
`option_id2` as `option_id`,
`option_val2` as `option_val`,
`option_parm2` as `option_parm`
from `mail_attachments`
where `option_id2` <> 0
union
select
`id`,
3 as `old_index`,
`option_id3` as `option_id`,
`option_val3` as `option_val`,
`option_parm3` as `option_parm`
from `mail_attachments`
where `option_id3` <> 0
union
select
`id`,
4 as `old_index`,
`option_id4` as `option_id`,
`option_val4` as `option_val`,
`option_parm4` as `option_parm`
from `mail_attachments`
where `option_id4` <> 0
) t2
order by `id`, `old_index`
) t ;
-- Fix option 0
update `mail_attachments`
left join `tmp_randomoptionfix`
on `mail_attachments`.`id` = `tmp_randomoptionfix`.`id` and `tmp_randomoptionfix`.`new_index` = 0
set
`option_id0` = coalesce( `tmp_randomoptionfix`.`option_id`, 0 ),
`option_val0` = coalesce( `tmp_randomoptionfix`.`option_val`, 0 ),
`option_parm0` = coalesce( `tmp_randomoptionfix`.`option_parm`, 0 )
;
-- Fix option 1
update `mail_attachments`
left join `tmp_randomoptionfix`
on `mail_attachments`.`id` = `tmp_randomoptionfix`.`id` and `tmp_randomoptionfix`.`new_index` = 1
set
`option_id1` = coalesce( `tmp_randomoptionfix`.`option_id`, 0 ),
`option_val1` = coalesce( `tmp_randomoptionfix`.`option_val`, 0 ),
`option_parm1` = coalesce( `tmp_randomoptionfix`.`option_parm`, 0 )
;
-- Fix option 2
update `mail_attachments`
left join `tmp_randomoptionfix`
on `mail_attachments`.`id` = `tmp_randomoptionfix`.`id` and `tmp_randomoptionfix`.`new_index` = 2
set
`option_id2` = coalesce( `tmp_randomoptionfix`.`option_id`, 0 ),
`option_val2` = coalesce( `tmp_randomoptionfix`.`option_val`, 0 ),
`option_parm2` = coalesce( `tmp_randomoptionfix`.`option_parm`, 0 )
;
-- Fix option 3
update `mail_attachments`
left join `tmp_randomoptionfix`
on `mail_attachments`.`id` = `tmp_randomoptionfix`.`id` and `tmp_randomoptionfix`.`new_index` = 3
set
`option_id3` = coalesce( `tmp_randomoptionfix`.`option_id`, 0 ),
`option_val3` = coalesce( `tmp_randomoptionfix`.`option_val`, 0 ),
`option_parm3` = coalesce( `tmp_randomoptionfix`.`option_parm`, 0 )
;
-- Fix option 4
update `mail_attachments`
left join `tmp_randomoptionfix`
on `mail_attachments`.`id` = `tmp_randomoptionfix`.`id` and `tmp_randomoptionfix`.`new_index` = 4
set
`option_id4` = coalesce( `tmp_randomoptionfix`.`option_id`, 0 ),
`option_val4` = coalesce( `tmp_randomoptionfix`.`option_val`, 0 ),
`option_parm4` = coalesce( `tmp_randomoptionfix`.`option_parm`, 0 )
;
-- Delete the data to have a clean table for the next run
delete from `tmp_randomoptionfix`;
-- Create storage data
insert into `tmp_randomoptionfix` ( `id`, `new_index`, `old_index`, `option_id`, `option_val`, `option_parm` )
select
`id`,
row_number() over( partition by `id` order by `old_index` asc ) - 1 as `new_index`,
`old_index`,
`option_id`,
`option_val`,
`option_parm`
from (
select * from (
select
`id`,
0 as `old_index`,
`option_id0` as `option_id`,
`option_val0` as `option_val`,
`option_parm0` as `option_parm`
from `storage`
where `option_id0` <> 0
union
select
`id`,
1 as `old_index`,
`option_id1` as `option_id`,
`option_val1` as `option_val`,
`option_parm1` as `option_parm`
from `storage`
where `option_id1` <> 0
union
select
`id`,
2 as `old_index`,
`option_id2` as `option_id`,
`option_val2` as `option_val`,
`option_parm2` as `option_parm`
from `storage`
where `option_id2` <> 0
union
select
`id`,
3 as `old_index`,
`option_id3` as `option_id`,
`option_val3` as `option_val`,
`option_parm3` as `option_parm`
from `storage`
where `option_id3` <> 0
union
select
`id`,
4 as `old_index`,
`option_id4` as `option_id`,
`option_val4` as `option_val`,
`option_parm4` as `option_parm`
from `storage`
where `option_id4` <> 0
) t2
order by `id`, `old_index`
) t ;
-- Fix option 0
update `storage`
left join `tmp_randomoptionfix`
on `storage`.`id` = `tmp_randomoptionfix`.`id` and `tmp_randomoptionfix`.`new_index` = 0
set
`option_id0` = coalesce( `tmp_randomoptionfix`.`option_id`, 0 ),
`option_val0` = coalesce( `tmp_randomoptionfix`.`option_val`, 0 ),
`option_parm0` = coalesce( `tmp_randomoptionfix`.`option_parm`, 0 )
;
-- Fix option 1
update `storage`
left join `tmp_randomoptionfix`
on `storage`.`id` = `tmp_randomoptionfix`.`id` and `tmp_randomoptionfix`.`new_index` = 1
set
`option_id1` = coalesce( `tmp_randomoptionfix`.`option_id`, 0 ),
`option_val1` = coalesce( `tmp_randomoptionfix`.`option_val`, 0 ),
`option_parm1` = coalesce( `tmp_randomoptionfix`.`option_parm`, 0 )
;
-- Fix option 2
update `storage`
left join `tmp_randomoptionfix`
on `storage`.`id` = `tmp_randomoptionfix`.`id` and `tmp_randomoptionfix`.`new_index` = 2
set
`option_id2` = coalesce( `tmp_randomoptionfix`.`option_id`, 0 ),
`option_val2` = coalesce( `tmp_randomoptionfix`.`option_val`, 0 ),
`option_parm2` = coalesce( `tmp_randomoptionfix`.`option_parm`, 0 )
;
-- Fix option 3
update `storage`
left join `tmp_randomoptionfix`
on `storage`.`id` = `tmp_randomoptionfix`.`id` and `tmp_randomoptionfix`.`new_index` = 3
set
`option_id3` = coalesce( `tmp_randomoptionfix`.`option_id`, 0 ),
`option_val3` = coalesce( `tmp_randomoptionfix`.`option_val`, 0 ),
`option_parm3` = coalesce( `tmp_randomoptionfix`.`option_parm`, 0 )
;
-- Fix option 4
update `storage`
left join `tmp_randomoptionfix`
on `storage`.`id` = `tmp_randomoptionfix`.`id` and `tmp_randomoptionfix`.`new_index` = 4
set
`option_id4` = coalesce( `tmp_randomoptionfix`.`option_id`, 0 ),
`option_val4` = coalesce( `tmp_randomoptionfix`.`option_val`, 0 ),
`option_parm4` = coalesce( `tmp_randomoptionfix`.`option_parm`, 0 )
;
-- Delete the data to have a clean table for the next run
delete from `tmp_randomoptionfix`;
-- Repeat this for any other storage tables that you have created (for example VIP)
-- To do this copy paste the code below and replace ${other_storage} with the name of your table
/**
-- Create ${other_storage} data
insert into `tmp_randomoptionfix` ( `id`, `new_index`, `old_index`, `option_id`, `option_val`, `option_parm` )
select
`id`,
row_number() over( partition by `id` order by `old_index` asc ) - 1 as `new_index`,
`old_index`,
`option_id`,
`option_val`,
`option_parm`
from (
select * from (
select
`id`,
0 as `old_index`,
`option_id0` as `option_id`,
`option_val0` as `option_val`,
`option_parm0` as `option_parm`
from `${other_storage}`
where `option_id0` <> 0
union
select
`id`,
1 as `old_index`,
`option_id1` as `option_id`,
`option_val1` as `option_val`,
`option_parm1` as `option_parm`
from `${other_storage}`
where `option_id1` <> 0
union
select
`id`,
2 as `old_index`,
`option_id2` as `option_id`,
`option_val2` as `option_val`,
`option_parm2` as `option_parm`
from `${other_storage}`
where `option_id2` <> 0
union
select
`id`,
3 as `old_index`,
`option_id3` as `option_id`,
`option_val3` as `option_val`,
`option_parm3` as `option_parm`
from `${other_storage}`
where `option_id3` <> 0
union
select
`id`,
4 as `old_index`,
`option_id4` as `option_id`,
`option_val4` as `option_val`,
`option_parm4` as `option_parm`
from `${other_storage}`
where `option_id4` <> 0
) t2
order by `id`, `old_index`
) t ;
-- Fix option 0
update `${other_storage}`
left join `tmp_randomoptionfix`
on `${other_storage}`.`id` = `tmp_randomoptionfix`.`id` and `tmp_randomoptionfix`.`new_index` = 0
set
`option_id0` = coalesce( `tmp_randomoptionfix`.`option_id`, 0 ),
`option_val0` = coalesce( `tmp_randomoptionfix`.`option_val`, 0 ),
`option_parm0` = coalesce( `tmp_randomoptionfix`.`option_parm`, 0 )
;
-- Fix option 1
update `${other_storage}`
left join `tmp_randomoptionfix`
on `${other_storage}`.`id` = `tmp_randomoptionfix`.`id` and `tmp_randomoptionfix`.`new_index` = 1
set
`option_id1` = coalesce( `tmp_randomoptionfix`.`option_id`, 0 ),
`option_val1` = coalesce( `tmp_randomoptionfix`.`option_val`, 0 ),
`option_parm1` = coalesce( `tmp_randomoptionfix`.`option_parm`, 0 )
;
-- Fix option 2
update `${other_storage}`
left join `tmp_randomoptionfix`
on `${other_storage}`.`id` = `tmp_randomoptionfix`.`id` and `tmp_randomoptionfix`.`new_index` = 2
set
`option_id2` = coalesce( `tmp_randomoptionfix`.`option_id`, 0 ),
`option_val2` = coalesce( `tmp_randomoptionfix`.`option_val`, 0 ),
`option_parm2` = coalesce( `tmp_randomoptionfix`.`option_parm`, 0 )
;
-- Fix option 3
update `${other_storage}`
left join `tmp_randomoptionfix`
on `${other_storage}`.`id` = `tmp_randomoptionfix`.`id` and `tmp_randomoptionfix`.`new_index` = 3
set
`option_id3` = coalesce( `tmp_randomoptionfix`.`option_id`, 0 ),
`option_val3` = coalesce( `tmp_randomoptionfix`.`option_val`, 0 ),
`option_parm3` = coalesce( `tmp_randomoptionfix`.`option_parm`, 0 )
;
-- Fix option 4
update `${other_storage}`
left join `tmp_randomoptionfix`
on `${other_storage}`.`id` = `tmp_randomoptionfix`.`id` and `tmp_randomoptionfix`.`new_index` = 4
set
`option_id4` = coalesce( `tmp_randomoptionfix`.`option_id`, 0 ),
`option_val4` = coalesce( `tmp_randomoptionfix`.`option_val`, 0 ),
`option_parm4` = coalesce( `tmp_randomoptionfix`.`option_parm`, 0 )
;
-- Delete the data to have a clean table for the next run
delete from `tmp_randomoptionfix`;
**/
drop table `tmp_randomoptionfix`;