Python学习从0开始——项目一day02数据库连接

Python学习从0开始——项目一day02数据库连接

  • 一、在线云数据库
  • 二、测试数据库连接
  • 三、数据库驱动介绍
  • 四、SQL执行
    • 4.1插入测试数据
    • 4.2安装数据库连接模块
    • 4.3测试SQL语句执行
    • 4.4执行SQL的固定步骤及示例

一、在线云数据库

找了一个在线数据库,需要邮箱注册,这个永久免费。如果本地装了数据库,也可以使用本地的。
这个在线的数据库功能比较简单,基本上都是通过SQL语句操作,也可以去注册阿里云等云服务器,阿里云有三个月MySQL服务器的免费试用期。
我使用的云服务器,如果使用这个云服务器一定要将那个返回的页面拍下来,我直接识图复制文本的时候,密码中有些字母的大小写是混淆了的,这个密码只会显示一次,很重要。
进入数据库后,直接建表:

CREATE TABLE picture(  
    pid INT AUTO_INCREMENT PRIMARY KEY,  
    width INT ,  
    height INT,  
    oriwidth INT,
    oriheight INT,
    thumbnailUrl varchar(128),
    fromUrl varchar(128),
    contSign  varchar(128)
);
alter table picture COMMENT  '爬虫图片';

二、测试数据库连接

看原始代码,参照建立我们自己数据库的配置
在这里插入图片描述
新建一个PyMySQL.py文件

#!/usr/bin/python3
import pymysql  
  
def test_mysql_connection(host, user, password, db_name):  
    try:  
        # 尝试连接到MySQL数据库  
        conn = pymysql.connect(host=host, user=user, password=password, db=db_name)  
        print("成功连接到MySQL数据库")  
          
        # 使用 cursor() 方法创建一个游标对象 cursor   
        with conn.cursor() as cursor:  
            cursor.execute("SHOW TABLES;")  
            tables = cursor.fetchall()  
            print("数据库中的表:", tables)  
          
        # 关闭连接  
        conn.close()  
          
    except pymysql.MySQLError as e:  
        print(f"无法连接到MySQL数据库: {e}")  

# 主方法
def main():
    # 使用你的MySQL数据库的主机名、用户名、密码和数据库名替换这里的值  
    test_mysql_connection("mysql.sqlpub.com", "12345", "12345", "12345")    

if __name__ == '__main__':
    main()

#终端输入
cd Python/Day02/learm
python3 PyMySQL.py 
#终端输出
成功连接到MySQL数据库
数据库中的表: (('picture',),)

数据库成功连接。
以上配置的用户名密码等按照该网站的要求,不能泄漏到公共环境,测试时替换为自己的连接。

三、数据库驱动介绍

  • 1.mysql-connector 是 MySQL 官方提供的驱动器, 它在Python中重新实现MySQL协议,它比较慢,但不需要C库,可移植性好。
  • 2.pymysql是由纯python实现的mysql模块。它相对于mysql.connector, MYSQLdb来说比较年轻。它的效率和可移植性和my-connector理论上是差不多的。
  • 3.MySQLdb是一个围绕_mysql简化的Python包装器,不支持Python 3,_mysql依赖C库,MYSQLdb也依赖C库,可移植性不太好。
  • 4.MysqlClient 是 Python 操作 MySql 的一个驱动程序,是 MySQL-python 的另外一个分支,目前MySQL-python 只支持到Python2,而 MysqlClient 支持 Python3 并且修复了一些bug。

四、SQL执行

4.1插入测试数据

在查询前,先来插入一条数据,数据取自day01爬虫生成的txt文件。

insert into picture(pid,width,height,oriwidth,oriheight,thumbnailUrl,fromUrl,contSign)values(
144520, 1200, 562, 1200, 562, "https://t7.baidu.com/it/u=1819248061,230866778&fm=193&f=GIF", "https://www.vcg.com/creative/1274231988","1819248061,230866778"
)

列名混杂了大写字母,没注意,先改一下

alter table picture 
change 
 thumbnailUrl thumbnail_url varchar(128),
 change fromUrl from_url varchar(128),
 change contSign cont_sign varchar(128);

4.2安装数据库连接模块

#input
pip3 install mysql-connector-python
#output
Looking in indexes: http://mirrors.aliyun.com/pypi/simple/
Collecting mysql-connector-python
  Downloading http://mirrors.aliyun.com/pypi/packages/0c/54/64c541bd569a3f250e54372be5a9e7ef28b519ff98b58ab4ef1a6f242c3b/mysql_connector_python-8.3.0-cp39-cp39-manylinux_2_17_x86_64.whl (21.5 MB)
     ━━━━━━━━━━ 21.5/21.5  634.6 kB/s eta 0:00:00
                MB                               
Installing collected packages: mysql-connector-python
Successfully installed mysql-connector-python-8.3.0
WARNING: Running pip as the 'root' user can result in broken permissions and conflicting behaviour with the system package manager. It is recommended to use a virtual environment instead: https://pip.pypa.io/warnings/venv

如果用到MySQLdb,可以使用如下语句:

import pymysql as MySQLdb

安装mysqlclient报错:

pip install mysqlclient
Looking in indexes: http://mirrors.aliyun.com/pypi/simple/
Collecting mysqlclient
  Using cached http://mirrors.aliyun.com/pypi/packages/79/33/996dc0ba3f03e2399adc91a7de1f61cb14b57ebdb4cc6eca8a78723043cb/mysqlclient-2.2.4.tar.gz (90 kB)
  Installing build dependencies ... done
  Getting requirements to build wheel ... error
  error: subprocess-exited-with-error
  
  × Getting requirements to build wheel did not run successfully.
  │ exit code: 1
  ╰─> [24 lines of output]

解决方法:手动下载再安装,在这不测试。

4.3测试SQL语句执行

复制原始代码到新建的learn文件夹下,修改每个文件里策参数为测试成功的参数。

#MySqlConnector.py文件
#!/usr/bin/python3
import mysql.connector
# 打开数据库连接
db = mysql.connector.connect(
  host="mysql.sqlpub.com",
  user="12345",
  passwd="12345",
  database="12345"
)

# 使用 cursor() 方法创建一个游标对象 cursor
cursor = db.cursor()
# 使用 execute()  方法执行 SQL 查询
cursor.execute("SELECT * FROM picture")
# 使用 fetchall() 方法获取s所有数据
data = cursor.fetchall()
print(data)
# 关闭数据库连接
db.close()
#终端
#input
python3 MySqlConnector.py 
#output
[(144520, 1200, 562, 1200, 562, 'https://t7.baidu.com/it/u=1819248061,230866778&fm=193&f=GIF', 'https://www.vcg.com/creative/1274231988', '1819248061,230866778')]

4.4执行SQL的固定步骤及示例

#step1.创建数据库连接
#step2.创建游标对象
#step3.写sql
#step4.执行
#step5.若有返回,则取回结果
#step6.关闭连接

示例:

#step1.创建数据库连接
import mysql.connector

db = mysql.connector.connect(
  host="mysql.sqlpub.com",
  user="12345",
  passwd="12345",
  database="12345"
)
#step2.创建游标对象
cursor = db.cursor()
#step3.写sql
#step4.执行
#step5.若有返回,则取回结果
#step6.关闭连接
db.close()

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/573586.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

使用Docker搭建Redis主从集群

文章目录 ☃️前言☃️搭建❄️❄️架构❄️❄️实例说明❄️❄️搭建第一个服务器上的两个实例❄️❄️搭建第二个服务器上的一个实例 ☃️开启主从❄️❄️改配置❄️❄️重启从节点 ☃️验证 欢迎来到 请回答1024 的博客 🍓🍓🍓欢迎来到 …

《MATLAB科研绘图与学术图表绘制从入门到精通》示例:绘制婴儿性别比例饼图

在MATLAB 中可以使用 pie 函数来创建饼图。饼图是一种展示不同部分占总体的相对比例的图表。 本示例从“婴儿出生数据.csv”文件读取婴儿出生数据,然后计算男性和女性婴儿的数量,使用MATLAB绘制饼图。 配套图书链接:https://item.jd.com…

【ruoyi-vue】axios的封装理解和基本使用

axios的配置 ruoyi的前端对axios进行了封装,让我们发get请求或者是post请求更加方便了。 ruoyi对axios的封装在下面文件中:打开文件,可以看到它有三个显眼的方法,分别是request拦截器、response拦截器和通用下载方法。ruoYi接口地…

MySQL主从的应用

说明:本文介绍MySQL主从在实际中的应用。主从搭建和问题参考下面两篇文章: MySQL主从结构搭建 搭建MySQL主从结构时的问题 数据迁移 当我们搭建完MySQL主从,第一步当然是把历史数据导入到主从结构中。有以下两种方式: 开启主从…

Linux 网络操作命令Telnet

Telnet 尽管 Telnet 已经逐渐被更安全的 SSH 协议所取代,但在某些特定场景下,如对旧系统的维护或教育目的,Telnet 仍然有其使用价值。本文将介绍如何在 Linux 系统中安装 Telnet 客户端,以及如何使用它进行远程登录。 用户使用 t…

什么是DTU和串口服务器的区别

在工业物联网的快速发展中,数据传输单元(DTU)和串口服务器作为两种关键设备,各自扮演着重要的角色。对于传统行业来说,了解它们的基本概念和区别,有助于更好地选择和应用这些技术,提升生产效率和…

Rust基本数据类型-切片

一、切片是什么,怎么用 1、切片是什么 切片并不是 Rust 独有的概念,在 Go 语言中就非常流行,它允许你引用集合中部分连续的元素序列,而不是引用整个集合。 对于字符串而言,切片就是对 String 类型中某一部分的引用&…

基于单片机的空气质量检测系统设计

摘要:随着社会经济的不断发展,人们的生活水平日益提高,健康与养生成为了全民关注的热点话题,空气质量地不断下降也引起了社会的广泛关注,如何了解家居内空气质量的情况也成了亟需解决的问题。在此背景下,本文针对室内空气的质量问题设计了基于单片机的空气质量检测系统,…

Mysql个人总结

前言 又来水字数啦,这次主要讲一下MySQL的常用概念,难点的就必须上项目讲解了,而且比较基础面试基本都会问一些,用的话,不少优化都从这里入手 操作数据库 1、创建数据库 CREATE DATABASE [IF NOT EXISTS] 数据库名;…

【AI相关】《这就是ChatGPT》读书笔记

《这就是ChatGPT》 斯蒂芬沃尔弗拉姆 这本书用了两天就一口气读完了,通篇读完后,这本书主要是介绍了ChatGPT怎么能做到生成内容的一些背后的原理逻辑,总结一下这本书是ChatGPT通过大量的数据(这些数据来自网络、书籍等等类似于数据…

Linux多进程(二)进程通信方式三 共享内存

共享内存提供了一个在多个进程间共享数据的方式,它们可以直接访问同一块内存区域,因此比使用管道或消息队列等通信机制更高效。在多进程程序中,共享内存通常与信号量一起使用,以确保对共享内存的访问是线程安全的。 一、打开/创建…

2024年达索系统智能制造核心合作伙伴会议圆满成功

2024年4月23日,达索系统在上海雅乐万豪侯爵酒店举办“2024年达索系统智能制造核心合作伙伴会议”,作为达索系统合作伙伴的百世慧也应邀出席了本次会议,并荣获“2023年度最佳销售业绩奖”,总经理冉恒奎先生还受邀在会上做出了精彩分…

电磁兼容(EMC):静电放电(ESD)抗扰度试验深度解读(八)

目录 1. 第一步 确定电磁环境 2. 第二步 确认设备工作状态 3. 第三步 制定试验计划 4. 间接施加的放电 4.1 水平耦合板 4.2 垂直耦合板 静电抗扰度的试验测试细节对测试结果影响比较大,本文详细介绍静电抗扰度试验的测试程序和注意事项。 1. 第一步 确定电磁…

Vision Pro“裸眼上车”,商汤绝影全新舱内3D交互亮相

2023年,Apple Vision Pro的横空出世让人们领略到了3D交互的魅力,商汤绝影通过深厚的技术研发实力和高效的创新迭代效率,带来两大全新座舱3D交互:3D Gaze高精视线交互和3D动态手势交互。 作为全球首创的能够通过视线定位与屏幕图标…

CST Studio初级教程 一

本教程将详细介绍CST Studio Project创建。 新建Project 1. 点击New and Recent,然后点击New Template。 然后依据我们的仿真属类,在下图中做选择需要的模板。 如果做高频连接器信号完整性(SI)仿真,我们就选Microwaves…

人工智能技术应用实训室解决方案

一、背景与意义 人工智能,作为新兴的技术科学领域,致力于模拟、延伸和扩展人类智能,其涵盖范围广泛,包括机器人技术、语言识别、图像识别、自然语言处理及专家系统等多元化领域。实际应用层面,人工智能已渗透到机器视…

【初阶数据结构】——循环队列

文章目录 1. 什么是循环队列?2. 结构的选择:数组 or 链表?链表结构分析数组结构分析判空判满入数据出数据取队头队尾元素 3. 代码实现(数组结构)C语言版本C版本 这篇文章我们来学习一下如何实现循环队列 那力扣上呢有一…

应用层协议 -- HTTPS 协议

目录 一、了解 HTTPS 协议 1、升级版的 HTTP 协议 2、理解“加密” 二、对称加密 1、理解对称加密 2、对称加密存在的问题 三、非对称加密 1、理解非对称加密 2、中间人攻击 3、CA 证书和数字签名 四、总结 一、了解 HTTPS 协议 1、升级版的 HTTP 协议 HTTPS 也是…

prompt提示词:AI英语词典,让AI教你学英语,通过AI实现一个网易有道英语词典

目录 英语词典提问技巧效果图:提示词: 英语词典提问技巧 随着AI工具的出现,学英语也可以变得很简单,大家可以直接通过AI 来帮助自己,提高记忆单词的效率,都可以不需要网易有道词典了,今天我教大…

Grid 布局

文章目录 容器属性display 属性grid-template-columns 和 grid-template-rows 属性row-gap、column-gap、gap 属性grid-template-areas 属性grid-auto-flow 属性justify-items、align-items、place-items 属性justify-content、align-content、place-content 属性grid-auto-col…
最新文章