欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2015年04月09日 16:45:28   作者:zengchenacmer  
這篇文章主要介紹了在Python的Flask框架下使用sqlalchemy庫的簡(jiǎn)單教程,用來簡(jiǎn)潔地連接與操作數(shù)據(jù)庫,需要的朋友可以參考下

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

首先import類庫:

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

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

 


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

在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> 


通過前面兩步 ,我們已經(jīng)讓flask和數(shù)據(jù)庫聯(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)警來源 
    :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è)表中的列都列出來,最后定義一個(gè) 初始化函數(shù) , 讓后面插入數(shù)據(jù)使用


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

1、insert

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

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

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

2、find

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

User.query.get(1)

<User
 u'admin'>

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

peter
=

User.query.filter_by(username='peter').first() 
#注意:精確查詢函數(shù)query.filter_by(),是通過傳遞參數(shù)進(jìn)行查詢;其他增強(qiáng)型查詢函數(shù)是query.filter(),通過傳遞表達(dá)式進(jìn)行查詢。

print(peter.id) 
#如果數(shù)據(jù)不存在則返回None

模糊查詢:
Code example:
 

User.query.filter(User.email.endswith('@example.com')).all()

[<User
 u'admin'>,
 <User u'guest'>]

邏輯非1:
Code example:
 

peter
=

User.query.filter(User.username
 !=

'peter').first()

print(peter.id)

邏輯非2:
Code example:
 

from

sqlalchemy import

not_

peter
=

User.query.filter(not_(User.username=='peter')).first()

print(peter.id)

邏輯與:
Code example:

from

sqlalchemy import

and_

peter
=

User.query.filter(and_(User.username=='peter',
 User.email.endswith('@example.com'))).first()

print(peter.id)

邏輯或:
Code example:

from

sqlalchemy import

or_

peter
=

User.query.filter(or_(User.username
 !=

'peter',
 User.email.endswith('@example.com'))).first()

print(peter.id)

filter_by:這個(gè)里面只能放具體放入條件,不能放一個(gè)復(fù)雜的計(jì)算 ,

filter: 這個(gè)里面可以放一些復(fù)雜的計(jì)算

.first:取第一條數(shù)據(jù)

.all:取出所有數(shù)據(jù)

還有一個(gè)其他的方法,可以進(jìn)行排序、計(jì)數(shù)之類的操作

3、使用sql語句

可以通過 前面構(gòu)造的 db 直接使用sql的原生語句

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

  <span style="font-size:18px;">insert_table.db.engine.execute(' ..... ')</span> 


4、delete

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

  <span style="font-size:18px;">me = User(........)</span> 

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

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

5、更新數(shù)據(jù)

Code example:
 
u
=

User.query.first()

u.username
=

'guest' 
#更新數(shù)據(jù)和變量賦值那么簡(jiǎn)單,但必須是通過查詢返回的對(duì)象。

db.session.commit()

相關(guān)文章

  • python中l(wèi)ist循環(huán)語句用法實(shí)例

    python中l(wèi)ist循環(huán)語句用法實(shí)例

    這篇文章主要介紹了python中l(wèi)ist循環(huán)語句用法,以實(shí)例形式詳細(xì)介紹了Python針對(duì)list的解析,包含各種常見的遍歷操作及原理分析,需要的朋友可以參考下
    2014-11-11
  • python接收/發(fā)送QQ郵箱保姆級(jí)教程

    python接收/發(fā)送QQ郵箱保姆級(jí)教程

    我們?cè)谌粘ython開發(fā)過程中,需求中常有實(shí)現(xiàn)發(fā)送郵箱的功能,可以說是非常常見,也非常重要的功能,下面這篇文章主要給大家介紹了關(guān)于python接收/發(fā)送QQ郵箱保姆級(jí)教程的相關(guān)資料,需要的朋友可以參考下
    2024-03-03
  • python使用pytest接口自動(dòng)化測(cè)試的使用

    python使用pytest接口自動(dòng)化測(cè)試的使用

    這篇文章主要介紹了python使用pytest接口自動(dòng)化測(cè)試的使用,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • Python中實(shí)現(xiàn)定時(shí)任務(wù)詳解

    Python中實(shí)現(xiàn)定時(shí)任務(wù)詳解

    這篇文章主要介紹了Python中實(shí)現(xiàn)定時(shí)任務(wù)詳解的相關(guān)資料,需要的朋友可以參考下
    2023-07-07
  • Python簡(jiǎn)單定義與使用字典dict的方法示例

    Python簡(jiǎn)單定義與使用字典dict的方法示例

    這篇文章主要介紹了Python簡(jiǎn)單定義與使用字典的方法,結(jié)合簡(jiǎn)單實(shí)例形式分析了Python字典的原理、組成、定義及使用方法,需要的朋友可以參考下
    2017-07-07
  • python利用pandas將excel文件轉(zhuǎn)換為txt文件的方法

    python利用pandas將excel文件轉(zhuǎn)換為txt文件的方法

    今天小編就為大家分享一篇python利用pandas將excel文件轉(zhuǎn)換為txt文件的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-10-10
  • Python實(shí)現(xiàn)遍歷讀取文件或文件夾

    Python實(shí)現(xiàn)遍歷讀取文件或文件夾

    搞機(jī)器學(xué)習(xí)或者深度學(xué)習(xí)算法很多時(shí)候需要遍歷某個(gè)目錄讀取文件,特別是經(jīng)常需要讀取某個(gè)特定后綴的文件。本文為大家準(zhǔn)備了Python遍歷讀取文件或文件夾的示例代碼,需要的可以參考一下
    2022-08-08
  • Python Opencv實(shí)戰(zhàn)之文字檢測(cè)OCR

    Python Opencv實(shí)戰(zhàn)之文字檢測(cè)OCR

    這篇文章主要為大家詳細(xì)介紹了如何利用Python Opencv實(shí)現(xiàn)文字檢測(cè)OCR功能,文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,需要的可以參考一下
    2022-08-08
  • Python新手入門之解釋器的安裝

    Python新手入門之解釋器的安裝

    相信有很多小伙伴還不會(huì)安裝Python解釋器,今天特地整理了本篇文章,文章有非常詳細(xì)的圖文示例,對(duì)不會(huì)安裝的小伙伴很有幫助,需要的朋友可以參考下
    2021-06-06
  • 解決Python中導(dǎo)入自己寫的類,被劃紅線,但不影響執(zhí)行的問題

    解決Python中導(dǎo)入自己寫的類,被劃紅線,但不影響執(zhí)行的問題

    這篇文章主要介紹了解決Python中導(dǎo)入自己寫的類,被劃紅線,但不影響執(zhí)行的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-07-07

最新評(píng)論