django2.2以上使用pymsql報錯問題解決方法

問題1

執(zhí)行makemigrations命令時提示:django.core.exceptions.ImproperlyConfigured: mysqlclient 1.3.13 or newer is required; you have 0.9.2. 詳細如下

File "C:\Python37\lib\site-packages\django\db\backends\mysql\base.py", line 36, in <module>
raise ImproperlyConfigured('mysqlclient 1.3.13 or newer is required; you have %s.' % Database.__version__)
django.core.exceptions.ImproperlyConfigured: mysqlclient 1.3.13 or newer is required; you have 0.9.2.

解決方法:

  • 方法一:按要求安裝mysqlclient 1.3.13或以上版本摇零。
  • 方法二: 找到C:\Python37\lib\site-packages\django\db\backends\mysql\base.py文件发乔,注釋掉如下代碼
    # if version < (1, 3, 13):
    #     raise ImproperlyConfigured('mysqlclient 1.3.13 or newer is required;     you have %s.' % Database.__version__)
    
    

問題2:

錯誤提示AttributeError: 'str' object has no attribute 'decode'

File "C:\Python37\lib\site-packages\django\db\backends\mysql\operations.py", line 146, in last_executed_query
    query = query.decode(errors='replace')
AttributeError: 'str' object has no attribute 'decode'

解決方法:

  1. 找到django\db\backends\mysql\operations.py文件下的last_executed_query方法,如下
    old
  def last_executed_query(self, cursor, sql, params):
      # With MySQLdb, cursor objects have an (undocumented) "_executed"
      # attribute where the exact query sent to the database is saved.
      # See MySQLdb/cursors.py in the source distribution.
      query = getattr(cursor, '_executed', None)
      if query is not None:
          query = query.decode(errors='replace')
      return query
  1. 修改last_executed_query方法
    new
from django.utils.encoding import force_str
def last_executed_query(self, cursor, sql, params):
      # With MySQLdb, cursor objects have an (undocumented) "_executed"
      # attribute where the exact query sent to the database is saved.
      # See MySQLdb/cursors.py in the source distribution.
      # MySQLdb returns string, PyMySQL bytes.
      return force_str(getattr(cursor, '_executed', None), errors='replace')
  1. 然后再執(zhí)行makemigrations命令就可以了
最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末炒辉,一起剝皮案震驚了整個濱河市绰寞,隨后出現(xiàn)的幾起案子到逊,更是在濱河造成了極大的恐慌铣口,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,968評論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件觉壶,死亡現(xiàn)場離奇詭異枷踏,居然都是意外死亡,警方通過查閱死者的電腦和手機掰曾,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,601評論 2 382
  • 文/潘曉璐 我一進店門旭蠕,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人旷坦,你說我怎么就攤上這事掏熬。” “怎么了秒梅?”我有些...
    開封第一講書人閱讀 153,220評論 0 344
  • 文/不壞的土叔 我叫張陵旗芬,是天一觀的道長。 經(jīng)常有香客問我捆蜀,道長疮丛,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,416評論 1 279
  • 正文 為了忘掉前任辆它,我火速辦了婚禮誊薄,結果婚禮上,老公的妹妹穿的比我還像新娘锰茉。我一直安慰自己呢蔫,他們只是感情好,可當我...
    茶點故事閱讀 64,425評論 5 374
  • 文/花漫 我一把揭開白布飒筑。 她就那樣靜靜地躺著片吊,像睡著了一般。 火紅的嫁衣襯著肌膚如雪协屡。 梳的紋絲不亂的頭發(fā)上俏脊,一...
    開封第一講書人閱讀 49,144評論 1 285
  • 那天,我揣著相機與錄音肤晓,去河邊找鬼爷贫。 笑死,一個胖子當著我的面吹牛材原,可吹牛的內(nèi)容都是我干的沸久。 我是一名探鬼主播季眷,決...
    沈念sama閱讀 38,432評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼余蟹,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了子刮?” 一聲冷哼從身側響起威酒,我...
    開封第一講書人閱讀 37,088評論 0 261
  • 序言:老撾萬榮一對情侶失蹤窑睁,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后葵孤,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體担钮,經(jīng)...
    沈念sama閱讀 43,586評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,028評論 2 325
  • 正文 我和宋清朗相戀三年尤仍,在試婚紗的時候發(fā)現(xiàn)自己被綠了箫津。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,137評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡宰啦,死狀恐怖苏遥,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情赡模,我是刑警寧澤田炭,帶...
    沈念sama閱讀 33,783評論 4 324
  • 正文 年R本政府宣布,位于F島的核電站漓柑,受9級特大地震影響教硫,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜辆布,卻給世界環(huán)境...
    茶點故事閱讀 39,343評論 3 307
  • 文/蒙蒙 一瞬矩、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧锋玲,春花似錦丧鸯、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,333評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至剿干,卻和暖如春蜂怎,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背置尔。 一陣腳步聲響...
    開封第一講書人閱讀 31,559評論 1 262
  • 我被黑心中介騙來泰國打工杠步, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人榜轿。 一個月前我還...
    沈念sama閱讀 45,595評論 2 355
  • 正文 我出身青樓幽歼,卻偏偏與公主長得像,于是被迫代替她去往敵國和親谬盐。 傳聞我的和親對象是個殘疾皇子甸私,可洞房花燭夜當晚...
    茶點故事閱讀 42,901評論 2 345