【48】在flask中使用SQLALchemy連接sqlite數(shù)據(jù)庫

方法:

1 配置數(shù)據(jù)庫

basedir= os.path.abspath(os.path.dirname(__file__))  #獲取當(dāng)前文件的絕對路徑

app = Flask(__name__)

# 拼接數(shù)據(jù)庫的URL路徑

#? os.path.join 把basedir和data.sqlite的路徑拼接起來#

# data.sqlite為數(shù)據(jù)庫文件,若該文件夾下沒有這個文件會自動創(chuàng)建

app.config['SQLALCHEMY_DATABASE_URI'] =\

'sqlite:///'+ os.path.join(basedir,'data.sqlite')

# 配置這個鍵之后贫母,每次請求結(jié)束之后都會提交數(shù)據(jù)庫的變動

app.config['SQLALCHEMY_COMMIT_ON_TEARDOWN'] =True

db = SQLAlchemy(app)

2 定義模型

# 定義模型

# db.Model是一個基類

classRole(db.Model):

# 對應(yīng)的數(shù)據(jù)庫表明

__tablename__ ='roles'

# 設(shè)置字段格式

id = db.Column(db.Integer,primary_key=True)

name = db.Column(db.String(64),unique=True)

# 創(chuàng)建與其他表的關(guān)系

users = db.relationship('User',backref='role',lazy='dynamic')

def__repr__(self):

return''%self.name

classUser(db.Model):

__tablename__ ='users'

id = db.Column(db.Integer,primary_key=True)

username= db.Column(db.String(64),unique=True,index=True)

role_id = db.Column(db.Integer,db.ForeignKey('roles.id'))

def__repr__(self):

return''%self.username

3 操作數(shù)據(jù)庫

db.create_all()

總結(jié):

1 調(diào)試代碼遇到問題令哟,要先把代碼本身什么意思搞清楚,再想解決辦法

在調(diào)試數(shù)據(jù)庫連接時遇到:

sqlalchemy.exc.OperationalError:?(sqlite3.OperationalError)?unable?to?open?database?file

網(wǎng)上說可能是路徑不對,我就開始修改

'sqlite:///'

這部分的內(nèi)容,添加各種路徑,然而卻沒有注意到這部分的內(nèi)容

os.path.join(basedir,'data.sqlite')

這部分就是文件的路徑了呼伸,我在 'sqlite:///'怎么加路徑都不可能正確啊,吸取這次教訓(xùn)

2 遇到問題多看官方的api文檔钝尸,基本的問題上面都有說明括享,在網(wǎng)上看的答案不一定適合現(xiàn)在的版本

3 在設(shè)置路徑時,路徑中不能有空格符珍促,有空格的符的話也會報錯

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末铃辖,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子猪叙,更是在濱河造成了極大的恐慌娇斩,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,194評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件穴翩,死亡現(xiàn)場離奇詭異犬第,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)芒帕,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,058評論 2 385
  • 文/潘曉璐 我一進(jìn)店門歉嗓,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人背蟆,你說我怎么就攤上這事鉴分。” “怎么了带膀?”我有些...
    開封第一講書人閱讀 156,780評論 0 346
  • 文/不壞的土叔 我叫張陵志珍,是天一觀的道長。 經(jīng)常有香客問我垛叨,道長伦糯,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,388評論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮舔株,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘还棱。我一直安慰自己载慈,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 65,430評論 5 384
  • 文/花漫 我一把揭開白布珍手。 她就那樣靜靜地躺著办铡,像睡著了一般。 火紅的嫁衣襯著肌膚如雪琳要。 梳的紋絲不亂的頭發(fā)上寡具,一...
    開封第一講書人閱讀 49,764評論 1 290
  • 那天,我揣著相機(jī)與錄音稚补,去河邊找鬼童叠。 笑死,一個胖子當(dāng)著我的面吹牛课幕,可吹牛的內(nèi)容都是我干的厦坛。 我是一名探鬼主播,決...
    沈念sama閱讀 38,907評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼乍惊,長吁一口氣:“原來是場噩夢啊……” “哼杜秸!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起润绎,我...
    開封第一講書人閱讀 37,679評論 0 266
  • 序言:老撾萬榮一對情侶失蹤撬碟,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后莉撇,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體呢蛤,經(jīng)...
    沈念sama閱讀 44,122評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,459評論 2 325
  • 正文 我和宋清朗相戀三年稼钩,在試婚紗的時候發(fā)現(xiàn)自己被綠了顾稀。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,605評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡坝撑,死狀恐怖静秆,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情巡李,我是刑警寧澤抚笔,帶...
    沈念sama閱讀 34,270評論 4 329
  • 正文 年R本政府宣布,位于F島的核電站侨拦,受9級特大地震影響殊橙,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,867評論 3 312
  • 文/蒙蒙 一膨蛮、第九天 我趴在偏房一處隱蔽的房頂上張望叠纹。 院中可真熱鬧,春花似錦敞葛、人聲如沸誉察。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,734評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽持偏。三九已至,卻和暖如春氨肌,著一層夾襖步出監(jiān)牢的瞬間鸿秆,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,961評論 1 265
  • 我被黑心中介騙來泰國打工怎囚, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留卿叽,地道東北人。 一個月前我還...
    沈念sama閱讀 46,297評論 2 360
  • 正文 我出身青樓桩了,卻偏偏與公主長得像附帽,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子井誉,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,472評論 2 348

推薦閱讀更多精彩內(nèi)容