flask框架實(shí)現(xiàn)連接sqlite3數(shù)據(jù)庫的方法分析
本文實(shí)例講述了flask框架實(shí)現(xiàn)連接sqlite3數(shù)據(jù)庫的方法。分享給大家供大家參考,具體如下:
1. 在flask文件夾中新建一個models.py文件用來定義模型,內(nèi)部代碼如下
import sqlite3 #導(dǎo)入sqlite3包
def get_conn():
#定義該函數(shù)用來連接數(shù)據(jù)庫
return sqlite3.connect("test.db")
class User(object):
def __init__(self,id,name):
self.id = id
self.name = name
def save(self):
sql = "insert into user VALUES (?,?)"#sql語句
conn = get_conn()#連接數(shù)據(jù)庫
cursor = conn.cursor()#定義一個游標(biāo)
cursor.execute(sql,(self.id,self.name))#執(zhí)行sql語句
conn.commit()#提交數(shù)據(jù)庫改動
cursor.close()#關(guān)閉游標(biāo)
conn.close()#關(guān)閉數(shù)據(jù)庫連接
'''
staticmethod相當(dāng)于一個定義在類里面的函數(shù),所以如果一個方法既不跟實(shí)例
相關(guān)也不跟特定的類相關(guān),推薦將其定義為一個staticmethod,這樣不僅使代
碼一目了然,而且似的利于維護(hù)代碼。
'''
@staticmethod
def query():
sql = "select * from user"
conn = get_conn()
cursor = conn.cursor()
rows = cursor.execute(sql)
users = []
for row in rows:
user = User(row[0],row[1])
users.append(user)
conn.commit()
cursor.close()
conn.close()
return users
def __str__(self):
return 'id:{}--name:{}'.format(self.id,self.name)#注此處的是點(diǎn)不是逗號
2. 在flask文件夾中新建一個manage.py文件
(1)導(dǎo)入flask_script包,導(dǎo)入sqlite3包,導(dǎo)入models.py中定義的模型,導(dǎo)入flask中的應(yīng)用,所以最終頭部代碼如下
from flask_script import Manager from learn_flask_script import app import sqlite3 from models import User
(2)創(chuàng)建數(shù)據(jù)庫,代碼如下
@manager.command
def init_db():
sql = "create table user (id INT,name TEXT)"
conn = sqlite3.connect("test.db")
cursor = conn.cursor()
cursor.execute(sql)
conn.commit()
cursor.close()
conn.close()
(3)保存數(shù)據(jù),代碼如下
@manager.command def save(): user = User(1,'csdn') user.save()
(4)查詢數(shù)據(jù),代碼如下
@manager.command def query_all(): users = User.query() for user in users: print(user)
整體代碼如下
from flask_script import Manager
from learn_flask_script import app
import sqlite3
from models import User
manager = Manager(app)
@manager.command
def init_db():
sql = "create table user (id INT,name TEXT)"
conn = sqlite3.connect("test.db")
cursor = conn.cursor()
cursor.execute(sql)
conn.commit()
cursor.close()
conn.close()
@manager.command
def save():
user = User(1,'zhangjia')
user.save()
@manager.command
def query_all():
users = User.query()
for user in users:
print(user)
if __name__ == "__main__":
manager.run()
3. 在終端中使用命令即可運(yùn)行數(shù)據(jù)庫的創(chuàng)建,添加以及查詢
更多關(guān)于Python相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Python常見數(shù)據(jù)庫操作技巧匯總》、《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》、《Python入門與進(jìn)階經(jīng)典教程》及《Python文件與目錄操作技巧匯總》
希望本文所述對大家Python程序設(shè)計有所幫助。
- Python web框架(django,flask)實(shí)現(xiàn)mysql數(shù)據(jù)庫讀寫分離的示例
- Python flask框架實(shí)現(xiàn)查詢數(shù)據(jù)庫并顯示數(shù)據(jù)
- flask 框架操作MySQL數(shù)據(jù)庫簡單示例
- flask框架配置mysql數(shù)據(jù)庫操作詳解
- 如何使用Flask-Migrate拓展數(shù)據(jù)庫表結(jié)構(gòu)
- Python使用Flask-SQLAlchemy連接數(shù)據(jù)庫操作示例
- Flask框架使用DBUtils模塊連接數(shù)據(jù)庫操作示例
- flask框架使用orm連接數(shù)據(jù)庫的方法示例
- Python框架Flask的基本數(shù)據(jù)庫操作方法分析
- Flask 數(shù)據(jù)庫集成的介紹
相關(guān)文章
python利用K-Means算法實(shí)現(xiàn)對數(shù)據(jù)的聚類案例詳解
這篇文章主要介紹了python利用K-Means算法實(shí)現(xiàn)對數(shù)據(jù)的聚類,本文通過案例講解的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-04-04
Python實(shí)現(xiàn)加解密,編碼解碼和進(jìn)制轉(zhuǎn)換(最全版)
這篇文章主要為大家詳細(xì)介紹了Python實(shí)現(xiàn)加解密、編碼解碼、進(jìn)制轉(zhuǎn)換、字符串轉(zhuǎn)換的最全版操作方法,文中的示例代碼講解詳細(xì),大家可以收藏一下2023-01-01
使用 Celery Once 來防止 Celery 重復(fù)執(zhí)行同一個任務(wù)
這篇文章主要介紹了使用 Celery Once 來防止 Celery 重復(fù)執(zhí)行同一個任務(wù),本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-10-10
Python如何讀取txt文件,獲取指定行中指定位置數(shù)據(jù)
這篇文章主要介紹了Python如何讀取txt文件,獲取指定行中指定位置數(shù)據(jù),具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-03-03
python神經(jīng)網(wǎng)絡(luò)MobileNet模型的復(fù)現(xiàn)詳解
這篇文章主要為大家介紹了python神經(jīng)網(wǎng)絡(luò)MobileNet模型的復(fù)現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-05-05
在Python中用has_key()方法查找鍵是否存在的教程
這篇文章主要介紹了在Python中用has_key()方法查找鍵是否存在的教程,是Python入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下2015-05-05
Python存儲List數(shù)據(jù)到文件(text/csv/excel)幾種常見方法
在數(shù)據(jù)分析中經(jīng)常需要從csv格式的文件中存取數(shù)據(jù)以及將數(shù)據(jù)寫書到csv文件中,下面這篇文章主要給大家介紹了關(guān)于Python存儲List數(shù)據(jù)到文件(text/csv/excel)的幾種常見方法,需要的朋友可以參考下2024-02-02

