成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

主頁(yè) > 知識(shí)庫(kù) > python實(shí)現(xiàn)sqlalchemy的使用概述

python實(shí)現(xiàn)sqlalchemy的使用概述

熱門標(biāo)簽:宿遷星美防封電銷卡 西藏房產(chǎn)智能外呼系統(tǒng)要多少錢 地圖標(biāo)注審核表 ai電銷機(jī)器人源碼 湛江智能外呼系統(tǒng)廠家 外呼并發(fā)線路 長(zhǎng)沙高頻外呼系統(tǒng)原理是什么 ai電話機(jī)器人哪里好 百度地圖標(biāo)注沒(méi)有了

sqlAlchemy解讀: https://www.jb51.net/article/174565.htm

sqlAlchemy解讀:https://www.jb51.net/article/173950.htm

特點(diǎn)是操縱Python對(duì)象而不是SQL查詢,也就是在代碼層面考慮的是對(duì)象,而不是SQL,體現(xiàn)的是一種程序化思維,這樣使得Python程序更加簡(jiǎn)潔易懂。

具體的實(shí)現(xiàn)方式是將數(shù)據(jù)庫(kù)表轉(zhuǎn)換為Python類,其中數(shù)據(jù)列作為屬性,數(shù)據(jù)庫(kù)操作作為方法。

  1. abstract # 輔助sqlAlchemy實(shí)現(xiàn)類的繼承,自動(dòng)繼承屬性,省去super()
  2. SQLAlchemy定義的ORM,在繼承父級(jí)ORM時(shí)候,F(xiàn)oreign Key外鍵是不能繼承的,它強(qiáng)制要求在子類中重新定義。

使用概述

在使用sqlalchemy訪問(wèn)數(shù)據(jù)庫(kù)的時(shí)候,以類的形式表示表格,因此在使用之前,需要先定義類。

類的定義有三種:基類BASE、父類、子類

基類是sqlalchemy底層的;當(dāng)需要一份數(shù)據(jù)切分為多個(gè)子表的時(shí)候,或多個(gè)表的字段一致時(shí),可以使用一個(gè)父類定義字段的類型,多個(gè)子表繼承父類的屬性。

一、創(chuàng)建引擎和會(huì)話

通過(guò)創(chuàng)建引擎、綁定引擎來(lái)創(chuàng)建會(huì)話,實(shí)現(xiàn)數(shù)據(jù)庫(kù)的訪問(wèn)。

from sqlalchemy import create_engine                          # 引擎
from sqlalchemy.orm import sessionmaker                       # 創(chuàng)建orm的會(huì)話池,orm和sql均可以管理對(duì)象關(guān)系型數(shù)據(jù)庫(kù),需要綁定引擎才可以使用會(huì)話,

# 創(chuàng)建連接
engine = create_engine("mysql+pymysql://root:1234;@127.0.0.1/test", # 需要安裝mysql和pymysql的模塊,用戶名:密碼@ip地址/某個(gè)數(shù)據(jù)庫(kù)
                       #echo=True,         # 打印操作對(duì)應(yīng)的SQL語(yǔ)句
                       pool_size=8,       # 連接個(gè)數(shù)
                       pool_recycle=60*30 # 不使用時(shí)斷開(kāi)
                       )

# 創(chuàng)建session
DbSession = sessionmaker(bind=engine)  # 會(huì)話工廠,與引擎綁定。
session = DbSession()                  # 實(shí)例化

session.close()  # 關(guān)閉會(huì)話

二、定義類來(lái)表示虛擬表格

在使用sqlalchemy訪問(wèn)數(shù)據(jù)庫(kù)的時(shí)候,以類的形式表示表格,因此在使用之前,需要先定義類。使用類的名稱而不是tablename實(shí)現(xiàn)之后的增刪改查。

# 導(dǎo)入定義類需要的模塊
from sqlalchemy.ext.declarative import declarative_base       # 調(diào)用sqlalchemy的基類
from sqlalchemy import Column, Index, distinct, update        # 指定字段屬性,索引、唯一、DML
from sqlalchemy.types import *                                # 所有字段類型

1. 直接建立一個(gè)可調(diào)用的表格

需要先繼承基類,在定義__init__函數(shù),設(shè)置輸入?yún)?shù)。

# 創(chuàng)建庫(kù)表類型
Base = declarative_base()  # 調(diào)用sqlalchemy的基類

class Users(Base):
    '''繼承基類'''
    __tablename__ = "users"                     # 數(shù)據(jù)表的名字
    __table_args__ = {'extend_existing': True}  # 當(dāng)數(shù)據(jù)庫(kù)中已經(jīng)有該表時(shí),或內(nèi)存中已聲明該表,可以用此語(yǔ)句重新覆蓋聲明。
    id = Column(Integer, primary_key=True)
    name = Column(String(64), unique=True)
    #email = Column(String(64))

    def __init__(self, name, email):
        self.name = name
        self.email = email                      # 聲明需要調(diào)用的特征,可以只聲明數(shù)據(jù)庫(kù)中表格列的子集
        
Base.metadata.create_all(engine)                # 表生效:將所有定義的類,使用引擎創(chuàng)建,此時(shí)可以在數(shù)據(jù)庫(kù)中看到這些表。

2. 創(chuàng)建多個(gè)相同列屬性的表格 先建立一個(gè)表格的父類,指定列的屬性,再通過(guò)繼承父類

不同的表

# 創(chuàng)建庫(kù)表類型
Base = declarative_base()  # 調(diào)用sqlalchemy的基類

class model_data(BASE):  
    '''創(chuàng)建數(shù)據(jù)庫(kù)表類:模型所需的基本字段'''
    __abstract__ = True                         # 輔助sqlAlchemy實(shí)現(xiàn)類的繼承,自動(dòng)繼承屬性,省去super()
    __table_args__ = {'extend_existing': True}  # 若表的聲明在內(nèi)存中已存在,則重新聲明表的名稱,不然會(huì)報(bào)錯(cuò)
    ai_xdr_id = Column(BigInteger(), primary_key=True, unique=True, autoincrement= True)
    ai_sdk_id = Column(BigInteger())

class TrainData(model_data): # 訓(xùn)練集表
    '''繼承model_data的屬性,并將表的名字定義為:'xxx_train_data'存入數(shù)據(jù)庫(kù) '''
    __tablename__ = 'xxx_train_data'
    
class DevData(model_data):   # 開(kāi)發(fā)集表
    '''表的名字定義為:'xxx_dev_data' '''
    __tablename__ = 'xxx_dev_data'

class TestData(model_data):  # 測(cè)試集表
    __tablename__ = 'xxx_test_data'

Base.metadata.create_all(engine)                # 表生效:將所有定義的類,使用引擎創(chuàng)建,此時(shí)可以在數(shù)據(jù)庫(kù)中看到這些表。

三、增刪改查

因?yàn)槭菚?huì)話操作,當(dāng)某個(gè)語(yǔ)句,例如增加數(shù)據(jù)時(shí),不成功的時(shí)候需要回滾。

增加數(shù)據(jù)

# 增加數(shù)據(jù)
add_user = Users("test3", "test123@qq.com")
session.add(add_user)
session.commit()

# add_users = Users(("test", "test123@qq.com"),('a','b')))
# session.add(add_users)
# session.commit()

# 當(dāng)上述語(yǔ)句出現(xiàn)執(zhí)行錯(cuò)誤時(shí),需要執(zhí)行回滾語(yǔ)句,才能繼續(xù)操作
session.rollback()

刪除數(shù)據(jù)

delete_users = session.query(Users).filter(Users.name == "test").first()
if delete_users:
    session.delete(delete_users)
    session.commit()
    
session.query(Users).filter(Users.name == "test").delete()
session.commit()

更改數(shù)據(jù)

# 改
session.query(Users).filter_by(id=1).update({'name': "Jack"})

users = session.query(Users).filter_by(name="Jack").first()
users.name = "test"

查找數(shù)據(jù)

users = session.query(Users).filter_by(id=5).all()
for item in users:
    print(item.name)
    print(item.email)   # 若未在類中聲明,則無(wú)法訪問(wèn)數(shù)據(jù)庫(kù)中該表的屬性。

四、進(jìn)階技能

1. 將DataFrame格式的數(shù)據(jù)導(dǎo)入數(shù)據(jù)庫(kù)

class DataAccessLayer:# 數(shù)據(jù)連接層、定義了連接和關(guān)閉。
    '''數(shù)據(jù)連接層、定義了連接和關(guān)閉。'''
    def __init__(self):
        self.ENGINE = None                 # 引擎
        self.SESSION = None                # 會(huì)話
        self.conn_string = "mysql+pymysql://root:1234;@127.0.0.1/test"  ## 需要安裝mysql和pymysql的模塊,用戶名:密碼@ip地址/某個(gè)數(shù)據(jù)庫(kù)

    def connect(self):
        '''連接時(shí)建立引擎和會(huì)話。'''
        self.ENGINE = create_engine(self.conn_string, encoding='utf-8',isolation_level="AUTOCOMMIT", connect_args={'connect_timeout': 7200})
        # self.ENGINE = create_engine(self.conn_string, encoding='utf-8',connect_args={'connect_timeout': 7200})
        self.SESSION = sessionmaker(bind=self.ENGINE)()

    def disconnect(self):
        '''斷開(kāi)時(shí),關(guān)閉引擎。'''
        self.ENGINE.close()

def df_save_db(df,tablename):
    '''將數(shù)據(jù)集DataFrame保存到數(shù)據(jù)庫(kù)'''
    db_ac = DataAccessLayer()
    db_ac.connect()
    conn = db_ac.ENGINE.connect()
    df.to_sql(name=tablename, con=conn, if_exists='append', index=False)
    conn.close()
    print('%s updated.'%tablename)

df = pd.read_csv('traindata_jiangsu_donghai.csv')
df_save_db(df,'traindata_jiangsu_donghai')

到此這篇關(guān)于python實(shí)現(xiàn)sqlalchemy的使用的文章就介紹到這了,更多相關(guān)python sqlalchemy使用內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • python數(shù)據(jù)庫(kù)如何連接SQLite詳解
  • Python流行ORM框架sqlalchemy的簡(jiǎn)單使用
  • python中的mysql數(shù)據(jù)庫(kù)LIKE操作符詳解
  • Python3 MySQL 數(shù)據(jù)庫(kù)連接的使用示例
  • python配置mssql連接的方法
  • python 操作sqlite數(shù)據(jù)庫(kù)的方法
  • 適合Python項(xiàng)目的五大SQL連接器

標(biāo)簽:普洱 林芝 寧夏 大同 海南 盤錦 南平 漯河

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《python實(shí)現(xiàn)sqlalchemy的使用概述》,本文關(guān)鍵詞  python,實(shí)現(xiàn),sqlalchemy,的,使用,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《python實(shí)現(xiàn)sqlalchemy的使用概述》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于python實(shí)現(xiàn)sqlalchemy的使用概述的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    久久色精品视频| 黄色av免费在线播放| 成人在线免费电影| 成人在线免费在线观看| 欧美日韩一级黄| 日韩在线欧美| av在线不卡一区| 色哟哟国产精品| 17c国产在线| 国产精品中文字幕亚洲欧美| 亚洲一卡二卡三卡| 欧美日韩视频在线第一区| 男人在线资源站| 福利网站在线观看| 在线精品视频一区二区三四| 视频一区二区三区四区五区| 2019亚洲日韩新视频| 国产羞羞视频在线观看| h狠狠躁死你h高h| 成人有码视频在线播放| 国产九一视频| 精品久久久久一区二区国产| 欧美性欧美巨大黑白大战| 国产精品自在欧美一区| 国产稀缺精品盗摄盗拍| 天堂在线免费视频| 97久久夜色精品国产| 久久久久999| 警花av一区二区三区| 日韩精品中文字幕一区| 日本精品免费| 尤物yw午夜国产精品视频| 久热re国产手机在线观看| 国产视频一区不卡| 亚洲精品555| 欧美美女在线| 久激情内射婷内射蜜桃| av最新地址| 国产在视频线精品视频www666| 免费成人高清| 国产免费一级| 丝袜熟女一区二区三区| 农村少妇一区二区三区四区五区| 911精品国产一区二区在线| 久久国产毛片| 久久av高潮av无码av喷吹| 国产一区二区三区四区福利| 欧美一级淫片免费视频魅影视频| 日韩精品电影在线观看| 欧美视频xxx| 欧美丰满老妇熟乱xxxxyyy| 97色伦图片97综合影院| 4444亚洲人成无码网在线观看| 欧美日韩综合网| 国产精品三级视频| 精品蜜桃在线看| 天天影视涩香欲综合网| 亚洲人成免费网站| 欧美天堂亚洲电影院在线观看| 777久久久精品| 丰满人妻妇伦又伦精品国产| 亚洲成色www.777999| 草莓视频性福宝| 一区二区三区四区不卡在线| 九九精品免费视频| 91精品国产入口在线| 国产人妻精品一区二区三| 免费国产羞羞网站美图| 久久久久久久毛片| 免费在线观看污| 91久久久久久久久久久久久久| 国产亚洲精品精品精品| 色88久久久久高潮综合影院| 亚洲免费观看高清完整版在线观看熊| 91精品婷婷国产综合久久竹菊| 成人高清在线观看视频| 国产人妻大战黑人20p| eeuss性xxxxxx电影| 欧美猛男同性videos| 偷窥国产亚洲免费视频| 国产欧美日韩最新| 亚洲一区二区四区| 国产精品夜夜嗨| 欧美一级艳片视频免费观看| 在线电影欧美成精品| 欧美激情视频在线播放| 最近中文字幕在线6| 热久久免费视频精品| 美女在线观看视频一区二区| 中文字幕在线永久在线视频| 一本一本久久a久久精品综合小说| a√在线中文网新版址在线| 日韩免费视频网站| 日本我和搜子同居的日子高清在线| 九九热精品视频国产| 日韩视频一区二区| 69堂免费精品视频在线播放| 98精品久久久久久久| a级片免费在线观看| 精品黑人一区二区三区在线观看| 精品久久久噜噜噜噜久久图片| 国产精品视频二| 香蕉精品999视频一区二区| 国产成人一区二区三区小说| 深田咏美在线x99av| 美女脱光内衣内裤视频久久网站| 91久久久一线二线三线品牌| 不卡视频一区| 久久久久高潮毛片免费全部播放| 蜜臀av性久久久久蜜臀aⅴ四虎| 亚洲青青青在线视频| 黄色在线免费看| blackedav金发美女大战黑人| 亚洲第一综合| 中文字幕人妻一区二区三区在线视频| 先锋影音成人资源| 日韩女同互慰一区二区| 欧美日韩一区二区三区不卡| 中文在线视频观看| 欧美中文字幕一二三四区| 香港三级日本三级a视频| 国产精品不卡av| 国产欧美精品aaaaaa片| 欧美黄色激情视频| 亚洲欧洲精品在线观看| 亚洲精品人成| 久久福利一区| 啊啊啊啊啊啊啊视频在线播放| 先锋影音亚洲资源| 欧美日韩国产一区精品一区| 国产成人三级一区二区在线观看一| 九九精品在线| 日本不卡一区视频| xx免费视频| 国产精品美女久久久免费| 免费污污网站| 午夜欧美视频| 欧美亚洲视频一区二区| 亚欧日韩另类中文欧美| 超碰在线观看免费| 免费黄色国产视频| 欧美久久婷婷综合色| 国产大学生校花援交在线播放| 欧美人与拘性视交免费看| 欧美图片一区二区三区| 亚洲第一香蕉视频| 高清日韩欧美| 成人黄色在线观看视频| 精品日本美女福利在线观看| 中文字幕福利视频| 免费不卡中文字幕视频| 国产免费一区| 六十路息与子猛烈交尾| 国产精品系列在线播放| 日韩美女视频19| 国产日韩欧美精品一区二区三区| 先锋av在线资源| 特黄特色特刺激视频免费播放| 97热精品视频官网| 熟女人妻在线视频| 精品精品精品| 欧美黑人激情| 国产一区二区三区欧美| 国产免费区一区二区三视频免费| 六月天色婷婷| **亚洲第一综合导航网站| 女人18毛片九区毛片在线| 美女做a视频| 美国av在线播放| 国产综合久久久久久久久久久久| 日韩一区二区中文字幕| 日本美女一区二区三区| 久久99精品国产自在现线小黄鸭| 久久久99免费视频| 色狠狠色狠狠综合| 欧美成人在线直播| 动漫精品一区一码二码三码四码| 8x8x华人在线| av在线你懂的| 五月天国产视频| 亚洲一区二区三区乱码aⅴ蜜桃女| 福利视频第一页| 青青草精品在线视频| 秋霞在线观看一区二区三区| 日本激情视频在线播放| 国产精品一区二区三区视频网站| www成人免费观看| 91免费观看视频在线| 天天影视久久综合| 影音先锋成人在线电影| 国产98色在线| 欧美极品美女视频| 欧美日韩中文国产| 欧美激情第99页| 一个人看的www片免费高清视频| 国产在线观看你懂的| 97久久久久久久| 天堂俺去俺来也www久久婷婷| 欧美伦理一区二区| 婷婷久久久久久| 欧美精品中文字幕亚洲专区| 欧美日韩二三区| 人妻在线日韩免费视频| 国产精品不卡视频| 日韩精品三区四区| chinese偷拍一区二区三区| 天堂av免费在线| 国产网站一区二区三区| 国产精品视频一区二区三区四| 黄无遮挡免费网站| 成人男女网免费| 国产精品99久久久久久似苏梦涵| 亚洲国产一区二区在线| 精品日韩成人av| 欧美性性性性性ⅹxxbbbb| 久久久久这里只有精品| 国产精品999久久久| 一区三区二区视频| 欧美成人激情视频| 欧美精品v日韩精品v韩国精品v| 欧美精品aaa| 女同性恋一区二区三区| 日本中文字幕在线视频观看| 庆余年2免费日韩剧观看大牛| 亚洲欧美日韩人成在线播放| 又黄又爽又色的视频| 亚洲精品中文字幕在线| 欧美承认网站| 精品69视频一区二区三区| 国产嫩草在线观看| 清纯唯美日韩| 亚洲成人精品在线| 亚洲激情自拍| av网站一区| 亚洲国产你懂的| 国产av无码专区亚洲av毛网站| 另类中文字幕国产精品| av女优在线播放| 国产精品日韩欧美大师| 欧美午夜一区二区三区免费大片| 成人激情文学综合网| 欧美日韩亚洲综合在线 欧美亚洲特黄一级| 欧美精品video| 菠萝蜜视频国产在线播放| 最新91在线视频| www.17c.com喷水少妇| 精品免费一区二区| 日本网站在线免费观看| 综合色婷婷一区二区亚洲欧美国产| 精品国产一区二区三区不卡蜜臂| 亚洲精品中文在线影院| 亚洲自拍小视频| 性欧美精品一区二区三区在线播放| 三级a性做爰视频| 吴梦梦av在线| 日韩极品视频在线观看| 公侵犯人妻一区二区三区| 亚洲精品视频在线播放| 色猫av在线| 国产精品日本精品| 中文字幕在线免费专区| 亚洲人体大胆视频| 国产成人手机高清在线观看网站| 日本综合一区二区三区| 中文字幕福利视频| 国产一区二区三区亚洲综合| 波多野结衣手机在线视频| 欧美精品一区二区三区高清aⅴ| 天堂在线中文网官网| 亚洲第一区色| 亚洲a一区二区| 波多野吉衣在线视频| 日韩成人av在线播放| 99热99这里只有精品| 国产精品99导航| 手机看片日韩国产| 精品久久久久久久久久岛国gif| 国产一区二区调教| 亚洲精品乱码久久久久久蜜桃91| 日本一区二区三区网站| 偷拍视屏一区| 亚洲午夜精品国产| 国产精品久久久久9999赢消| 福利在线一区二区三区| 国产粉嫩一区二区三区在线观看| 亚洲丁香日韩| 成人全视频在线观看在线播放高清| 嫩草影院一区二区| av日韩在线免费观看| aiss精品大尺度系列| 日韩影院在线| 国产精品7777777| 鲁大师影院一区二区三区| 女同性αv亚洲女同志| 亚洲一区二区三区日本久久九| 国产特级毛片| 国产精品视频免费看| 国产精品久久久久久久久久ktv| 区二区三区在线| 欧美激情久久久久久久久久久| 91黄色免费网站| 久久久三级国产网站| 4438x亚洲最大成人网| 蜜桃av一区| 日本道在线视频| 亚洲激情在线观看视频免费| 成人短剧在线观看| 97精品国产97久久久久久| 神马影院我不卡| 91精品国产91久久久久久一区二区| 国产精品久久久久久久久动漫| 欧美成人在线免费视频| 色婷婷av国产精品| 黄一区二区三区| 国产大尺度视频| 久久99精品视频一区97| 三级精品视频| 紧缚捆绑精品一区二区| 欧美一级免费片| 亚洲精品一区二区三区四区| 2018中文字幕第一页| 日本不卡高清| 亚洲在线视频播放| 欧美一级免费大片| www.xxx麻豆| 丰满肉肉bbwwbbww| 在线观看国产成人av片| 欧美成人激情免费网|