日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

mysql 导出数据字典_操作MySQL?这个库比pymysql香一百倍

發布時間:2024/7/23 数据库 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mysql 导出数据字典_操作MySQL?这个库比pymysql香一百倍 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

原創: 阿亮 Python極客社區

操作MySQL,我們都習慣于用pymsq,基本流程就是

  • 創建連接
  • 創建游標
  • 執行SQL
  • 關閉連接
  • 代碼是這樣的

    import pymysql# 1.創建連接conn = pymysql.connect(host='127.0.0.1', port=3306, user='root', password='root', charset='utf8')# 2.創建游標cursor = conn.cursor()# 3.執行sql語句cursor.execute('select * from user where xxx')result=cursor.execute(sql) #執行sql語句,返回sql查詢成功的記錄數目# 關閉連接,游標和連接都要關閉cursor.close()conn.close()


    而今天要說的庫,可以快速的進行查詢,比pymysql好使,不再需要操作游標。即:records庫,網上關于這個庫的資料其實并不多。

    什么?你沒聽過,所以不敢用?那你總知道requests庫吧,其實這兩個庫都是同一個作者寫的。

    這個庫不光支持MySQL,同樣還只是PostgreSQL,SQLite,Oracle等..

    項目地址:https://github.com/kennethreitz/records

    安裝 : pip install records mysqlclient

    創建一個user_demo表

    import records# 獲取數據庫連接db = records.Database('mysql+pymysql://root:root@localhost:3306/records_test')# 創建表的sqlcreate_sql = """CREATE TABLE IF NOT EXISTS user_demo ( id int(11) PRIMARY KEY AUTO_INCREMENT, name varchar(20), age int);"""# 執行db.query(create_sql)


    獲取數據庫連接的格式是標準的url格式具體看下圖

    插入數據

    對于records,插入單條和多條數據都比較方便,而且還支持動態加載數據。

    # 獲取數據庫連接db = records.Database('mysql+pymysql://root:root@localhost:3306/records_test')# 插入一條數據db.query("INSERT INTO user_demo(name, age) VALUE ('tom', 19)")# 通過參數傳值動態插入一條user = {'name': 'liming', 'age': 20}db.query("INSERT INTO user_demo(name, age) VALUE (:name, :age)", **user)# 插入多條users = [ {'name': '二狗子', 'age': 14}, {'name': '二柱子', 'age': 12}, {'name': '翠花', 'age': 9}]# records的bulk_query方法支持插入和更新多條數據db.bulk_query ("INSERT INTO user_demo(name, age) VALUES (:name, :age)", users)

    執行之后,再查詢數據庫,發現都正常插入了;

    mysql> select * from user_demo;+----+--------+------+| id | name | age |+----+--------+------+| 1 | tom | 19 || 2 | liming | 20 || 3 | 二狗子 | 14 || 4 | 二柱子 | 12 || 5 | 翠花 | 9 |+----+--------+------+5 rows in set (0.00 sec)

    查詢數據

    records默認是返回封裝的RecordCollection對象,當然我們也可以通過調整某些參數,獲取到不一樣的數據類型。

    • as_dict = True:通過字典的形式返回數據
    • as_ordereddict=True:以排序字典的形式返回數據

    代碼示例:

    rows = db.query('select * from user_demo')# 獲取全部數據print(rows.all())# 獲取第一條數據print(rows.first()) # # 以字典的形式獲取數據print(rows.all(as_dict=True))print(rows.first(as_dict=True))# 排序字典print(rows.first(as_ordereddict=True)) # OrderedDict([('id', 1), ('name', 'tom'), ('age', 19)])

    事務

    數據庫事務是構成單一邏輯工作單元的操作合集,生活中最好的例子就是轉賬操作,A給B轉賬100元,先從A的賬戶扣除100,再給B的賬戶加100。如果再給B賬戶加100的過程程序出現異常,就會導致A莫名其妙的被扣了100。事務就是用來解決這種問題的,保證一個執行單元,要么都執行成功,要么就都不成功。

    records同樣也支持事務。代碼如下:

    with db.transaction() as t: user1 = {'name': '狗蛋', 'age': 8} user2 = {'id': 1, 'name': '錘子', 'age': 10} t.query("INSERT INTO user_demo(name, age) VALUE (:name, :age)", **user1) print("user1 已執行插入...") t.query("INSERT INTO user_demo(id,name, age) VALUE (:id,:name, :age)", **user2) print('user2 已執行插入...')

    數據存中已經存在了id為1的信息,因此執行user2的時候,會導致主鍵沖突。 控制臺輸出:

    user1 已執行插入...

    并沒有輸出‘user2 已執行插入...’ 說明執行插入user2的時候出現了主鍵沖突(數據庫中已經存在id為1的數據了)。再去查看數據庫,發現并沒有name為狗蛋的數據,說明這是一個數據庫事務的過程。在執行user2失敗的時候,將已經執行成功的user1,進行了事務回滾。

    數據導出

    有時候我們需要將數據庫的數據進行導出,比如存成文本或者Excel。強大的records可以直接進行導出操作。

    導出csv文件

    rows = db.query('select * from user_demo')with open('user_demo.csv', 'wb') as f: f.write(rows.export('xlsl'))

    同樣可以導出yaml、json、xlsl、pandas、html等格式。導出方法為

    rows.export('你要導出的格式')

    例如導出Html格式:

    rows = db.query('select * from user_demo')with open('user_demo.html', 'wb') as f: f.write(rows.export('html').encode('utf-8'))


    最后,我自己是一名從事了多年開發的Python老程序員,辭職目前在做自己的Python私人定制課程,今年年初我花了一個月整理了一份最適合2019年學習的Python學習干貨,可以送給每一位喜歡Python的小伙伴,想要獲取的可以關注我的頭條號并在后臺私信我:01,即可免費獲取。

    總結

    以上是生活随笔為你收集整理的mysql 导出数据字典_操作MySQL?这个库比pymysql香一百倍的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    主站蜘蛛池模板: 国产日韩欧美不卡 | 国产亚洲精品久久久久久久久动漫 | 国产夜夜夜 | 裸体一区二区三区 | 中文字幕在线观看播放 | 一级黄色录像大片 | 久久久精品人妻一区二区三区四 | 无码人妻一区二区三区在线视频 | 人妻少妇无码精品视频区 | 国产曰肥老太婆无遮挡 | 亚洲精品在线电影 | 国产精品久久久毛片 | 日韩欧美性视频 | 亚洲老女人视频 | 午夜福利电影一区二区 | 日日撸视频| 免费毛片网 | 欧美中文字幕第一页 | mm1313亚洲国产精品无码试看 | 国产一级二级三级 | 久久亚洲精品无码va白人极品 | 制服丝袜影音先锋 | 日韩久久影院 | 亚洲怡红院av | 久久久久99精品成人片我成大片 | 人妻妺妺窝人体色www聚色窝 | a级片中文字幕 | 色香蕉在线 | 九一爱爱| 三级三级久久三级久久18 | 男女午夜爽爽爽 | 男女交性视频 | 草1024榴社区成人 | 日韩欧美久久久 | 人人干人人看 | 日韩一级片免费 | 开心激情播播 | 欧洲一区二区三区在线 | 男人天堂视频网站 | 国内外免费激情视频 | 日韩精品成人一区二区在线 | 又大又硬又爽免费视频 | 黄色片子看看 | www.亚洲色图.com| 国产亚洲精品久久久久婷婷瑜伽 | 免费操 | 国产视频在线免费观看 | 少妇被躁爽到高潮 | aaa久久| 久色综| 日本免费一区二区三区最新 | 中文字幕一区二区三 | 美女被到爽高潮视频 | 99re8在线精品视频免费播放 | 欧美日韩在线免费视频 | 9.1在线观看免费 | 久草手机在线视频 | 手机av免费观看 | 嫩草影院久久 | 夜夜操夜夜摸 | 亚洲综合中文字幕在线 | 色婷婷免费视频 | 国产精品麻豆一区二区 | 亚洲精品久久久久 | 玖玖热视频 | 亚洲国产午夜 | 国产9区| 欧美 日韩 国产在线 | 亚洲九九视频 | 亚洲欧美日本一区二区 | 久久99精品国产麻豆婷婷 | 自拍偷拍五月天 | 人妻无码中文久久久久专区 | 萌白酱在线观看 | 免费看黄色网址 | 日韩视频一区二区三区 | 亚洲一区二区在线视频 | 中文字幕一区二区三区精华液 | av资源免费观看 | 国产在线视视频有精品 | 人妻丰满熟妇无码区免费 | 森泽佳奈av| 国产国语亲子伦亲子 | 欧美a久久| 4438全国成人免费 | 日本少妇18p| 岛国中文字幕 | 色多多视频在线 | 亚洲男人的天堂av | 深夜激情影院 | 在线观看亚洲 | 天天综合久久 | 高清一区二区三区四区五区 | 麻豆视频在线观看 | 日韩网| www久久久| 日韩一区二区三区在线观看视频 | 在线免费观看不卡av | 国产最新毛片 |