python - sqlalchemy app.config使用報(bào)錯(cuò)
問(wèn)題描述
#!/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): ''' 新聞評(píng)論 ''' 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)
打算學(xué)習(xí)創(chuàng)建數(shù)據(jù)庫(kù)的,但是提示報(bào)錯(cuò),
>>> 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:'.’ )
上面說(shuō)。。。SQLALCHEMY_DATABASE_URI不在app.config里面。。。但是我上面的編碼。。確實(shí)在這個(gè)里面。。我崩潰。。。求助大神們。。。哪出錯(cuò)了。。
問(wèn)題解答
回答1:找到問(wèn)題點(diǎn)了,第一個(gè)app.config 要在 db = SQLAlchemy(app) 之前第二個(gè)在python3中的url使用是mysql+pymysql://
回答2:db = SQLAlchemy(app)app.config[’SQLALCHEMY_DATABASE_URI’] = ’mysql://root:123456@127.0.0.1/flask_test’
將這兩句調(diào)換順序,應(yīng)該是需要在初始化 db 前設(shè)置URI
另 URI 格式是不是有問(wèn)題,官網(wǎng)文檔
相關(guān)文章:
1. Python從URL中提取域名2. php傳對(duì)應(yīng)的id值為什么傳不了啊有木有大神會(huì)的看我下方截圖3. python - scrapy url去重4. python - Flask寫(xiě)的注冊(cè)頁(yè)面,當(dāng)注冊(cè)時(shí),如果填寫(xiě)數(shù)據(jù)庫(kù)里有的相同數(shù)據(jù),就報(bào)錯(cuò)5. 關(guān)于mysql聯(lián)合查詢(xún)一對(duì)多的顯示結(jié)果問(wèn)題6. 實(shí)現(xiàn)bing搜索工具urlAPI提交7. 數(shù)據(jù)庫(kù) - Mysql的存儲(chǔ)過(guò)程真的是個(gè)坑!求助下面的存儲(chǔ)過(guò)程哪里錯(cuò)啦,實(shí)在是找不到哪里的問(wèn)題了。8. python - oslo_config9. MySQL主鍵沖突時(shí)的更新操作和替換操作在功能上有什么差別(如圖)10. 小白學(xué)python的問(wèn)題 關(guān)于%d和%s的區(qū)別
