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

news2024/9/17 8:35:48

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.coloradmin.cn/o/1617684.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

jetcache fastjson 泛型复杂对象JSON序列 ,反序列化

Jetcache fastjson 泛型复杂对象JSON序列 ,反序列化 默认的FastJson2 序列化存在问题增强FastJson 支持Encode 编码器Decode 解码器 默认的FastJson2 序列化存在问题 默认的序列化不能转换List 中的泛型数据类型, 从缓存拿取的list集合对象数据全部都转换成了JSONObject 增强F…

基于 Win32 编程,使用 C语言开发一个记事本。

现在 Win32 非常少见,因为太原始了,同时也因为高级语言做应用开发速度更快。但是用 C 语言开发一个 win32 记事本对于理解应用程序运行的内部原理还是很有帮助的,“最基础的就是最有用的”,Windows 编程圣经 《Windows 程序设计》…

开发区块链DApp应用,引领数字经济新潮流

随着区块链技术的飞速发展,分布式应用(DApp)正成为数字经济中的一股强劲力量。DApp以其去中心化、透明公正的特点,为用户带来了全新的数字体验,开创了数字经济的新潮流。作为一家专业的区块链DApp应用开发公司&#xf…

【Elasticsearch】Elasticsearch 从入门到精通(二):基础使用

《Elasticsearch 从入门到精通》共包含以下 2 2 2 篇文章: Elasticsearch 从入门到精通(一):基本介绍Elasticsearch 从入门到精通(二):基础使用 😊 如果您觉得这篇文章有用 ✔️ 的…

使用写入这类接口后,文件指针fp是否会偏移?

以fprintf为例: 在使用 fprintf 函数写入数据时,文件指针 fp 会自动进行偏移,以确保数据被写入到文件的正确位置。 每次调用 fprintf 函数都会将数据写入文件,并且文件指针会在写入完成后自动移动到写入的末尾,以便下…

MYSQL中ID是无序的,但是需要通过指定的条件查询到最大的值的ID应该如何查询。

1、开发中遇到这个问题,下面直接通过mysql的方式讲解 select id, start_time, eva_id from a where eva_id 1 order by start_time desc 执行查询出来的数据是这样的 2、解决方案 那么问题来了, 我只想获取到start_time 最大的那个ID,那有些…

CRMEB pro版/多门店商城系统客服配置教程

客服功能配置介绍 功能提示: Pro v2.0系统采用swoole框架,客服不需要单独配置,按照正常安装流程配置好程序即可使用! 如出现客服无法使用,请检查: 1.消息队列是否正常 2.重启swoole 一、功能介绍 CRMEB商城…

【UML建模】用例图

1 参与者 参与者的概念: 指系统以外的、需要使用系统或与系统交互的外部实体 可以分为:人、外部设备、外部系统 参与者的图形符号: 例 3.1 在一个银行业务系统中,可能会有以下参与者 客户 :在银行业务系统中办理…

图像处理技术与应用(一)

图像处理技术与应用入门 使用skimage进行图像读取和显示 skimage库(Scikit-image)提供了一个强大的工具集,用于执行各种图像处理任务。以下是如何使用skimage读取和显示图像的基本示例: from skimage import ioimg io.imread(…

华为sr-mpls policy配置案例

SR-MPLS POLICY在ensp上面做不了,这是官方上的配置

金铲铲无限金币-罗小黑最新

罗小黑最新,下载自测。 记得查看注意事项。 获取链接:https://pan.baidu.com/s/1mRuQPAqWXv6oeihQ5fsn0w?pwdd0s3 提取码:d0s3 --来自百度网盘超级会员V1的分享

Apache Answer 开源问答社区安装体验

Answer 是由 SegmentFault 思否团队打造的一款问答平台软件,后端使用 Go 语言编写,于2022年10月24日(程序员节)正式开源。你可以免费使用 Answer 高效地搭建一个问答社区,并用于产品技术问答、客户支持、用户交流等场景。 2023年10月9日,Answer 顺利通过投票,以全票通过…

spring的跨域问题

跨域问题 什么是跨域解决跨域 什么是跨域 跨域问题本质是浏览器的一种保护机制,它的初衷是为了保证用户的安全,防止恶意网站窃取数据。如果出现了以下情况中的任意一种,那么它就是跨域请求: 1、协议不同,如 http 和 h…

Ubuntu 自己写的程序如何创建快捷方式

在Ubuntu中创建程序的快捷方式通常是通过将一个指向程序可执行文件的.desktop文件放入/usr/share/applications/或用户的~/.local/share/applications/目录来实现的。以下是创建快捷方式的基本步骤和示例: 在application里创建快捷方式 创建一个新的.desktop文件。…

把 WordPress 变成 BaaS 服务:API 调用指南

有了前面两篇内容的铺垫,我们来聊聊 WordPress 作为 CMS / BaaS 服务使用时绕不开的问题,API 调用。 这篇内容同样的,会尽量少贴代码,简单的讲清楚一件事,降低阅读负担。 写在前面 首先,我们需要进行清晰…

STM32H750时钟频率和功耗以及RTC功能测试

STM32H750时钟频率和功耗和RTC功能测试 ✨在使用STM32CubeMX修改STM32H750时钟树参数时,如果使用软件自动求解,这是一个非常耗时的操作,有时候还不一定成功,还是推荐使用手动方式进行配置,这一点和STM32其他系列不同&a…

叉车4G无线视频监控管理解决方案:提升效率,保障安全

在现代物流行业中,叉车被广泛应用于仓储和物流领域,成为提升效率和降低成本的重要工具。然而,叉车作为重要的运输设备,其安全性和管理效率也备受关注。针对这一问题,叉车4G无线视频监控管理解决方案应运而生。 叉车是仓…

RB-Tree

RB-tree 平衡二叉搜索树 元素排列规则有利于search 和 insert red-black tree(红黑树)是平衡二元搜索树(balanced binary tree)。其特征:排列规则有利于Search和Insert,并保持适度平衡—无任何节点过深。rb_tree提供两种插入操作:inset_unique和insert…

Rest微服务案例

Rest 父工程构建microservicecloud-api公共子模块Modulemicroservicecloud-provider-dept-8001部门微服务提供者Modulemicroservicecloud-consumer-dept-80部门微服务消费者Module 以Dept部门模块做一个微服务通用案例 Consumer消费者(Client)通过REST调…

HF区块链链码基础

链码生命周期 一 . 链码准备 准备文件 . 在测试目录下创建chaincode,拷贝测试链码进 chaincode目录,拷贝 set-env.sh 脚本进 scripts 目录 二. 打包链码 打包测试链码 export FABRIC_CFG_PATH${PWD}/config peer lifecycle chaincode package ./chaincode/chaincode_basic.…