多くの似たようなSQLを発行したい場合、例えばプログラムのfor文で回せば処理できるような場合どうすればいいか。一般にSQLはfor文はないから、pythonなどでスクリプトを書くのもいいかもしれない。がスクリプトでDBを開いてとか書くのが面倒。そこでpythonでSQLだけを出力して、それを実行してしまえばいい。
jupyter
こういうときのちょっとしたpythonスクリプトを書くにはjupyterが便利。
まずは1個のSQLをpythonのprintで出力してみる
|
print('RENAME TABLE `eitango`.`old_2019_tango_111_111` TO `eitango`.`old__2019_tango_111_111`;') |
次にfor文で回す。SQLはformatで置換する。
|
for i in range(1, 13): for j in range(1,21): print('RENAME TABLE `eitango`.`old_2019_tango_{0:03}_{1:03}` TO `eitango`.`old__2019_tango_{0:03}_{1:03}`;'.format(i,j)) |
文字列中の{0:03}はformat引数の0番目の値を3桁で0で埋めることを指定している。これを実行すると以下のようなSQLが得られる。
|
RENAME TABLE `eitango`.`old_2019_tango_001_001` TO `eitango`.`old__2019_tango_001_001`; RENAME TABLE `eitango`.`old_2019_tango_001_002` TO `eitango`.`old__2019_tango_001_002`; RENAME TABLE `eitango`.`old_2019_tango_001_003` TO `eitango`.`old__2019_tango_001_003`; RENAME TABLE `eitango`.`old_2019_tango_001_004` TO `eitango`.`old__2019_tango_001_004`; RENAME TABLE `eitango`.`old_2019_tango_001_005` TO `eitango`.`old__2019_tango_001_005`; RENAME TABLE `eitango`.`old_2019_tango_001_006` TO `eitango`.`old__2019_tango_001_006`; RENAME TABLE `eitango`.`old_2019_tango_001_007` TO `eitango`.`old__2019_tango_001_007`; RENAME TABLE `eitango`.`old_2019_tango_001_008` TO `eitango`.`old__2019_tango_001_008`; RENAME TABLE `eitango`.`old_2019_tango_001_009` TO `eitango`.`old__2019_tango_001_009`; |
あとはこれはphpMyAdminにコピペしたり、mysqlに直接流し込んでもいいかもしれない。DBの変更は間違うと大変なのでよくチェックしてから行おう。