序言

搭建MySQL环境MySQL Server。

请参考:https://blog.csdn.net/m0_37788308/article/details/79965378 或者 https://blog.csdn.net/qq_20788055/article/details/80372577

安装MySQL Workbench数据库管理工具。

请参考:http://www.xitongcheng.com/jiaocheng/win10_article_40089.html

MySQL Worbench使用教程:

http://c.biancheng.net/view/2625.html

mysql-connector 驱动

本章节我们为大家介绍使用 mysql-connector 来连接使用 MySQL, mysql-connectorMySQL 官方提供的驱动器。

我们可以使用 pip 命令来安装 mysql-connector

python -m pip install mysql-connector

使用以下代码测试 mysql-connector 是否安装成功:

import mysql.connector

创建数据库连接

可以使用以下代码来连接数据库:

import mysql.connector

mydb = mysql.connector.connect(
# host="127.0.0.1", # 数据库主机地址 localhost报错
host="localhost", # 数据库主机地址
user="PythonTest", # 数据库用户名
passwd="Jeremy123" # 数据库密码
) print(mydb)

创建数据库

创建数据库使用 "CREATE DATABASE" 语句,以下创建一个名为 runoob_db 的数据库:

import mysql.connector
# 创建数据库连接
mydb = mysql.connector.connect(
# host="127.0.0.1", # 数据库主机地址 localhost报错
host="localhost", # 数据库主机地址
user="root", # 数据库用户名
passwd="Jeremy123" # 数据库密码
)
# print(mydb) # 创建数据库
mycursor = mydb.cursor()
mycursor.execute("CREATE DATABASE runoob_db")

一般在创建数据库之前需要查看数据库是否已经存在:

import mysql.connector
# 创建数据库连接
mydb = mysql.connector.connect(
# host="127.0.0.1", # 数据库主机地址 localhost报错
host="localhost", # 数据库主机地址
user="root", # 数据库用户名
passwd="Jeremy123" # 数据库密码
)
mycursor = mydb.cursor() mycursor.execute("SHOW DATABASES") for x in mycursor:
print(x)

或者我们可以直接连接数据库,如果数据库不存在,会输出错误信息:

import mysql.connector
# 创建数据库连接
mydb = mysql.connector.connect(
# host="127.0.0.1", # 数据库主机地址 localhost报错
host="localhost", # 数据库主机地址
user="root", # 数据库用户名
passwd="Jeremy123" , # 数据库密码
database="runoob_db"
)

创建数据表

创建数据表使用 "CREATE TABLE" 语句,创建数据表前,需要确保数据库已存在,以下创建一个名为 sites 的数据表:

import mysql.connector

mydb = mysql.connector.connect(
host="localhost",
user="root",
passwd="Jeremy123",
database="runoob_db"
)
mycursor = mydb.cursor() mycursor.execute("CREATE TABLE sites (name VARCHAR(255), url VARCHAR(255))")

查看结果:

我们也可以使用 "SHOW TABLES" 语句来查看数据表是否已存在:

import mysql.connector

mydb = mysql.connector.connect(
host="localhost",
user="root",
passwd="Jeremy123",
database="runoob_db"
)
mycursor = mydb.cursor() mycursor.execute("SHOW TABLES") for x in mycursor:
print(x)

主键设置

创建表的时候我们一般都会设置一个主键(PRIMARY KEY),我们可以使用 "INT AUTO_INCREMENT PRIMARY KEY" 语句来创建一个主键,主键起始值为 1,逐步递增。

如果我们的表已经创建,我们需要使用 ALTER TABLE 来给表添加主键:

import mysql.connector

mydb = mysql.connector.connect(
host="localhost",
user="root",
passwd="Jeremy123",
database="runoob_db"
)
mycursor = mydb.cursor() mycursor.execute("ALTER TABLE sites ADD COLUMN id INT AUTO_INCREMENT PRIMARY KEY")

插入数据

插入数据使用 "INSERT INTO" 语句:

import mysql.connector

mydb = mysql.connector.connect(
host="localhost",
user="root",
passwd="",
database="runoob_db"
)
mycursor = mydb.cursor() sql = "INSERT INTO sites (name, url) VALUES (%s, %s)"
val = ("RUNOOB", "https://www.runoob.com")
mycursor.execute(sql, val) mydb.commit() # 数据表内容有更新,必须使用到该语句 print(mycursor.rowcount, "记录插入成功。")

执行结果:

批量插入

批量插入使用 executemany() 方法,该方法的第二个参数是一个元组列表,包含了我们要插入的数据:

import mysql.connector
mydb = mysql.connector.connect(
    host="localhost",
user="root",
passwd="Jeremy123",
database="runoob_db"
)
mycursor = mydb.cursor() sql = "INSERT INTO sites (name, url) VALUES (%s, %s)"
val = [
('Google', 'https://www.google.com'),
('Github', 'https://www.github.com'),
('Taobao', 'https://www.taobao.com'),
('stackoverflow', 'https://www.stackoverflow.com/')
] mycursor.executemany(sql, val) mydb.commit() # 数据表内容有更新,必须使用到该语句 print(mycursor.rowcount, "记录插入成功。")

执行结果

查询数据

查询数据使用 SELECT 语句:

import mysql.connector

mydb = mysql.connector.connect(
host="localhost",
user="root",
passwd="",
database="runoob_db"
)
mycursor = mydb.cursor() mycursor.execute("SELECT * FROM sites") myresult = mycursor.fetchall() # fetchall() 获取所有记录 for x in myresult:
print(x)

where 条件语句

如果我们要读取指定条件的数据,可以使用 where 语句:

import mysql.connector

mydb = mysql.connector.connect(
host="localhost",
user="root",
passwd="Jeremy123",
database="runoob_db"
)
mycursor = mydb.cursor() sql = "SELECT * FROM sites WHERE name ='RUNOOB'" mycursor.execute(sql) myresult = mycursor.fetchall() for x in myresult:
print(x)

条件表达式中也可以使用通配符 %,这里就不再一一赘述了,和Oracle差不多。 

排序

查询结果排序可以使用 ORDER BY 语句,默认的排序方式为升序,关键字为 ASC,如果要设置降序排序,可以设置关键字 DESC

Limit

如果我们要设置查询的数据量,可以通过 "LIMIT" 语句来指定:SELECT * FROM sites LIMIT 3

也可以指定起始位置,使用的关键字是 OFFSET:SELECT * FROM sites LIMIT 3 OFFSET 1

删除记录

删除记录使用 "DELETE FROM" 语句:DELETE FROM sites WHERE name = 'stackoverflow'

注意:要慎重使用删除语句,删除语句要确保指定了 WHERE 条件语句,否则会导致整表数据被删除。

为了防止数据库查询发生 SQL 注入的攻击,我们可以使用 %s 占位符来转义删除语句的条件:

更新表数据

数据表更新使用 "UPDATE" 语句:UPDATE sites SET name = 'ZH' WHERE name = 'Zhihu'

注意:UPDATE 语句要确保指定了 WHERE 条件语句,否则会导致整表数据被更新。

为了防止数据库查询发生 SQL 注入的攻击,我们可以使用 %s 占位符来转义更新语句的条件:

删除表

删除表使用 "DROP TABLE" 语句, IF EXISTS 关键字是用于判断表是否存在,只有在存在的情况才删除:

DROP TABLE IF EXISTS sites

参考资料:

Python - MySQL - mysql-connector -第二十四天的更多相关文章

  1. Python之路【第二十四篇】:Python学习路径及练手项目合集

      Python学习路径及练手项目合集 Wayne Shi· 2 个月前 参照:https://zhuanlan.zhihu.com/p/23561159 更多文章欢迎关注专栏:学习编程. 本系列Py ...

  2. Python之路【第二十四篇】Python算法排序一

    什么是算法 1.什么是算法 算法(algorithm):就是定义良好的计算过程,他取一个或一组的值为输入,并产生出一个或一组值作为输出.简单来说算法就是一系列的计算步骤,用来将输入数据转化成输出结果. ...

  3. Python之路【第二十四篇】:数据库索引

    数据库索引 一.索引简介 索引在mysql中也叫做"键",是存储引擎用于快速找到记录的一种数据结构.索引对于良好的性能非常关键,尤其是当表中的数据量越来越大时,索引对于性能的影响愈 ...

  4. python自动开发之第二十四天(Django)

    一.ModelForm操作及验证 1.class Meta:class Meta: #注意以下字段不能加逗号 model = models.UserInfo #这里的all代指所用的字段,也可以是一个 ...

  5. 【Python之路】第二十四篇--爬虫

    网络爬虫(又被称为网页蜘蛛,网络机器人,在FOAF社区中间,更经常的称为网页追逐者),是一种按照一定的规则,自动地抓取万维网信息的程序或者脚本.另外一些不常使用的名字还有蚂蚁.自动索引.模拟程序或者蠕 ...

  6. 我的MYSQL学习心得(十四) 备份和恢复

    我的MYSQL学习心得(十四) 备份和恢复 我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(四) ...

  7. Python第二十四天 binascii模块

    Python第二十四天 binascii模块 binascii用来进行进制和字符串之间的转换 import binascii s = 'abcde' h = binascii.b2a_hex(s) # ...

  8. 孤荷凌寒自学python第二十四天python类中隐藏的私有方法探秘

    孤荷凌寒自学python第二十四天python类中隐藏的私有方法探秘 (完整学习过程屏幕记录视频地址在文末,手写笔记在文末) 今天发现了python的类中隐藏着一些特殊的私有方法. 这些私有方法不管我 ...

  9. NeHe OpenGL教程 第二十四课:扩展

    转自[翻译]NeHe OpenGL 教程 前言 声明,此 NeHe OpenGL教程系列文章由51博客yarin翻译(2010-08-19),本博客为转载并稍加整理与修改.对NeHe的OpenGL管线 ...

  10. javaSE第二十四天

    第二十四天    363 1:多线程(理解)    363 (1)JDK5以后的Lock锁    363 A:定义    363 B:方法:    364 C:具体应用(以售票程序为例)    364 ...

随机推荐

  1. Add a Class from the Business Class Library 从业务类库添加类 (XPO)

    In this lesson, you will learn how to use business classes from the Business Class Library as is. Fo ...

  2. git安装和项目上传到GitHub

    重装系统后,Git安装也要来重来 下载 国内下载地址:https://npm.taobao.org/mirrors/git-for-windows 安装忽略 生成密钥 输入然后都是下一步,生成密钥,生 ...

  3. python 计算 对象 占用大小

    # 这里主要是计算文件内容(str)的大小即: 统计空间占用情况, 并转换宜读单位 K,M def gen_atta_size(con): # 参数可以是任意数据类型 if con: size_b = ...

  4. 重新认识快速视图窗体(Quick View Form)

    关注本人微信和易信公众号: 微软动态CRM专家罗勇 ,回复158或者20151009可方便获取本文,同时可以在第一时间得到我发布的最新的博文信息,follow me! 在我的 微软Dynamics C ...

  5. [20190524]使用use_concat or_expand提示优化.txt

    [20190524]使用use_concat or_expand提示优化.txt --//上午看了链接https://connor-mcdonald.com/2019/05/22/being-gene ...

  6. TypeScript 学习笔记(二)

    块级作用域变量: 1.不能在被声明前读或写 console.log(num); let num: number = 0; // 报错 2.仍然可以在一个拥有块级作用域的变量声明前通过函数捕获它,但不能 ...

  7. python 实现 AES CBC模式加解密

    AES加密方式有五种:ECB, CBC, CTR, CFB, OFB 从安全性角度推荐CBC加密方法,本文介绍了CBC,ECB两种加密方法的python实现 python 在 Windows下使用AE ...

  8. C++中的C

    前言 因为C++是以C为基础的,所以要用C++编程就必须熟悉C的语法. C语言的学习可以学习K & R C的<C程序设计语言> 创建函数 Q: 函数原型? A: 标准C/C++有一 ...

  9. React、Vue、Angular对比 ---- 新建及打包

    react:npm install -g create-react-appcreate-react-app react-projectnpm installnpm run start vue:npm ...

  10. sqlite 的去重

    1) 找到重复的记录,归类到一个新表里面 max(id) 是想要删除的record 2) 删除 delete from gallery where id in ( select theid from ...