使用Python连接MySQL数据库
来源:亿速云
2024-03-28 08:45:13
0浏览
收藏
小伙伴们对文章编程感兴趣吗?是否正在学习相关知识点?如果是,那么本文《使用Python连接MySQL数据库》,就很适合你,本篇文章讲解的知识点主要包括。在之后的文章中也会多多分享相关知识点,希望对大家的知识积累有所帮助!
一、表格与键概念
主键:可唯一表示该资料(可以设置多个列表为主键)
设置外键进行表与表的相连,且外键必须是其他表的主键(外键也可以设置自己表格的主键)
二、创建资料库
CREATE DATABASE `sql_tutorial`; --创建资料库 SHOW databases; --展示资料库 drop database `sql_tutorial`; --删除资料库
–为注释
;为结束命令的格式
三、创建表格
MySQL的资料形态:
INT --整形
DECIMAL(m,n) --有小数点的数 (3,2)则是2.33,总共有m位数,小数点站n位
VARCHAR(n) --字串
BLOB --图片 影片 档案…(二进制的资料)
DATE --日期(yyyy-mm-dd)
TIMESTAMP --记录时间(yyyy-mm-dd hh:mm:ss)
CREATE DATABASE `sql_tutorial`; -- 创建资料库 SHOW databases; -- 展示资料库 use `sql_tutorial`; -- 选择使用的资料库 create table student( `student_id` int primary key, -- 第一列 `name` varchar(20), -- 第二列 `major` varchar(20) -- 第三列,20指的是最大字符长度 ); -- 创建表格并设计属性 describe `student`; -- 展示表格 drop table `student`; -- 删除表格 alter table `student` add gpa decimal(3,2); -- 增加资料属性 alter table `student` drop column gpa ; -- 删除资料属性
四、储存资料
create table student( `student_id` int primary key, -- 第一列 `name` varchar(20), -- 第二列 `major` varchar(20) -- 第三列,20指的是最大字符长度 ); -- 创建表格并设计属性 select * from `student`; -- 搜索表格的全部资料 insert into `student` values(1,'小白','历史'); -- 写入表格数据 insert into `student` values(2,'小黑','生物'); -- 写入表格数据 insert into `student` values(3,'小绿',null); -- 写入表格数据,null为空 insert into `student`(`name`,`major`,`student_id`) values('小蓝','英语','4'); -- 按照设置写入表格数据 insert into `student`(`major`,`student_id`) values('英语','5'); -- 按照设置写入表格数据,没有的数据则为空白null
五、限制约束
create table student( `student_id` int primary key, -- 第一列 `name` varchar(20) not null, -- 第二列,not null指这个属性不可以为空 `major` varchar(20) unique -- 第三列,20指的是最大字符长度,unique指每个值不可以重复 ); -- 创建表格并设计属性 create table student( `student_id` int primary key auto_increment, -- 第一列,auto_increment自动会加一 `name` varchar(20), -- 第二列,not null指这个属性不可以为空 `major` varchar(20) default '历史' -- 第三列,20指的是最大字符长度,default指预设值,如果没有写该属性,则为预设值 ); -- 创建表格并设计属性 drop table `student`; select * from `student`; -- 搜索表格的全部资料 insert into `student`(`name`,`major`) values('小蓝','英语'); -- 按照设置写入表格数据 insert into `student`(`name`) values('小黑'); -- 按照设置写入表格数据
六、修改、删除资料
条件:>,<,>=,<=,=,<>
set sql_safe_updates = 0; -- 把预设更新模式关闭,这样更新操作才可以成功 create table student( `student_id` int primary key auto_increment, -- 第一列 `name` varchar(20), -- 第二列 `major` varchar(20), -- 第三列,20指的是最大字符长度 `score` int ); -- 创建表格并设计属性 drop table `student`; select * from `student`; -- 搜索表格的全部资料 insert into `student`(`name`,`major`) values('小蓝','英语'); -- 按照设置写入表格数据 insert into `student`(`name`,`major`) values('小白','化学'); -- 按照设置写入表格数据 insert into `student`(`name`,`major`) values('小黑','生物'); -- 按照设置写入表格数据 update `student` -- 更新哪个表格 set `major` = '英语文学' -- 将什么更新成什么 where `major` = '英语'; -- 将其中谁的什么进行更新 -- 还可以进行多个更新 update `student` -- 更新哪个表格 set `major` = '生化' -- 将什么更新成什么 where `major` = '生物' or `major` = '化学' ; -- 将其中谁的什么进行更新 update `student` -- 更新哪个表格 set `name` = '小辉',`major` = '生化' -- 将什么更新成什么 where `student_id`=1 ; -- 将其中谁的什么进行更新 -- 不加条件则都改 update `student` -- 更新哪个表格 set `major` = '物理'; -- 将其中谁的什么进行更新,都改成了生化 delete from `student` where `student_id` = 3; -- 删除表格中的数据 -- 条件也可以设置多个 delete from `student` where `name` = '小白' and `major`='物理'; -- 删除表格中的数据 delete from `student`; -- 删除所有的资料
七、取得资料
-- 取得资料 select * from `student`; -- 取得表格的全部资料 select `name` from `student`; -- 只取得表格的对应数据 select `name`, `major` from `student`; -- 取得表格的对应多个数据 select * from `student` ORDER BY `score`; -- 取得表格的全部资料,并排序(默认正序) select * from `student` ORDER BY `score` DESC; -- 取得表格的全部资料,并排序(由高到低,asc是由低到高) select * from `student` ORDER BY `score` ,`student_id`; -- 取得表格的全部资料,并排序(先有score做排序,score中相同的再由student_id做排序) select * from `student` LIMIT 3 ; -- 限制资料范围 select * from `student` ORDER BY `score` LIMIT 3 ; -- 排序并限制资料范围 select * from `student` where `major`= '英语'; -- 查找对应资料 select * from `student` where `major`= '英语' and `student_id` = 1; -- 查找对应资料(多条件) select * from `student` where `major` in('历史','英语','生物'); -- 查找对应资料(多条件)1
八、创建公司资料库
CREATE DATABASE `sql_tutorial`; -- 创建资料库 SHOW databases; -- 展示资料库 use `sql_tutorial`; -- 选择使用的资料库 create table `employee`( `emp_id` int primary key, -- 第一列 `name` varchar(20), -- 第二列,20指的是最大字符长度 `bath_date` date, -- 第三列 `sex` varchar(1), `salary` int, `branch_id` int, `sup_id` int ); -- 创建表格并设计属性 create table `branch`( `branch_id` int primary key , -- 第一列 `branch_name` varchar(20), -- 第二列 `manager_id` int, -- 第三列,20指的是最大字符长度 foreign key (`manager_id`) references `employee`(`emp_id`) on delete set null -- 设置好外键(选择什么是并对应什么表格的什么属性) ); -- 创建表格并设计属性 -- 补充外键(外表格对应) alter table `employee` -- 在什么表格上进行更新 add foreign key(`branch_id`) -- 在他的什么属性上 references `branch`(`branch_id`) -- 从哪的什么属性对应 on delete set null; -- 补充外键(内表格对应) alter table `employee` -- 在什么表格上进行更新 add foreign key(`sup_id`) -- 在他的什么属性上 references `employee`(`emp_id`) -- 从哪的什么属性对应 on delete set null; create table `client`( `client_id` int primary key , -- 第一列 `client_name` varchar(20), -- 第二列 `phone` varchar(20) -- 第三列,20指的是最大字符长度 ); -- 创建表格并设计属性 create table `works_with`( `emp_id` int, -- 第一列 `client_id` int, -- 第二列 `total_sales` int, -- 第三列,20指的是最大字符长度 primary key(`emp_id`,`client_id`), foreign key (`emp_id`) references `employee`(`emp_id`) on delete cascade, -- 设置好外键(选择什么是并对应什么表格的什么属性) foreign key (`client_id`) references `client`(`client_id`) on delete cascade -- 设置好外键(选择什么是并对应什么表格的什么属性) ); -- 创建表格并设计属性 -- 当增加资料冲突的时候可以先将其设置为null然后再更新 insert into `branch` values(1,'研发',null); insert into `employee` values(206,'xiaohuang','1998-10-08','F',50000,1,null); update `branch` set `manager_id` = 206 where `branch_id` = 1;
九、取得公司资料
-- 取得对应表格所有资料 select * from `employee`; -- 取得对应表格所有资料并排序(默认低到高) select * from `employee` order by `salary`; -- 低为加desc -- 增加限制取出条件 select * from `employee` order by `salary` desc limit 3 ; -- 取出前三高 -- 取出对应属性 select `name` from `employee` ; -- 取出对应属性的内容(且不重复) select distinct `name` from `employee` ;
十、聚合函数
-- 取得人数 select count(*) from `employee`; -- 统计几笔资料 select count(`sup_id`) from `employee`; -- 统计对应属性资料个数(null不计入) -- 增加条件取数 select count(*) from `employee` where `bath_date` > '1970-01-01' and `sex` = 'F'; -- 统计几笔资料 -- 计算对应的属性的平均 select avg(`salary`) from `employee`; -- 计算对应的属性的总和 select sum(`salary`) from `employee`; -- 取得最高的 select max(`salary`) from `employee`; -- 取得最低的 select min(`salary`) from `employee`;
十一、万用子元
-- %表示多个子元,_表示一个子元 -- 取得尾数335的数据 select * from `client` where `phone` like '%335'; -- 取得姓艾的 select * from `client` where `client_name` like '艾%'; -- 取得生日是10月的 select * from `employee` where `bath_date` like '_____10%';
十二、联集
-- 员工与客户合并为一列(类型必须相同) select `name` from `employee` union select `client_name` from `client`; -- 多个数据合并为多列(类型必须相同) select `emp_id`, `name` from `employee` union select `client_id`, `client_name` from `client`; -- 多个数据合并为多列(类型必须相同)顺便改个名 select `emp_id` as `total_id`, `name` as `total_name` from `employee` union select `client_id`, `client_name` from `client`;
十三、连接
-- 连接 -- 取得所有部门经理名字,这就需要先确定部门再确定经理(二表相连) select * from `employee` join `branch` on `emp_id` = `manager_id`; -- 还可以写成 select * from `employee` join `branch` on `employee`.`emp_id` = `branch`.`manager_id`; -- 附加条件 select * from `employee` left join `branch` on `employee`.`emp_id` = `branch`.`manager_id`; -- 左边的表格(join的左边)返回全部数据,右边的必须满足才可
十四、子查询
-- 查询套查询 select `name` from `employee` where `emp_id` = ( select `manager_id` from `branch` where `branch_name` = '研发' ); -- 查找研发部门的经理名字 select `emp_id` from `employee` where `emp_id` in ( select `emp_id` from `works_with` where `total_sales` > 50000 ); -- 销售资金超50000的人有哪些
十五、On delete
On delete set null 的作用是若该数据删除了(或者说对应不到了)则会设置为null
On delete decade 若对应数据删除了(或者说对应不到了)则该表格的这条数据跟着删掉
注:当为主键时则不能设置为on delete set nullcreate table `branch`(
`branch_id` int primary key , -- 第一列 `branch_name` varchar(20), -- 第二列 `manager_id` int, -- 第三列,20指的是最大字符长度 foreign key (`manager_id`) references `employee`(`emp_id`) on delete set null -- 设置好外键(选择什么是并对应什么表格的什么属性) ); -- 创建表格并设计属性 create table `works_with`( `emp_id` int, -- 第一列 `client_id` int, -- 第二列 `total_sales` int, -- 第三列,20指的是最大字符长度 primary key(`emp_id`,`client_id`), foreign key (`emp_id`) references `employee`(`emp_id`) on delete cascade, -- 设置好外键(选择什么是并对应什么表格的什么属性) foreign key (`client_id`) references `client`(`client_id`) on delete cascade -- 设置好外键(选择什么是并对应什么表格的什么属性) ); -- 创建表格并设计属性
十六、Python连接MySQL
# 导入功能包(mysql-connector-python) import mysql.connector # 创入连线 connection = mysql.connector.connect(host='localhost', # mysql的位置 port='3306', # 连接通道 user='root', # 使用者名称 password='123456') # 使用者密码 '''connection = mysql.connector.connect(host='localhost', # mysql的位置 port='3306', # 连接通道 user='root', # 使用者名称 password='123456', # 使用者密码 database='sql_tutorial') # 直接打开目标资料库''' # 告知开始使用操作 cursor = connection.cursor() # 在对mysql操作时即用该格式:cursor.execute("你要执行的mysql语句命令") # 创建资料库 # cursor.execute("CREATE DATABASE `qq`;") # 取得所有资料库名称 cursor.execute("show databases;") records = cursor.fetchall() # 取出回传资料库 for r in records: print(r) # 因为回传列表,为便于观察,进行循环打印 # 选择资料库 cursor.execute("use `sql_tutorial`;") # 创建表格 # 告知关闭操作 cursor.close() # 若要懂资料进行修改需要结尾加一个指令,这样才能提交指令生效 connection.commit() # 关闭连线 connection.close()
以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于文章的相关知识,也可关注golang学习网公众号。
版本声明
本文转载于:亿速云 如有侵犯,请联系study_golang@163.com删除

- 上一篇
- 通过MySQL读写分离来优化性能的方法

- 下一篇
- Java错误:处理与避免批处理错误
查看更多
最新文章
-
- 文章 · python教程 | 3小时前 |
- Python编程100题:从入门到算法实战
- 318浏览 收藏
-
- 文章 · python教程 | 3小时前 |
- TimeMachine备份结合Python虚拟环境隔离技巧
- 384浏览 收藏
-
- 文章 · python教程 | 3小时前 |
- 学习Python需要哪些基础编程知识和技能?
- 301浏览 收藏
-
- 文章 · python教程 | 3小时前 |
- PythonWebSocket服务器终极创建指南
- 102浏览 收藏
-
- 文章 · python教程 | 4小时前 |
- Matplotlib图像保存技巧与Python应用
- 202浏览 收藏
-
- 文章 · python教程 | 4小时前 |
- Ubuntu22.04源码编译Python3.12:依赖详解
- 206浏览 收藏
-
- 文章 · python教程 | 5小时前 |
- Pythonasync/await使用技巧与示例
- 225浏览 收藏
-
- 文章 · python教程 | 5小时前 | orm 性能问题 多表关联查询 学习曲线 sqlalchemy
- Python多表关联查询的实用技巧
- 136浏览 收藏
-
- 文章 · python教程 | 5小时前 |
- Python编程100题:从基础到算法实战
- 198浏览 收藏
-
- 文章 · python教程 | 6小时前 |
- Python表单数据处理技巧与代码示例
- 463浏览 收藏
-
- 文章 · python教程 | 6小时前 |
- Python数据归一化处理方法及技巧
- 250浏览 收藏
-
- 文章 · python教程 | 8小时前 | orm 模型定义 管理员类 Django管理员界面 URL映射
- 在Python中如何自定义Django管理员界面?
- 276浏览 收藏
查看更多
课程推荐
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
查看更多
AI推荐
-
- AI Make Song
- AI Make Song是一款革命性的AI音乐生成平台,提供文本和歌词转音乐的双模式输入,支持多语言及商业友好版权体系。无论你是音乐爱好者、内容创作者还是广告从业者,都能在这里实现“用文字创造音乐”的梦想。平台已生成超百万首原创音乐,覆盖全球20个国家,用户满意度高达95%。
- 16次使用
-
- SongGenerator
- 探索SongGenerator.io,零门槛、全免费的AI音乐生成器。无需注册,通过简单文本输入即可生成多风格音乐,适用于内容创作者、音乐爱好者和教育工作者。日均生成量超10万次,全球50国家用户信赖。
- 12次使用
-
- BeArt AI换脸
- 探索BeArt AI换脸工具,免费在线使用,无需下载软件,即可对照片、视频和GIF进行高质量换脸。体验快速、流畅、无水印的换脸效果,适用于娱乐创作、影视制作、广告营销等多种场景。
- 12次使用
-
- 协启动
- SEO摘要协启动(XieQiDong Chatbot)是由深圳协启动传媒有限公司运营的AI智能服务平台,提供多模型支持的对话服务、文档处理和图像生成工具,旨在提升用户内容创作与信息处理效率。平台支持订阅制付费,适合个人及企业用户,满足日常聊天、文案生成、学习辅助等需求。
- 16次使用
-
- Brev AI
- 探索Brev AI,一个无需注册即可免费使用的AI音乐创作平台,提供多功能工具如音乐生成、去人声、歌词创作等,适用于内容创作、商业配乐和个人创作,满足您的音乐需求。
- 17次使用
查看更多
相关文章
-
- Flask框架安装技巧:让你的开发更高效
- 2024-01-03 501浏览
-
- Django框架中的并发处理技巧
- 2024-01-22 501浏览
-
- 提升Python包下载速度的方法——正确配置pip的国内源
- 2024-01-17 501浏览
-
- Python与C++:哪个编程语言更适合初学者?
- 2024-03-25 501浏览
-
- 品牌建设技巧
- 2024-04-06 501浏览