Python交互數(shù)據(jù)庫(Mysql | Mongodb | Redis)

數(shù)據(jù)庫

Mysql

Mysql

MySQL是一個關(guān)系型數(shù)據(jù)庫管理系統(tǒng)余佛,由瑞典MySQL AB公司開發(fā)柠新,后來被Sun公司收購,Sun公司后來又被Oracle公司收購辉巡,目前屬于Oracle旗下產(chǎn)品

MySQL 軟件采用了雙授權(quán)政策恨憎,它分為社區(qū)版和商業(yè)版,由于其體積小红氯、速度快框咙、總體擁有成本低咕痛,尤其是開放源碼這一特點痢甘,一般中小型網(wǎng)站的開發(fā)都選擇MySQL作為網(wǎng)站數(shù)據(jù)庫.

創(chuàng)建數(shù)據(jù)庫

create database zhaozhao charset=utf8;

use zhaozhao;


create table zhaozhao_comic(

    id int unsigned primary key auto_increment not null,
    name varchar(100),
    zone varchar(100) 


);

insert into zhaozhao_comic values
    (0, "旋渦鳴人", "木葉村"),
    (0, "蘇蘇", "涂山"),
    (0, "曹焱兵", "鎮(zhèn)魂街"),
    (0, "坂田銀時", "萬事屋");


操作數(shù)據(jù)庫

from pymysql import *

def main():
    # 創(chuàng)建Connection連接
    conn = connect(host='172.16.221.143',port=3306,database='zhaozhao',user='root',password='root',charset='utf8')
    
    # 獲得Cursor對象
    cs1 = conn.cursor()
    # 執(zhí)行insert語句,并返回受影響的行數(shù):添加一條數(shù)據(jù)

    # 增加
    count = cs1.execute('insert into zhaozhao_comic(name, zone) values("我愛羅", "風(fēng)之國"),("奇拉比", "雷之國")')
    # 打印受影響的行
    print ("共有",count, "行受影響!")
    count = cs1.execute('insert into zhaozhao_comic values(0, "奧特曼", "M78星云")')
    # 打印受影響的行
    print ("共有",count, "行受影響!")

    # 執(zhí)行
    conn.commit()

    # 刪除
    count = cs1.execute('delete from zhaozhao_comic where name = "奇拉比" ')
    # 打印受影響的行
    print ("共有",count, "行受影響!")
    # 執(zhí)行
    conn.commit()

    # 更改
    count = cs1.execute('update zhaozhao_comic set name="賽羅奧特曼" where name="奧特曼"')
    # 打印受影響的行
    print ("共有",count, "行受影響!")
    # 執(zhí)行
    conn.commit()
    
    # 查詢
    count = cs1.execute('select * from zhaozhao_comic where id < 5')
    # 打印受影響的行
    print ("共查到",count, "行數(shù)據(jù)!")

    for i in range(count):

        result = cs1.fetchone()
        print ("第%d次查到的數(shù)據(jù)為%s:"%(i+1, result))

    # 關(guān)閉Cursor對象
    cs1.close()
    # 關(guān)閉Connection對象
    conn.close()

if __name__ == '__main__':
    main()

Mongdb

Mongdb

MongoDB 是一個基于分布式文件存儲的NoSQL數(shù)據(jù)庫.
MongoDB由C++語言編寫茉贡,運行穩(wěn)定塞栅,性能高.
MongoDB旨在為WEB應(yīng)用提供可擴(kuò)展的高性能數(shù)據(jù)存儲解決方案.

from pymongo import *

def main():
    
    # 創(chuàng)建連接對象
    client=MongoClient(host='localhost',port=27017)

    # 獲得數(shù)據(jù)庫,此處使用python數(shù)據(jù)庫
    db=client.python

    # 增加
    
    db.stu.insert_one({'name':'佐助','gender':'男'})
    db.stu.insert_one({'name':'春野櫻','gender':'女'})
    db.stu.insert_one({'name':'蒙奇 D 路飛','gender':'男'})
    db.stu.insert_one({'name':'索隆','gender':'男'})
    db.stu.insert_one({'name':'娜美','gender':'女'})


    # 查詢

    #查詢一條文檔
    result=db.stu.find_one({'name':'索隆'})
    print (result)

    #查詢多條文檔
    result=db.stu.find({'gender':'男'})

    for item in result:
        print ('%s--%s'%(item['name'],item['gender']))


    # 修改

    #更新滿足條件的第一條文檔
    db.stu.update_one({'name':'佐助'},{'$set':{'name':'宇智波佐助'}})

    #更新滿足條件的所有文檔
    db.stu.update_many({'gender':"男"},{'$set':{'gender':'boy'}})


    # 刪除
    # 刪除滿足條件的第一條文檔
    db.stu.delete_one({'gender':'男'})

    #刪除滿足條件的所有文檔
    db.stu.delete_many({'gender':'女'})


if __name__=='__main__':
    main()


redis

Redis

Redis是一個開源的使用ANSI C語言編寫腔丧、支持網(wǎng)絡(luò)放椰、可基于內(nèi)存亦可持久化的日志型、Key-Value數(shù)據(jù)庫愉粤,并提供多種語言的API砾医。從2010年3月15日起,Redis的開發(fā)工作由VMware主持.
Redis是一個開源(BSD許可)的衣厘、內(nèi)存中的數(shù)據(jù)結(jié)構(gòu)存儲系統(tǒng)如蚜,它可以用作數(shù)據(jù)庫、緩存和消息中間件.

from redis import *

def main():

    #創(chuàng)建StrictRedis對象影暴,與redis服務(wù)器建立連接
    sr=StrictRedis()

    # 添加

    #添加鍵py1错邦,值為gj
    result=sr.set('name','zhaozhao')
    #輸出響應(yīng)結(jié)果,如果添加成功則返回True型宙,否則返回False
    print ("添加結(jié)果:",result)

    # 查詢

    #獲取鍵py1的值
    result = sr.get('name')
    #輸出鍵的值撬呢,如果鍵不存在則返回None
    print ("獲取的值為:",result)


    # 修改

    #設(shè)置鍵py1的值,如果鍵已經(jīng)存在則進(jìn)行修改妆兑,如果鍵不存在則進(jìn)行添加
    result = sr.set('name','zhaozhaolee')
    #輸出響應(yīng)結(jié)果魂拦,如果操作成功則返回True,否則返回False
    print (result)

    # 刪除

    #設(shè)置鍵py1的值搁嗓,如果鍵已經(jīng)存在則進(jìn)行修改晨另,如果鍵不存在則進(jìn)行添加
    result = sr.delete('name')
    #輸出響應(yīng)結(jié)果,如果刪除成功則返回受影響的鍵數(shù)谱姓,否則則返回0
    print (result)



if __name__=="__main__":
    main()

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末借尿,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌路翻,老刑警劉巖狈癞,帶你破解...
    沈念sama閱讀 219,270評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異茂契,居然都是意外死亡蝶桶,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,489評論 3 395
  • 文/潘曉璐 我一進(jìn)店門掉冶,熙熙樓的掌柜王于貴愁眉苦臉地迎上來真竖,“玉大人,你說我怎么就攤上這事厌小』止玻” “怎么了?”我有些...
    開封第一講書人閱讀 165,630評論 0 356
  • 文/不壞的土叔 我叫張陵璧亚,是天一觀的道長讨韭。 經(jīng)常有香客問我,道長癣蟋,這世上最難降的妖魔是什么透硝? 我笑而不...
    開封第一講書人閱讀 58,906評論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮疯搅,結(jié)果婚禮上濒生,老公的妹妹穿的比我還像新娘。我一直安慰自己幔欧,他們只是感情好罪治,可當(dāng)我...
    茶點故事閱讀 67,928評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著琐馆,像睡著了一般规阀。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上瘦麸,一...
    開封第一講書人閱讀 51,718評論 1 305
  • 那天谁撼,我揣著相機(jī)與錄音,去河邊找鬼滋饲。 笑死厉碟,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的屠缭。 我是一名探鬼主播箍鼓,決...
    沈念sama閱讀 40,442評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼呵曹!你這毒婦竟也來了款咖?” 一聲冷哼從身側(cè)響起何暮,我...
    開封第一講書人閱讀 39,345評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎铐殃,沒想到半個月后海洼,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,802評論 1 317
  • 正文 獨居荒郊野嶺守林人離奇死亡富腊,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,984評論 3 337
  • 正文 我和宋清朗相戀三年坏逢,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片赘被。...
    茶點故事閱讀 40,117評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡是整,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出民假,到底是詐尸還是另有隱情浮入,我是刑警寧澤,帶...
    沈念sama閱讀 35,810評論 5 346
  • 正文 年R本政府宣布阳欲,位于F島的核電站舵盈,受9級特大地震影響陋率,放射性物質(zhì)發(fā)生泄漏球化。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,462評論 3 331
  • 文/蒙蒙 一瓦糟、第九天 我趴在偏房一處隱蔽的房頂上張望筒愚。 院中可真熱鬧,春花似錦菩浙、人聲如沸巢掺。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,011評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽陆淀。三九已至,卻和暖如春先嬉,著一層夾襖步出監(jiān)牢的瞬間轧苫,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,139評論 1 272
  • 我被黑心中介騙來泰國打工疫蔓, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留含懊,地道東北人。 一個月前我還...
    沈念sama閱讀 48,377評論 3 373
  • 正文 我出身青樓衅胀,卻偏偏與公主長得像岔乔,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子滚躯,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,060評論 2 355

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