国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 編程 > Python > 正文

在Python的Flask框架下使用sqlalchemy庫(kù)的簡(jiǎn)單教程

2020-02-23 00:37:23
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

flask中的sqlalchemy 相比于sqlalchemy封裝的更加徹底一些 , 在一些方法上更簡(jiǎn)單

首先import類庫(kù):

在CODE上查看代碼片派生到我的代碼片

  <span style="font-size:18px;">from flask import Flask   from flask.ext.sqlalchemy import SQLAlchemy</span>

 


然后,需要加載 數(shù)據(jù)庫(kù)路徑

在CODE上查看代碼片派生到我的代碼片

  <span style="font-size:18px;">mysqlname='<span style="color: rgb(230, 219, 116); font-family: 'Source Code Pro'; font-size: 13pt; background-color: rgb(39, 40, 34);">mysql://user:passwd@127.0.0.1/student?charset=utf8</span>'</span> 

在CODE上查看代碼片派生到我的代碼片

  <span style="font-size:18px;">app = Flask(__name__)   app.config['SQLALCHEMY_DATABASE_URI'] = mysqlname   db = SQLAlchemy(app)</span> 


通過(guò)前面兩步 ,我們已經(jīng)讓flask和數(shù)據(jù)庫(kù)聯(lián)系到了一起

下面我們要把 flask和具體的表聯(lián)系在一起、

這樣建立一個(gè)model模型

在CODE上查看代碼片派生到我的代碼片

  <span style="font-size:18px;">class User(db.Model):        """存儲(chǔ) 每種報(bào)警類型的數(shù)量 , 以 分鐘 為單位進(jìn)行統(tǒng)計(jì)     :param source: string ,報(bào)警來(lái)源     :param network_logic_area: string ,該報(bào)警所屬的邏輯網(wǎng)絡(luò)區(qū)域     :param start_time: datetime , 報(bào)警發(fā)生時(shí)間     """        __tablename__ = 'hello'     id = db.Column(db.Integer , primary_key = True)     source = db.Column(db.String(255) )     network_logic_area = db.Column(db.String(255) )     start_time = db.Column(db.DateTime)     count = db.Column(db.Integer)        def __init__(self , source , network_logic_area , start_time , count):       self.source = source       self.network_logic_area = network_logic_area       self.start_time = start_time       self.count = count        def alter(self):       self.count += 1;</span> 

上面這個(gè)代碼,就讓falsk和具體的表hello聯(lián)系在了一起

在這個(gè)類中 ,我們首先要指定表,然后把這個(gè)表中的列都列出來(lái),最后定義一個(gè) 初始化函數(shù) , 讓后面插入數(shù)據(jù)使用


現(xiàn)在開(kāi)始具體的數(shù)據(jù)庫(kù)操作:

1、insert

在CODE上查看代碼片派生到我的代碼片

  <span style="font-size:18px;">    p = User(........)       db.session.add(p)       db.session.commit()</span> 

通過(guò) 類User構(gòu)造了一條數(shù)據(jù)

2、find

用主鍵獲取數(shù)據(jù):
Code example:

User.query.get(1)<User u'admin'>

通過(guò)一個(gè)精確參數(shù)進(jìn)行反查:
Code example:

peter=User.query.filter_by(username='peter').first() #注意:精確查詢函數(shù)query.filter_by(),是通過(guò)傳遞參數(shù)進(jìn)行查詢;其他增強(qiáng)型查詢函數(shù)是query.filter(),通過(guò)傳遞表達(dá)式進(jìn)行查詢。print(peter.id) #如果數(shù)據(jù)不存在則返回None            
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 琼海市| 台东县| 仪陇县| 阆中市| 遵义县| 衢州市| 华亭县| 鞍山市| 呼伦贝尔市| 西青区| 务川| 搜索| 溧阳市| 清徐县| 青川县| 社旗县| 铜陵市| 万宁市| 桐梓县| 乌苏市| 寻乌县| 仁寿县| 娄底市| 阿勒泰市| 霍山县| 滨海县| 博兴县| 荥经县| 湘潭市| 禹州市| 开原市| 二连浩特市| 灵川县| 平原县| 中超| 安远县| 宁南县| 台南市| 德惠市| 类乌齐县| 灌南县|