首頁 > 軟體

Python練習之操作MySQL資料庫

2022-06-13 18:03:33

文章介紹內容:

操作MySQL資料庫:

  • 建立MySQL資料表;
  • 向表中插入記錄;
  • 其他資料庫操作。

面試題:

  • 如何建立MySQL資料表?
  • 如何向MySQL表中插入資料?
  • 如何查詢MySQL中的資料?

一、建立MySQL資料表

# coding=utf-8
from pymysql import *
def connectDB():
    '''
    連線本地MySQL資料庫,指定連線的庫為test庫。
    :return:
    '''
    db = connect(host='localhost', user='root', password='123456', port=3306, db='test')
    return db
db = connectDB()
print(type(db))
def createTable(db):
    c = db.cursor()
    try:
        c.execute('''create table persons
                    (id int primary key not null,
                    name text not null,
                    age int not null,
                    address char(100),
                    salary real);''')
        db.commit()
        db.commit()
        return True
    except:
        db.rollback()
    return False
if createTable(db):
    print('create table success')
else:
    print('create table failed')

使用navicat工具檢視: 

三、向MySQL表中插入資料

# coding=utf-8
from pymysql import *
def connectDB():
    '''
    連線本地MySQL資料庫,指定連線的庫為test庫。
    :return:
    '''
    db = connect(host='localhost', user='root', password='123456', port=3306, db='test')
    return db
db = connectDB()
print(type(db))
def insertRecords(db):
    cursor = db.cursor()
    try:
        cursor.execute("delete from persons")
        cursor.execute('''
        insert into persons(id,name,age,address,salary)
        values(1, 'GuHanZhe', 18, 'China', 9999)
        ''')
        cursor.execute('''
        insert into persons(id,name,age,address,salary)
        values(2, 'XiaoZhang', 55, 'China', 9)
        ''')
        db.commit()
        return True
    except Exception as e:
        print(e)
        db.rollback()
    return False
if insertRecords(db):
    print("成功插入記錄")
else:
    print("插入記錄失敗")

使用navicat工具檢視:

三、查詢MySQL中的資料

# coding=utf-8
from pymysql import *
def connectDB():
    '''
    連線本地MySQL資料庫,指定連線的庫為test庫。
    :return:
    '''
    db = connect(host='localhost', user='root', password='123456', port=3306, db='test')
    return db
db = connectDB()


def selectRecords(db):
    cursor = db.cursor()
    sql = 'select name,age,salary from persons order by age desc'
    cursor.execute(sql)
    results = cursor.fetchall()
    print(results)
    print(type(results))    # 列印發現是元組型別

selectRecords(db)
db.close()

  • 我們發現查詢資料輸出型別是元組型別,如果我們想要將欄位名和查詢出的資料一一對應該怎麼做呢?
  • 這裡就需要用到兩個很常用的函數dict()和zip(),如下:
# coding=utf-8
import json
from pymysql import *
def connectDB():
    '''
    連線本地MySQL資料庫,指定連線的庫為test庫。
    :return:
    '''
    db = connect(host='localhost', user='root', password='123456', port=3306, db='test')
    return db
db = connectDB()


def selectRecords(db):
    cursor = db.cursor()
    sql = 'select name,age,salary from persons order by age desc'
    cursor.execute(sql)
    results = cursor.fetchall()
    print(results)
    print(type(results))    # 列印發現是元組型別

    # 將欄位名和查詢結果整合在一起
    fields = ['name', 'age', 'salary']
    records = []
    for row in results:
        records.append(dict(zip(fields, row)))
    return json.dumps(records)      # 輸出型別為JSON字串
endresults = selectRecords(db)
print(endresults)
db.close()

總結

注意:我們使用的是pymysql模組中的API來操作MySQL資料庫,該模組需要單獨安裝

到此這篇關於Python練習之操作MySQL資料庫的文章就介紹到這了,更多相關Python 操作MySQL內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com