python操作mysql(ORM)

使用SQLAlchemy

安裝方法
pip install SQLAlchemy

更多內(nèi)容參考flask魚(yú)書(shū)項(xiàng)目

from sqlalchemy import create_engine

from sqlalchemy.ext.declarative import declarative_base 
from sqlalchemy import Column, Integer, String ,DateTime, Boolean

# 連接數(shù)據(jù)庫(kù)
engine = create_engine('mysql://root:password@localhost:3306/school?charset=utf8')
## 編碼問(wèn)題

# # 獲取基類
Base = declarative_base()

class News(Base): # 繼承基類
    __tablename__ = 'students1'
    id = Column(Integer, primary_key = True)
    nickname = Column(String(20))
    name = Column(String(20), nullable = False)
    sex = Column(String(1))
    in_time = Column(DateTime)
    is_vaild = Column(Boolean)
    idcard = Column(Integer, unique = True)
        
News.metadata.create_all(engine)   # 創(chuàng)建表格

## 新增數(shù)據(jù)
from sqlalchemy.orm import sessionmaker
Session = sessionmaker(bind=engine)

class OrmTest(object):
    def __init__(self):
        self.session = Session()

    def add_one(self):
        new_obj = News(
            nickname = '123',
            name = '321',
            sex = '男',
        )
        self.session.add(new_obj)
        self.session.commit()
        return new_obj

    def add_more(self):
        new_obj = News(
            nickname = '123',
            name = '321',
            sex = '男',
        )
        new_obj2 = News(
            nickname = 'wei',
            name = 'lai',
            sex = '女',
        )
        self.session.add_all([new_obj,
                        new_obj2])
        self.session.commit()
        return new_obj

## 查詢數(shù)據(jù)        
    def get_one(self):
        return self.session.query(News).get(10)  # get 是選id為2的

    def get_more(self):
        return self.session.query(News).filter_by(is_vaild=True)


## 修改數(shù)據(jù)
## 將一條當(dāng)作多條的一種情況
    def update_data(self):
        data_list = self.session.query(News).filter(News.id >= 5)
        for item in data_list:
            if item:
                item.is_vaild = 0 
                self.session.add(item)  # 加入
        self.session.commit()  # 提交
## filter 與 filter_by 的區(qū)別


## 刪除數(shù)據(jù)
    def delete_data(self):
        data = self.session.query(News).get(8)
        if data:
            self.session.delete(data)
            self.session.commit()
        else:
            return False

    def delete_data_more(self):
        delete_list = self.session.query(News).filter(News.id <= 5)
        for item in delete_list:
            if item:
                self.session.delete(item)       
            else:
                return False
        self.session.commit() 



def main():
    obj = OrmTest()
    obj.add_one()
    obj.add_more()

    data = obj.get_one() 

    ## 防止查詢失誤
    if data:  
        print('ID:{0}  {1}'.format(data.id,data.sex))
    else:
        print('Not exist')

    data_more = obj.get_more()
    print(data_more.count())  # 計(jì)數(shù)
    for new_obj in data_more:
        print('ID:{0}  {1} {2} {3}'.format(new_obj.id,new_obj.sex,new_obj.name,new_obj.nickname))

    obj.update_data()
    print('數(shù)據(jù)修改成功')
    
    obj.delete_data()
    print('數(shù)據(jù)刪除成功')

    obj.delete_data_more()


if __name__ == '__main__':
    main()
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末囱皿,一起剝皮案震驚了整個(gè)濱河市蜕青,隨后出現(xiàn)的幾起案子却汉,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,591評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)索抓,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,448評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人逼肯,你說(shuō)我怎么就攤上這事耸黑。” “怎么了篮幢?”我有些...
    開(kāi)封第一講書(shū)人閱讀 162,823評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵大刊,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我三椿,道長(zhǎng)缺菌,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,204評(píng)論 1 292
  • 正文 為了忘掉前任搜锰,我火速辦了婚禮伴郁,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘蛋叼。我一直安慰自己焊傅,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,228評(píng)論 6 388
  • 文/花漫 我一把揭開(kāi)白布狈涮。 她就那樣靜靜地躺著狐胎,像睡著了一般。 火紅的嫁衣襯著肌膚如雪薯嗤。 梳的紋絲不亂的頭發(fā)上顽爹,一...
    開(kāi)封第一講書(shū)人閱讀 51,190評(píng)論 1 299
  • 那天纤泵,我揣著相機(jī)與錄音骆姐,去河邊找鬼。 笑死捏题,一個(gè)胖子當(dāng)著我的面吹牛玻褪,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播公荧,決...
    沈念sama閱讀 40,078評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼带射,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了循狰?” 一聲冷哼從身側(cè)響起窟社,我...
    開(kāi)封第一講書(shū)人閱讀 38,923評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎绪钥,沒(méi)想到半個(gè)月后灿里,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,334評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡程腹,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,550評(píng)論 2 333
  • 正文 我和宋清朗相戀三年匣吊,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,727評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡色鸳,死狀恐怖社痛,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情命雀,我是刑警寧澤蒜哀,帶...
    沈念sama閱讀 35,428評(píng)論 5 343
  • 正文 年R本政府宣布,位于F島的核電站吏砂,受9級(jí)特大地震影響凡怎,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜赊抖,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,022評(píng)論 3 326
  • 文/蒙蒙 一统倒、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧氛雪,春花似錦房匆、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,672評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至弦追,卻和暖如春岳链,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背劲件。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,826評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工掸哑, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人零远。 一個(gè)月前我還...
    沈念sama閱讀 47,734評(píng)論 2 368
  • 正文 我出身青樓苗分,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親牵辣。 傳聞我的和親對(duì)象是個(gè)殘疾皇子摔癣,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,619評(píng)論 2 354

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