广告
返回顶部
首页 > 资讯 > 数据库 >MySQL如何使用Python进行连接
  • 683
分享到

MySQL如何使用Python进行连接

2023-07-06 11:07:40 683人浏览 薄情痞子
摘要

今天小编给大家分享一下MySQL如何使用python进行连接的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、表格与键概念主

今天小编给大家分享一下MySQL如何使用python进行连接的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

一、表格与键概念

MySQL如何使用Python进行连接

MySQL如何使用Python进行连接

MySQL如何使用Python进行连接

主键:可唯一表示该资料(可以设置多个列表为主键)

MySQL如何使用Python进行连接

设置外键进行表与表的相连,且外键必须是其他表的主键(外键也可以设置自己表格的主键)

二、创建资料库

CREATE DATABASE `sql_tutorial`;    --创建资料库SHOW databases;    --展示资料库drop database `sql_tutorial`;    --删除资料库

–为注释
;为结束命令的格式

MySQL如何使用Python进行连接

三、创建表格

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 ; -- 删除资料属性

MySQL如何使用Python进行连接

四、储存资料

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

MySQL如何使用Python进行连接

五、限制约束

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('小黑'); -- 按照设置写入表格数据

MySQL如何使用Python进行连接

六、修改、删除资料

条件:>,<,>=,<=,=,<>

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` = 206where `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`uNIOnselect `client_name` from `client`;-- 多个数据合并为多列(类型必须相同)select `emp_id`, `name` from `employee`unionselect `client_id`, `client_name` from `client`;-- 多个数据合并为多列(类型必须相同)顺便改个名select `emp_id` as `total_id`, `name` as `total_name` from `employee`unionselect `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()

以上就是“MySQL如何使用Python进行连接”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注编程网数据库频道。

您可能感兴趣的文档:

--结束END--

本文标题: MySQL如何使用Python进行连接

本文链接: https://www.lsjlt.com/news/357897.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MySQL如何使用Python进行连接
    今天小编给大家分享一下MySQL如何使用Python进行连接的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、表格与键概念主...
    99+
    2023-07-06
  • MySQL怎么使用Python进行连接
    一、表格与键概念主键:可唯一表示该资料(可以设置多个列表为主键)设置外键进行表与表的相连,且外键必须是其他表的主键(外键也可以设置自己表格的主键)二、创建资料库CREATE DATABASE `sql_tutorial`; --创建资...
    99+
    2023-05-14
    Python MySQL
  • MySQL操作并使用Python进行连接
    目录一、表格与键概念二、创建资料库三、创建表格四、储存资料五、限制约束六、修改、删除资料七、取得资料八、创建公司资料库九、取得公司资料十、聚合函数十一、万用子元十二、联集十三、连接十...
    99+
    2022-11-13
  • 如何进行OpenResty连接Mysql
    本篇文章为大家展示了如何进行OpenResty连接Mysql,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。centos 安装myslCentos系统下安装mysql,先下载mysql-communi...
    99+
    2023-06-19
  • Python 连接mysql数据库进行操
    1.MySQLdb 模块是用于Python链接Mysql数据库的接口,默认是没有安装的[root@python ~]# yum  install  MySQL-python   -y2.创建python脚本[root@python ~]# ...
    99+
    2023-01-31
    数据库 Python mysql
  • 怎么使用PHP MySQL进行数据连接
    小编给大家分享一下怎么使用PHP MySQL进行数据连接,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!PHP MySQL 连接一起学习PHP MySQL 连接方式...
    99+
    2023-06-15
  • 使用Java如何连接MySQL数据库并进行操作
    这篇文章给大家介绍使用Java如何连接MySQL数据库并进行操作,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1. 连接数据库  (1) 下载Mysql连接驱动网址: http://dev.mysql.com/down...
    99+
    2023-05-31
    java mysql 数据库
  • 怎么使用Python连接MySQL
    这篇文章主要介绍了怎么使用Python连接MySQL的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇怎么使用Python连接MySQL文章都会有所收获,下面我们一起来看看吧。1、MySQL-pythonMySQL...
    99+
    2023-06-27
  • 使用Python连接MySQL数据库进行编程的步骤详解
    目录1.连接到mysql数据库2.创建表3.插入/更新数据4.查询数据5. 异常处理6.小结PostgreSQL等。本教程将重点介绍使用python连接MySQL数据库进行编程。 MySQL是一种常见的关系型数据库,我们...
    99+
    2023-06-10
    Python连接MySQL进行编程 Python连接MySQL数据库 Python MySQL
  • 如何使用ADO连接mysql
    这篇文章给大家介绍如何使用ADO连接mysql,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。一、创建数据库、创建表、插入数据>show databases;>create ...
    99+
    2022-10-18
  • 如何使用jdk连接mysql
    如何使用jdk连接mysql,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。  import java.sql.*; ...
    99+
    2022-10-18
  • 如何使用asp连接Mysql
    这篇文章主要介绍了如何使用asp连接Mysql,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。ASP连接Mysql数据库的问题。下了一个MyS...
    99+
    2022-10-18
  • 如何使用eclipse连接mysql
    本篇文章为大家展示了如何使用eclipse连接mysql,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。打开eclipse,依次点击Window-preferences-java-Build Path...
    99+
    2023-06-15
  • 如何使用pyMySql连接mysql
    本篇内容介绍了“如何使用pyMySql连接mysql”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!安装pip3 install pymysq...
    99+
    2023-06-04
  • 如何使用命令行连接MySQL数据库
    Windows操作系统下,开始——运行,打开"运行"对话框,输入cmd,点击“确定”即可进入DOS窗口。DOS窗口输入登录MySQL数据库命令mysql -h 127.0.0.1 -u ...
    99+
    2022-10-18
  • mysql如何使用命令行连接服务器
    这篇文章给大家分享的是有关mysql如何使用命令行连接服务器的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1、在登录成功后出现mysql命令提示窗口,在上面执行SQL语句。[root@host]# my...
    99+
    2023-06-20
  • 阿里云ECS如何使用FTP进行连接
    在阿里云上使用ECS服务器时,我们有时需要使用FTP进行文件的上传、下载或同步。本文将详细说明如何在阿里云上使用FTP进行连接。 一、准备工作在使用FTP之前,我们需要准备以下几点:阿里云账号:在阿里云上进行任何操作都需要使用阿里云账号...
    99+
    2023-12-11
    阿里 如何使用 ECS
  • SpringBoot连接MYSQL数据库并使用JPA进行操作
    今天给大家介绍一下如何SpringBoot中连接Mysql数据库,并使用JPA进行数据库的相关操作。步骤一:在pom.xml文件中添加MYSQl和JPA的相关Jar包依赖,具体添加位置在dependencies中,具体添加的内容如下所示。&...
    99+
    2023-05-31
    jpa mysql spring
  • mysql连接如何在Java项目中进行获取
    mysql连接如何在Java项目中进行获取?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。一、传统的连接方式:首先在 src 目录下创建名为 lib 的文件夹,导入数据库驱动...
    99+
    2023-05-31
    java mysql ava
  • python通过远程连接mysql数据库进行操作
    文章目录 前言一、开启远程访问权限1、开启远程访问端口2、命令行登录mysql 二、Navicat 建库1、新建连接2、建库建表 三、python对数据库进行远程操作三、总结四、参考资...
    99+
    2023-09-20
    数据库 python mysql
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作