python操作mysql数据库,为什么要在执行后加commit()?
一、python操作mysql数据库,为什么要在执行后加commit()
因为在操作数据库的时候是先在程序中执行sql语句,这种操作并没有在本地数据库中更新,当我们只想commit时才会真正更新。这样就可以避免我们操作途中遇到问题,导致数据只操作一般的问题。像银行转账就是个很好的例子,我的钱转出去了,但是这个时候出现问题,程序结束了。这个时候我的钱少了,但是收款方却没收到钱。
通用步骤
其实,这里有一个通用步骤,都是写死了的,大家照做就行。
# 1. 导入相关库
import pymysql
# 2. 链接MySQL服务器
db = pymysql.connect(host=’localhost’ , user=’root’ , password=’******’ , port=3306 ,db=’spiders’ , charset=’utf8′)
# 3. 创建一个cursor游标对象
cursor = db.cursor()
# 4. 在这一步写你的sql语句
sql = ‘select version()’
# 5. 执行sql语句
cursor.execute(sql)
# 6. 断开连接
db.close()
可以看出,整个过程就是第四步那里不同。归根到底,其实就是写sql。
延伸阅读:
二、数据库中的概念
Table:数据库中的表,下文称“table”或者“表”。
Column:表中的各个字段,下文称“column”或者“列”或者“字段”。
Row:表中的各条记录,下文称“row”或者“行”
Index:表中的索引,用户可以建立索引以便加速搜索,但是用户无法直接使用索引,下文称“index”或者“索引”。
View:数据库中的视图,一种由实际的表导出的可视化的表,并不实际存储。
Virtual table:虚拟表是一种表现得像表的对象,从SQL语句的角度看,虚表可以和表或者view一样操作,但是对虚拟表的查询或者修改操作会调用注册在虚拟表上的回调函数,虚拟表机制使程序可以提供类似于SQL的表的接口供SQL语句操作。隐藏在虚拟表下的数据结构可能是内存中的数据,或者通过即时运算得出的结果,或者是磁盘上的文件(比如CSV)。下文称“virtual table”或者“虚拟表”。
Shadow table:FTS(全文搜索)中所使用的每个virtual table,都有3-5个真实的数据库的table(分别名为%_content、%_segdir、%_segment、 %_stat、%_docsize,%是FTS virtual table的名字)来在实现,这些table被称为shadow table。
Trigger:数据库中的触发器,由修改数据库的事件触发的存储过程,下文称“触发器”或者“trigger”。
Schema:SQLite数据库的结构(有哪些table/index/view/trigger,分别有哪些字段),下文称“schema”。
Rowid:rowid是SQLite中的表隐含的一个column,是其内部id,在该表中少数,是SQLite中的元数据。
Statement:SQL语句。
Prepared statement:经过“预备”的SQL语句,所谓“预备”类似编译,可以再多次执行同一语句的时候加速(跳过“预备”过程)。
sqlite_master:sqlite数据库中维护的系统表,该表的b-tree的根页号永远为1,有5个列,分别是类型(table, view, index,trigger,四者之一)、名称、所在表名、根页号、SQL语句。
Journal:日志
Transaction:事务是用户定义的一系列数据库操作,要么全部执行,要么全部不执行。
Magic string:类似“魔数/幻数”,SQLite数据库文件特征头。
Fraction
Auto-vacuum:自动清空
Incremental-vacuum
BLOB:Binary Large OBject
猜你喜欢LIKE
相关推荐HOT
更多>>MySQL索引为什么能让查询效率提高?
一、MySQL索引为什么能让查询效率提高DB在执行一条Sql语句的时候,默认的方式是根据搜索条件进行全表扫描。如果我们对某一字段增加索引,查询时...详情>>
2023-10-19 13:16:01什么是四层(L4 proxy)和七层负载均衡(L7 proxy)?
一、四层负载均衡(L4 proxy)四层负载均衡工作在OSI模型的传输层,由于在传输层,只有TCP/UDP协议,这两种协议中除了包含源IP、目标IP以外,还包...详情>>
2023-10-19 09:17:45为什么用navicat连接sqlserver后看不到master数据库?
一、为什么用navicat连接sqlserver后看不到master数据库在navicat的安装目录下找到sqlserver的驱动双击安装即可,现在我们就可以连接Navicat了...详情>>
2023-10-19 08:23:06mq消息积压中,突然mq挂了,或者mysql挂了,或者两个都挂了怎么处理?
一、mq消息积压中,mq挂了的处理方法如果MQ挂掉,势必会影响发消息的逻辑,MQ不像数据库,挂了就没办法进行任何操作了。MQ本身就是用于多系统解...详情>>
2023-10-19 06:18:33热门推荐
Python语言除了爬虫scrapy外还有哪些优势?
沸MySQL分布式集群数据是怎么存储的?
热MySQL索引为什么能让查询效率提高?
热oracle怎么样实现数据库跨机房同步?
新安卓开发前需要考虑哪些问题?
怎样系统全面的分析oracle的AWR报告?
IS(信息系统)没有数据库,系统的数据如何存储?
开发APP软件需要哪些编程语言和开发环境?
互联网、金融这两个领域上用于数据挖掘、数据分析的数据库是什么?
一个搜索框对应数据库多个字段,后台怎么对应?
什么是四层(L4 proxy)和七层负载均衡(L7 proxy)?
用count(*)做判断条件怎么弄的好一点?
为什么用navicat连接sqlserver后看不到master数据库?
MySQL的select语句怎么输出多行常量?