スクリプトのお勉強 失敗談 技術

Django2.2 でのMySQL5.1対応

投稿日:

「対応」と書きながら、思い切り回避ですが。

マイグレーション時のエラー

マイグレーションしたら、以下のエラーになりました。

$ pipenv run python3 manage.py migrate<br>django.db.utils.ProgrammingError: (1064, "You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '(6) NOT NULL, `update_date` datetime(6) NOT NULL)' at line 1")

調べたら、SQL文の”(6)”という部分は、MySQL 5.6.4 以降での「マイクロ秒 (6 桁) までの精度を持つ」ことができる機能らしいです。

https://dev.mysql.com/doc/refman/5.6/ja/date-and-time-type-overview.html

対処: 対象のSQL文から削除する。。

ぶっちゃけ「μ秒」なんて使わないので、マイグレーション時に発行するSQL文から、”(6)”を消しました。。対応がムゴいのは認めます。。

私の場合はpipenvを使用して、ディレクトリ下に仮想環境を作成して修正しているので、対象のSQL文は以下にあります。

.venv/lib/python3.6/site-packages/django/db/backends/mysql/base.py

class DatabaseWrapper(BaseDatabaseWrapper):
    vendor = 'mysql'
        # 'DateTimeField': 'datetime(6)',
        'DateTimeField': 'datetime',

のように、”(6)”を消したら、一応、マイグレーションは成功しました。

その後の動作も特に問題なく動いているようです。

-スクリプトのお勉強, 失敗談, 技術

執筆者:

関連記事

Pythonパッケージ管理の歴史

歴史っても、あまり過去に興味がないので、、 Pythonのパッケージ管理の歴史は、常に流動的で、そもそもからして、とてもじゃないがまとめて説明できるようなものではないです。 はっきり言って昔からよく分 …

Pythonからsvnしてみる

SVN: レガシーシステムの一つ。。 私の関わってるシステムでは、いまだにsvnレポジトリがあります。pythonで処理する必要性が生じましたが、そういえばどう処理していいもんか、完全に忘れました。 …

Nuxt.jsのFormで入力/確認/完了フォームを作成してみた(その1)

背景 今回は、Webアプリケーションの、フロントエンド系のお話です。ほとんどの場合、バックエンドなのですが、時々フロントエンドもするんですよね。。 私の派遣先では、入力フォームを以下のように分ける要望 …

小ネタ: JavaScriptにてBase64エンコード/デコードする方法

小ネタです。JavaScriptにてBase64エンコード/デコードをしようとして、意外と詰まったので、メモ的に方法を書いておきます。 結論: js-base64ライブラリを使用する これだけです。。 …

Python3/ある日付から日付までの月/日/時間ごとの時刻を算出する

小ネタです。 要するに、時刻A と 時刻B を指定したときの、各時間間隔での時刻取得したかったです。 当初はdateutilを使う方法でなく、自前で実装しようと思ったのですが、面倒なことに気づきました …

    google オプトアウト Click here to opt-out.