I am trying to edit a big text file. What I am trying to achieve is swap lines from positions between 3 and 14 to positions between 16 and 27. I have extracted UPDATE statements from MySQL bin-logs and put them in a file. The problem is that, the position of WHERE clause and SET clause is reversed in bin-logs. I need to put SET clause before WHERE clause. Currently WHERE clause is before SET clause. There are 27 lines in one UPDATE statement and there are thousands of such UPDATE statements. Thus all the 13 lines from the SET clause (including the SET line from lines 15 to 27) in each UPDATE statement should be put at positions 2 and 14 and vice-a-versa.
I have no clue if this is possible or not. I tried to understand it from the following article, but don't understand it at all. I don't understand regular expressions or SED or AWK completely. Swap lines in text file only where containing strings using sed or ed?
Following are the sample output and the desired output. Sample UPDATE statement
### UPDATE `db`.`tb`
### WHERE
###   @1=39741631
###   @2=49969113
###   @3=1
###   @4=34
###   @5='{"CustomerName":"S","CustomerEmail":"[email protected]","CustomerMobile":"9","VersionId":"5","InSrc":"3","Eagerness":"-1"}'
###   @6=NULL
###   @7=0
###   @8='2021-11-09 19:11:49'
###   @9=NULL
###   @10=1
###   @11=29
###   @12=NULL
### SET
###   @1=39741631
###   @2=49969113
###   @3=1
###   @4=34
###   @5='{\n  "CustomerName": "S",\n  "CustomerEmail": "[email protected]",\n  "CustomerMobile": "9",\n  "VersionId": "5",\n  "InSrc": "39",\n  "Eagerness": "-1"}'
###   @6='33195861'
###   @7=1
###   @8='2021-11-09 19:11:49'
###   @9='2021-11-09 19:11:50'
###   @10=1
###   @11=20
###   @12='Pushed to CVL panel'
--
Desired output
### UPDATE `db`.`tb`
### SET
###   @1=39741631
###   @2=49969113
###   @3=1
###   @4=34
###   @5='{\n  "CustomerName": "S",\n  "CustomerEmail": "[email protected]",\n  "CustomerMobile": "9",\n  "VersionId": "5",\n  "InSrc": "39",\n  "Eagerness": "-1"}'
###   @6='33195861'
###   @7=1
###   @8='2021-11-09 19:11:49'
###   @9='2021-11-09 19:11:50'
###   @10=1
###   @11=20
###   @12='Pushed to CVL panel'
### WHERE
###   @1=39741631
###   @2=49969113
###   @3=1
###   @4=34
### @5='{"CustomerName":"S","CustomerEmail":"[email protected]","CustomerMobile":"9","VersionId":"5","InSrc":"3","Eagerness":"-1"}'
###   @6=NULL
###   @7=0
###   @8='2021-11-09 19:11:49'
###   @9=NULL
###   @10=1
###   @11=29
###   @12=NULL
--


###?--really terminate the "SET" section of the input? If not please replace it with whatever does terminate the "SET" section.