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-pythonDownloading 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:00MB                               
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 mysqlclientUsing cached http://mirrors.aliyun.com/pypi/packages/79/33/996dc0ba3f03e2399adc91a7de1f61cb14b57ebdb4cc6eca8a78723043cb/mysqlclient-2.2.4.tar.gz (90 kB)Installing build dependencies ... doneGetting requirements to build wheel ... errorerror: 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.connectordb = 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.mzph.cn/news/827524.shtml

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

相关文章

甄美天使1+3退休模式开发|最新升级模式

我是新零售商业架构师肖琳,易创客社交新零售创始‌‌‌‌‌人,擅长品牌从0-1、1-10起盘全过程。易创客新零售,提供商业模式解决方案系统,包括分销系统、微商系统、新零售系统;提供社交新零售陪跑代运营,提供…

Uds的0x10服务

0x10为诊断会话控制,该服务下有三种子功能,分别为默认会话,扩展会话,编程会话。 如果长时间在非默认会话下,没有用诊断仪跟ECU通讯,那么ECU会调回或者是返回到默认会话下。一般UDS协议上推荐是5000毫秒&…

Ubuntu搭建RP2040开发环境-1

Ubuntu搭建RP2040开发环境-1 2024-4-23 hongxi.zhu 前置依赖(可选) sudo apt-get install vim sudo apt-get install cmake sudo apt-get install libncurses-dev sudo apt-get install libssl-dev sudo apt-get install git一、下载SDK和编译链 下载SD…

【OpenGL概念】QOpenGLWidget类详述--此文档基于Qt5.14.2

一、说明 QOpenGLWidget提供了在Qt应用程序中显示集成OpenGL图形的功能。使用它非常简单:让您的类继承它,并像使用任何其他QWidget一样使用子类,除了您可以选择使用QPainter和标准OpenGL渲染命令之间的区别。 二、QOpenGLWidget概述 QOpenGL…

云原生的基石:containerd引领未来容器发展趋势

文章目录 一、Containerd简介:容器技术的心脏二、Containerd核心原理解析三、Containerd与Docker的关系四、Containerd在云原生应用部署中的作用五、Containerd的扩展性和插件机制六、Containerd的安全特性七、Containerd的性能优化八、Containerd的社区和生态系统九…

c++ primer plus(1)

前言 本次博客将要通过文字以及代码来介绍 c primer plus 没有C语言基础的放心,我还是会把自己当成傻子,一步一步的来 主要是理解这本书的第二章重点内容,仅仅是笔者自己的鄙见,有问题请指出 OK,开始 第二章 首…

vue+vite+elements

1.安装 1> 安装vite&#xff08;直接安装&#xff09; 2> 安装好elements 3> 安装 windicss windicss简单用法 <template> <button class"btn">按钮</button> </template> <style scoped> .btn { apply bg-purple-500 …

新能源行业数据防泄密解决方案

行业背景 随着全球能源危机和环境污染问题日益突出,节能、环保有关行业的发展被高度重视,发展新能源电池已经在全球范围内形成共识。新能源电池相关技术是人们当下最为关注、研究投入最大的科研项目。人们不断尝试新的技术和材料,创造出新型电池。未来生活中将会有越来越高…

顺序表(详解)

1.什么是数据结构 所谓数据结构也就是数据在内存中的储存结构&#xff0c;它有 线性表&#xff0c;队列&#xff0c;栈结构&#xff0c;树结构&#xff0c;图结构等等&#xff0c;顺序表是线性表的一种。 2.物理结构与逻辑结构 物理结构是指一个数据在内存实际的储存空间&am…

C++面向对象程序设计 - 运算符重载

函数重载就是对一个已有的函数赋予新的含义&#xff0c;使之实现新的功能。因此一个函数名就可以用来代表不同功能的函数&#xff0c;也就是一名多用。运算符也可以重载&#xff0c;即运算符重载&#xff08;operator overloading&#xff09;。 一、运算符重载的方法 运算符重…

代码随想录学习Day 29

1005.K次取反后最大化的数组和 题目链接 讲解链接 思路&#xff1a;先对数组进行排序&#xff0c;保证数组中最小的值&#xff08;也就是取反后损失最小的值&#xff09;位于数组最前端。然后对数组进行遍历&#xff0c;在k次内尽可能将负数全部取反。当数组中元素全部>0…

indexDB 大图缓存

背景 最近在项目中遇到了一个问题&#xff1a;由于大屏背景图加载速度过慢&#xff0c;导致页面黑屏时间过长&#xff0c;影响了用户的体验。从下图可以看出加载耗时将近一分钟 IndexDB 主要的想法就是利用indexDB去做缓存&#xff0c;优化加载速度&#xff1b;在这之前&am…

在选择试验台底座时,应注意哪些问题——河北北重

在选择试验台底座时&#xff0c;应注意以下几个方面&#xff1a; 底座尺寸和承载能力&#xff1a;底座的尺寸和承载能力应与试验台的尺寸和所需承载的设备重量相匹配&#xff0c;确保底座能够稳定承载试验台和设备。 材料和质量&#xff1a;底座的材料应具有足够的强度和耐久性…

软件测试之【合理的利用GPT来辅助软件测试一】

读者大大们好呀&#xff01;&#xff01;!☀️☀️☀️ &#x1f525; 欢迎来到我的博客 &#x1f440;期待大大的关注哦❗️❗️❗️ &#x1f680;欢迎收看我的主页文章➡️寻至善的主页 文章目录 前言GPT的原理及技巧GPT辅助接口自动化测试 前言 在编程基础栏目中&#xff…

Kafak详解(1)

简介 消息队列 为什么要有消息队列 图-1 消息队列的使用 消息队列 1)消息Message&#xff1a;网络中的两台计算机或者两个通讯设备之间传递的数据。例如说&#xff1a;文本、音乐、视频等内容。 2)队列Queue&#xff1a;一种特殊的线性表(数据元素首尾相接)&#xff0c;特…

2024平替电容笔买哪个品牌好?iPad电容笔全能榜单热门款TOP5分享!

2024年&#xff0c;随着科技的不断发展和消费者对生活品质的追求&#xff0c;电容笔作为一种创新的无纸化工具&#xff0c;逐渐走进人们的生活和工作中。然而&#xff0c;在电容笔市场的繁荣背后&#xff0c;也隐藏着品质良莠不齐的现象。众多品牌为了追求利润&#xff0c;推出…

python常用高阶函数

map函数 map(function, iterable1[, iterable2, …]) map() 是 Python 内置的高阶函数&#xff0c;它用于将一个或多个可迭代对象&#xff08;如列表、元组、字符串等&#xff09;中的每个元素按照指定的函数进行处理&#xff0c;并返回一个迭代器&#xff08;iterator&#xf…

JS----随机数字,字符,数组

随机数字 function random(min 0, max 100) {if (min > 0 && max > 0 && max > min) {const gab max - min 1return Math.floor(Math.random() * gab min)}return 0 }输入格式 随机字符 function randomStr (len 32) {var s for (; s.lengt…

电力调度自动化系统由什么构成?

电力调度自动化系统由什么构成&#xff1f; 电力调度自动化系统通过数据采集与传输、数据处理与存储、监视与控制、优化与决策、通信网络和系统应用软件等构成&#xff0c;实现对电力系统的监控、控制和优化。 电力调度自动化系统是一种集成了计算机技术、通信技术、自动化技术…

SpringBoot下载Excel模板功能

目录 一、前端只需要填写一个a标签调用一下后端接口即可 二、后端 2.1 准备一个excel模板 &#xff0c;将其复制到resource目录下的templates文件夹下 2.2 接着复制下列代码即可 三、运行效果 一、前端只需要填写一个a标签调用一下后端接口即可 1.1 先代理一下防止跨域 e…