Python练习之操作MySQL数据库

作者:??孤寒者???? 时间:2024-01-20 12:29:22 

文章介绍内容:

操作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')

Python练习之操作MySQL数据库

使用navicat工具查看: 

Python练习之操作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 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("插入记录失败")

Python练习之操作MySQL数据库

使用navicat工具查看:

Python练习之操作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()

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()

Python练习之操作MySQL数据库

  • 我们发现查询数据输出类型是元组类型,如果我们想要将字段名和查询出的数据一一对应该怎么做呢?

  • 这里就需要用到两个很常用的函数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()

Python练习之操作MySQL数据库

来源:https://juejin.cn/post/7101921300704133151

标签:Python,操作,MySQL,数据库
0
投稿

猜你喜欢

  • python批量下载网站马拉松照片的完整步骤

    2023-08-31 19:00:27
  • 解决PyCharm import torch包失败的问题

    2023-12-05 14:27:24
  • python控制windows剪贴板,向剪贴板中写入图片的实例

    2021-03-27 07:35:31
  • python输出电脑上所有的串口名的方法

    2022-06-23 20:56:03
  • ajax标签导航实例详解教程

    2008-02-01 10:54:00
  • python yield关键词案例测试

    2021-02-07 03:14:07
  • python 实现简单的FTP程序

    2021-03-29 10:33:00
  • opencv-python 提取sift特征并匹配的实例

    2022-01-25 03:43:18
  • Python数据库sqlite3图文实例详解

    2024-01-15 07:50:33
  • Python类继承及super()函数使用说明

    2023-12-06 19:23:07
  • python文件读取失败怎么处理

    2023-05-06 17:14:46
  • Python函数式编程实现登录注册功能

    2022-02-16 14:03:31
  • Python实现葵花8号卫星数据自动下载实例

    2021-09-26 13:40:25
  • PyTorch学习笔记之回归实战

    2023-09-17 10:26:19
  • Python编程中字符串和列表的基本知识讲解

    2022-02-19 16:39:25
  • 用python 绘制茎叶图和复合饼图

    2023-08-04 10:34:54
  • 快速一键生成Python爬虫请求头

    2022-05-21 01:00:53
  • PDO::getAttribute讲解

    2023-06-06 02:58:22
  • centos下安装配置phpMyAdmin的方法步骤

    2023-11-09 01:27:11
  • 多个域名后缀同时查询的域名查询系统代码

    2008-05-20 11:53:00
  • asp之家 网络编程 m.aspxhome.com