关于Python连接MySQL数据库

在关于Python的使用,不管是机器学习、web开发或者爬虫,数据库都是绕不过去的。那么今天就来介绍一下关于Python如何和MySQL数据库进行连接以及数据的交换,主要是分一下方面:

  • 什么是数据库?
  • 什么是MySQLdb?
  • Python如何连接数据库?
  • 创建MySQL数据库
  • 数据库操作–CRUD

什么是数据库
数据库基本上是结构化数据的集合,通过数据库可以用各种方式轻松地检索、管理和访问数据。最简单的数据库形式之一是文本数据库。目前关系数据库是最流行的数据库系统,目前主流的关系数据库主要有以下几个:

  • MySQL
  • Oracle Database
  • SQL server
  • Sybase
  • Informix
  • IBM db2
  • NO SQL
    其中MySQL是最容易使用的数据库,也是这次主要介绍的。

什么是MySQLdb
MySQLdb是一个开元免费的关系数据库管理系统,它使用结构化查询语言,SQL(结构化查询语言)是关系数据库的标准语言,允许用户对数据进行各种操作,如操作、创建、删除等。简而言之,SQL允许用户对数据执行任何操作。

Python如何连接数据库
在连接MySQL数据库之前,确保在计算机上安装了MySQL应用程序,也可以使用远程的数据库,MySQL应用程序提供了一些数据工具:MySQL服务器、所有可用的连接器、MySQL Workbench、MySQL通知程序、用于Excel和Microsoft Visual Studio的工具、MySQL示例数据库、MySQL文档。

安装好应用程序以后,我们还需要安装python对应的MySQL函数库mysql.connector,这个可以直接使用pip进行安装。连接数据库需要的基本参数是:

  • 用户名:为MySQL服务器工作的用户名,默认的用户名是root;
  • 密 码:密码由用户在安装MySQL数据库提供。这里我使用的是我的mysql密码,修改密码具体参考CSDN中一些关于数据库密码的博文;
  • 主机名:运行MySQL的服务器名称或者IP地址,如果是’localhost’,那么IP地址是127.0.0.0
    以下是使用Python连接数据库的程序
import mysql.connector
mydb = mysql.connector.connect(host = 'localhost', user = 'root', passwd = 'password123')
print(mydb)

运行程序输出为:

C:UsersHarshit_KantPycharmProjectstest1venvScriptspython.exe C:/Users/Harshit_Kant/PycharmProjects/test1/venv/python-db-conn.py
<mysql.connector.connection_cext.CMySQLConnection object at 0x000001606D7BD6A0>

这里的“mydb”只是一个示例,从输出中可以清楚地看到Python已经连接到的数据库。

创建数据库
经过上一步,我们已经可以成功的建立数据库链接了,现在就可以创建自己的数据库,它将充当python和MySQL服务器之间数据交流的桥梁。建立数据库的代码如下:

import mysql.connector
mydb = mysql.connector.connect(host = 'localhost', user = 'root', passwd = 'password123')
mycursor = mydb.cursor( )
mycursor.execute('create database harshdb')

程序说明:

  • 在上面的程序中使用了游标,它基本上是一个用于与整个MySQL服务器通信的对象,通过它我们可以创建自己的数据库;
  • 我们还可以从输出中看到创建了一个名为“harshdb”的数据库,该数据库是自定义的,因为我们可以为数据库指定任何名称。

如果我们想要查看服务器中已经建立的数据库,可以使用以下代码:

import mysql.connector
mydb = mysql.connector.connect(host = 'localhost', user = 'root', passwd = 'password123')
mycursor = mydb.cursor( )
mycursor.execute('show databases')
for db in mycursor:
	print(db)

输出示例

('harshdb')
('information_schema')
('mysql')
('performance_schema')
······

数据库操作
数据库的基本操作:增删改查,下面我们通过示例程序来看基本使用方法。
增(创建操作):用于在表中创建记录的SQL语句,或者可以说它用于创建表,代码如下:

import mysql.connector
mydb=mysql.connector.connect(host="localhost",user="root",passwd="password123",database=harshdb)
mycursor=mydb.cursor()
mycursor.execute("create table employee(name varchar(250),sal int(20))")

程序说明:

  • 在上面给出的程序中,创建了一个表’employee’
  • 表员工有两个字段’name’、‘sal’,用于访问harshdb
    下面的截图显示了表’employee’并返回字段’name’、'sal’在这里插入图片描述读取写入:用于从数据库中获取有用信息。代码示例如下
import mysql.connector
mydb=mysql.connector.connect(host="localhost",user="root",passwd="password123",database="harshdb")
mycursor=mydb.cursor()
sqlformula = "Insert into employee(name,sal) values(%s,%s)"//'values has placeholders
employees = [("harshit",200000),("rahul", 30000),("avinash", 40000),("amit", 50000),]//Created an array of emplpoyees
mycursor.executemany(sqlformula, employees)//Passing the data
mydb.commit()//SQL statement used for saving the changes

在上面的代码中,我们通过在Python中编写SQL语句写入一组员工数据,写入之后数据库的屏幕截图显示如下:在这里插入图片描述
更新操作:用于更新表中的记录或者更新表。代码如下

import mysql.connector
mydb=mysql.connector.connect(host="localhost",user="root",passwd="password123",database="harshdb")
mycursor=mydb.cursor()
sql = "Update employee SET sal = 70000 WHERE name = 'harshit'"
mycursor.execute(sql)
mydb.commit()

程序说明:我们在上面给出的代码中更新了harshit的行“sal”。下面给出的数据库截图显示更新结果。
在这里插入图片描述
删除操作:用于删除表格记录,代码如下

import mysql.connector

mydb = mysql.connector.connect(host =“localhost”,user =“root”,passwd =“password123”,database =“harshdb”)
mycursor = mydb.cursor()

sql =“DELETE FROM employee WHERE name ='harshit'“

mycursor.execute(sql)

mydb.commit()

程序说明:在上面的代码中,删除了一条’harshit’的重复记录。

Python连接数据库还有一个pymysql函数包,该包也十分简单且方便的与数据库进行交互,大家可以尝试一下。

参考原文

侵删

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值