数据存储之关系型数据库存储---MySQL存储
MySQL的存储
利用PyMySQL连接MySQL
连接数据库
import pymysql # 连接MySQL MySQL在本地运行 用户名为root 密码为123456 默认端口3306
db = pymysql.connect(host='localhost', user='root', password='', port=3306) # cursor()方法获得MySQL的操作游标,利用游标来执行SQL语句,其中执行方法为execute()
cursor = db.cursor() # 获取MySQL的当前版本
cursor.execute('SELECT VERSION()') # fetchone()方法获得第一条数据,即版本号
data = cursor.fetchone()
print('Database version:', data) # 创建一个名为reptile的数据库,默认编码为utf8mb4
cursor.execute("CREATE DATABASE reptile DEFAULT CHARACTER SET utf8mb4")
db.close() # 运行输出:
Database version: ('8.0.16',)
# 运行生成一个名为reptile的数据库创建表
import pymysql db = pymysql.connect(host='localhost', user='用户名', password='密码', port=3306, db='reptile')
cursor = db.cursor()
sql = '''CREATE TABLE
IF NOT EXISTS students
(
id VARCHAR(255) NOT NULL,
name VARCHAR(255) NOT NULL,
age INT NOT NULL,
PRIMARY KEY (id)
)'''
# 创建一个名为students的数据表,主键为id
cursor.execute(sql)
db.close() # 运行创建一个数据表插入数据
import pymysql id = ''
user = 'Lee Hua'
age = 20 # 连接数据库
db = pymysql.connect(host='localhost', user='用户名', password='密码', port=3306, db='reptile')
# 获得MySQL的操作游标
cursor = db.cursor()
sql = '''INSERT INTO students(id, name, age) VALUES(%s %s %s)''' try:
# 执行
cursor.execute(sql, (id, user, age))
# 数据插入、更新、删除操作,都需要用到commit()方法才能生效
db.commit() except:
# 调用rollback()执行数据回滚,相当于什么都没有发生过
db.rollback() db.close() # 运行,数据被插入到数据表中import pymysql db = pymysql.connect(host='localhost', user='用户名', password='密码', port=3306, db='reptile')
cursor = db.cursor() data = {
'id': '',
'user': 'Lao wang',
'age': 19
}
table_name = 'students'
keys = ', '.join(data.keys()) # id, user, age
values = ', '.join(['%s'] * len(data)) # ['%s', '%s', ......] len(data)个'%s'
sql = '''INSERT INTO {table_name}({keys}) VALUES({values})'''.format(table_name=table_name, keys=keys, values=values)
# sql = INSERT INTO students(id, name, age) VALUES(%s %s %s) try:
tuple_ = tuple(data.values())
if cursor.execute(sql, tuple_):
print('成功插入数据')
db.commit() except:
print('插入数据失败')
db.rollback() db.close() # 与上面一个例子做比较更新数据
import pymysql db = pymysql.connect(host='localhost', user='用户名', password='密码', port=3306, db='reptile')
cursor = db.cursor() sql = 'UPDATA students SET age = %s WHERE name = %s'
try:
cursor.execute(sql, (25, 'Bob'))
db.commit()
except:
db.rollback() db.close() 简单方式数据更新简单方式数据更新
# 实现去重(如果数据存在,则更新数据;如果数据不存在,则插入数据。)
import pymysql db = pymysql.connect(host='localhost', user='用户名', password='密码', port=3306, db='reptile')
cursor = db.cursor() data = {
'id': '',
'user': 'Lao wang',
'age': 19
}
table_name = 'students'
keys = ', '.join(data.keys()) # keys = id, name, age
values = ', '.join(['%s'] * len(data)) # values = %s, %s, %s
update = ', '.join(
[" {key} = %s".format(key=key) for key in data]
) # id = %s, name = %s, age = %s
sql = '''INSERT INTO {table_name}({keys}) VALUES({values}) ON DUPLICATE KEY update'''.format(table_name=table_name, keys=keys, values=values)
# ON DUPLICATE KEY UPDATE 表示:如果主键已经存在,那么就执行更新操作 try:
tuple_ = tuple(data.values())
if cursor.execute(sql, tuple_):
print('成功插入数据')
db.commit() except:
print('插入数据失败')
db.rollback() db.close()删除数据
import pymysql db = pymysql.connect(host='localhost', user='用户名', password='密码', port=3306, db='reptile')
cursor = db.cursor() table = 'students'
condition = 'age > 20'
sql = 'DELETE FROM {table} WHERE {conditon}'.format(table=table, conditon=condition)
try:
cursor.execute(sql)
db.commit()
except:
db.rollback() db.close() # 删除age > 20的数据简单示例
查询数据
import pymysql db = pymysql.connect(host='localhost', user='用户名', password='密码', port=3306, db='reptile')
cursor = db.cursor() sql = 'SELECT * FROM students WHERE age >= 20'
try:
cursor.execute(sql)
print('Count:', cursor.rowcount) # 调用cursor的rowcount属性,获取查询结果的条数
one = cursor.fetchone() # 获取结果的第一条信息
print('One:', one)
result = cursor.fetchall() # 获取结果的所有数据
print('Result:', result)
print('Result Type:', type(result))
for row in result:
print(row)
except:
print('Error') # 输出:
Count: 0
One: None
Result: ()
Result Type: <class 'tuple'>一次性查询所有数据----fetchall()
import pymysql db = pymysql.connect(host='localhost', user='用户名', password='密码', port=3306, db='reptile')
cursor = db.cursor() sql = 'SELECT * FROM students WHERE age >= 20'
try:
cursor.execute(sql)
print('Count:', cursor.rowcount) # 调用cursor的rowcount属性,获取查询结果的条数
row = cursor.fetchone() # 获取结果的第一条数据
while row:
print('Row:', row)
row = cursor.fetchone()
except:
print('Error')逐条查询数据----fatchone()
数据存储之关系型数据库存储---MySQL存储的更多相关文章
- 解析IFC数据并存储到关系型数据库
即系IFC数据并存储到关系型数据库中,目前解析的IFC文件是两亿多行,构件数量120万
- Cobar是提供关系型数据库(MySQL)分布式服务的中间件
简介 Cobar是提供关系型数据库(MySQL)分布式服务的中间件,它可以让传统的数据库得到良好的线性扩展,并看上去还是一个数据库,对应用保持透明. 产品在阿里巴巴稳定运行3年以上. 接管了3000+ ...
- Python3爬虫(九) 数据存储之关系型数据库MySQL
Infi-chu: http://www.cnblogs.com/Infi-chu/ 关系型数据库关系型数据库是基于关系模型的数据库,而关系模型是通过二维表来保存的,所以关系型数据库的存储方式就是行列 ...
- 关系型数据库之Mysql
简介 主要知识点包括:能够与mysql建立连接,创建数据库.表,分别从图形界面与脚本界面两个方面讲解 相关的知识点包括:E-R关系模型,数据库的3范式,mysql中数据字段的类型,字段约束 数据库的操 ...
- 关系型数据库之MySQL基础总结_part1
一:数据库的操作语言的种类 MySQL 是我们最常使用的关系型数据库,对于MySQL的操作的语言种类又可以分为:DDL,DML,DCL,DQL DDL:是数据库的定义语言:主要对于数据库信息的一些定义 ...
- 关于关系型数据库(MySQL)的一些概念
主键:关系型数据库中的一条记录中有若干个属性,若其中某一个属性组(注意是组)能唯一标识一条记录, 该属性组就可以成为一个主键,主键不允许为空,主键只能有同一个 外键:如果一个表的某个属性是另一个表的主 ...
- 【大数据】安装关系型数据库MySQL安装大数据处理框架Hadoop
作业来源于:https://edu.cnblogs.com/campus/gzcc/GZCC-16SE2/homework/3161 1. 简述Hadoop平台的起源.发展历史与应用现状. 列举发展过 ...
- 【大数据】安装关系型数据库MySQL 安装大数据处理框架Hadoop
作业要求来自:https://edu.cnblogs.com/campus/gzcc/GZCC-16SE2/homework/3161 1.安装Mysql 使用命令 sudo apt-get ins ...
- 应用开发实践之关系型数据库(以MySql为例)小结
本文主要是对目前工作中使用到的DB相关知识点的总结,应用开发了解到以下深度基本足以应对日常需求,再深入下去更偏向于DB本身的理论.调优和运维实践. 不在本文重点关注讨论的内容(可能会提到一些): 具体 ...
随机推荐
- 【SQL server初级】数据库性能优化二:数据库表优化
数据库优化包含以下三部分,数据库自身的优化,数据库表优化,程序操作优化.此文为第二部分 数据库性能优化二:数据库表优化 优化①:设计规范化表,消除数据冗余 数据库范式是确保数据库结构合理,满足各种查询 ...
- JAVA MyBatis配置文件用properties引入外部配置文件
方式一:通过properties 元素的子元素来传递数据 例如: <properties> <property name="driver" value=" ...
- java并发之CAS详解
前言 在高并发的应用当中,最关键的问题就是对共享变量的安全访问,通常我们都是通过加锁的方式,比如说synchronized.Lock来保证原子性,或者在某些应用当中,用voliate来保证变量的可见性 ...
- BZOJ 2535: [Noi2010]Plane 航空管制2
Description 世博期间,上海的航空客运量大大超过了平时,随之而来的航空管制也频频发生.最近,小X就因为航空管制,连续两次在机场被延误超过了两小时.对此,小X表示很不满意. 在这次来烟台的路上 ...
- 经典的Redis的主从复制搭建
##### 配置服务器 1).打开redis.conf文件修改 bind 指定的ip地址: ![image](https://img2018.cnblogs.com/blog/1334966/20 ...
- Bran的内核开发教程(bkerndev)-04 创建main函数和链接C文件
目录 创建main函数和链接C文件 PS: 下面是我自己写的 Win10安装gcc编译器 本节教程对应的Linux下的编译脚本 _main的问题 创建main函数和链接C文件 一般C语言使用mai ...
- dnn文本分类
简介 文本分类任务根据给定一条文本的内容,判断该文本所属的类别,是自然语言处理领域的一项重要的基础任务.具体的,本任务是对文本quey进行分类,任务流程如下: 收集用户query数据. 清洗,标记. ...
- 中国.NET开发者峰会特别活动-基于k8s的微服务和CI/CD动手实践报名
2019.11.9 的中国.NET开发者峰会将在上海举办,到目前为止,大会的主题基本确定,这两天就会和大家会面,很多社区的同学基于对社区的信任在我们议题没有确定的情况下已经购票超过了300张,而且分享 ...
- [Abp vNext 源码分析] - 11. 用户的自定义参数与配置
一.简要说明 文章信息: 基于的 ABP vNext 版本:1.0.0 创作日期:2019 年 10 月 23 日晚 更新日期:暂无 ABP vNext 针对用户可编辑的配置,提供了单独的 Volo. ...
- table表格中文字超出显示省略号
第一步: table {table-layout:fixed:}列宽由表格宽度和列宽度设定,不随文字多少变化 第二步: td { white-space:nowrap;/*文本不会换行,文本会在在同一 ...