python - sqlalchemy app.config使用報錯
問題描述
#!/usr/bin/python#coding=utf-8from flask import Flaskfrom flask_sqlalchemy import SQLAlchemyapp = Flask(__name__)db = SQLAlchemy(app)class News(db.Model): ''' 新聞模型 ''' __tablename__ = ’news’ id = db.Column(db.Integer, primary_key=True) title = db.Column(db.String(200), nullable=False) content = db.Column(db.String(2000), nullable=False) is_valid = db.Column(db.Boolean, default=True) created_at = db.Column(db.DateTime) updated_at = db.Column(db.DateTime) comments = db.relationship(’Comments’, backref=’news’,lazy=’dynamic’) def __repr__(self):return ’<News %r>’ % self.titleclass Comments(db.Model): ''' 新聞評論 ''' id = db.Column(db.Integer, primary_key=True) content = db.Column(db.String(2000), nullable=False) is_valid = db.Column(db.Boolean, default=True) created_at = db.Column(db.DateTime) updated_at = db.Column(db.DateTime) new_id = db.Column(db.Integer, db.ForeignKey(’news.id’)) def __repr__(self):return ’<News %r>’ % self.contentapp.config[’SQLALCHEMY_DATABASE_URI’] = ’mysql://root:123456@127.0.0.1/flask_test’if __name__ == ’__main__’: app.run(debug=True)
打算學習創建數據庫的,但是提示報錯,
>>> from test_orm import dbD:mycodesvirtualflask-testlibsite-packagesflask_sqlalchemy__init__.py:819: UserWarning: SQLALCHEMY_DATABASE_URI not set. Defaulting to 'sqlite:///:memory:'. ’SQLALCHEMY_DATABASE_URI not set. Defaulting to ’>>>
我去看了一下源碼
if ’SQLALCHEMY_DATABASE_URI’ not in app.config: warnings.warn(’SQLALCHEMY_DATABASE_URI not set. Defaulting to ’’'sqlite:///:memory:'.’ )
上面說。。。SQLALCHEMY_DATABASE_URI不在app.config里面。。。但是我上面的編碼。。確實在這個里面。。我崩潰。。。求助大神們。。。哪出錯了。。
問題解答
回答1:找到問題點了,第一個app.config 要在 db = SQLAlchemy(app) 之前第二個在python3中的url使用是mysql+pymysql://
回答2:db = SQLAlchemy(app)app.config[’SQLALCHEMY_DATABASE_URI’] = ’mysql://root:123456@127.0.0.1/flask_test’
將這兩句調換順序,應該是需要在初始化 db 前設置URI
另 URI 格式是不是有問題,官網文檔
相關文章:
1. javascript - ie11以下單擊打開不了file,雙擊可以。求解?2. javascript - 關于定時器 與 防止連續點擊 問題3. javascript - 關于這組數據如何實現 按字母列表分類展示 不改動數據結構4. javascript - 寫移動端的頁面的時候,有不一快空白,是怎么回事?5. javascript - 求助這種功能有什么好點的插件?6. objective-c - ios百度地圖定位問題7. 微信開放平臺 - Android調用微信分享不顯示8. html5 - rudy編譯sass的時候有中文報錯9. javascript - 在IE中(9+)平時的樣式不生效,只有用開發者工具選中這個元素才生效,是什么原因?10. Python做掃描,發包速度實在是太慢了,有優化的方案嗎?
