Pyhton学习——Day48
# 转载:http://www.cnblogs.com/yuanchenqi/articles/6437362.html
#python关于mysql的API--pymysql模块
# 执行sql语句
# import pymysql
#
# #添加数据
#
# conn = pymysql.connect(host='127.0.0.1', port=3306, user='root', passwd='', db='yyy')
#
# cursor = conn.cursor()
#
#
# # sql = """CREATE TABLE EMPLOYEE (
# # FIRST_NAME CHAR(20) NOT NULL,
# # LAST_NAME CHAR(20),
# # AGE INT,
# # SEX CHAR(1),
# # INCOME FLOAT )"""
# #
# # cursor.execute(sql)
#
# #row_affected = cursor.execute("create table t1(id INT ,name VARCHAR(20))")
#
# #row_affected=cursor.execute("INSERT INTO t1(id,name) values (1,'alvin'),(2,'xialv')")
#
# #cursor.execute("update t1 set name = 'silv2' where id=2")
#
#
#
#
# #查询数据
# row_affected=cursor.execute("select * from t1")
# one=cursor.fetchone()
#
# # many=cursor.fetchmany(2)
# # all=cursor.fetchall()
#
#
#
# #scroll
# #cursor.scroll(-1,mode='relative') # 相对当前位置移动
#
# #cursor.scroll(2,mode='absolute') # 相对绝对位置移动
#
#
# #更改获取数据结果的数据类型,默认是元组,可以改为字典等:conn.cursor(cursor=pymysql.cursors.DictCursor)
#
#
# conn.commit()
# cursor.close()
# conn.close()
#——————————————————————————————————————————————————#
# 事务(非常重要)
# 事务指逻辑上的一组操作,组成这组操作的各个单元,要不全部成功,要不全部不成功。
# 数据库开启事务命令
# -- start transaction 开启事务
# -- Rollback 回滚事务,即撤销指定的sql语句(只能回退insert delete update语句),回滚到上一次commit的位置
# -- Commit 提交事务,提交未存储的事务
# --
# -- savepoint 保留点 ,事务处理中设置的临时占位符 你可以对它发布回退(与整个事务回退不同)
# UPDATE account set balance=balance-5000 WHERE name=”yuan”;
# UPDATE account set balance=balance+5000 WHERE name=”xialv”;
# create table test2(id int PRIMARY KEY auto_increment,name VARCHAR(20)) engine=innodb;
# INSERT INTO test2(name) VALUE ("alvin"),
# ("yuan"),
# ("xialv");
#
#
#
# start transaction;
# insert into test2 (name)values('silv');
# select * from test2;
# commit;
#
#
# -- 保留点
#
# start transaction;
# insert into test2 (name)values('wu');
# savepoint insert_wu;
# select * from test2;
#
#
#
# delete from test2 where id=4;
# savepoint delete1;
# select * from test2;
#
#
# delete from test2 where id=1;
# savepoint delete2;
# select * from test2;
#
# rollback to delete1;
#
#
# select * from test2;
#
# savepoint
#——————————————————————————————————————————————————#
# python中调用数据库启动事务的方式
# import pymysql
#
# #添加数据
#
# conn = pymysql.connect(host='127.0.0.1', port=3306, user='root', passwd='', db='yyy')
#
# cursor = conn.cursor()
#
#
# try:
# insertSQL0="INSERT INTO ACCOUNT2 (name,balance) VALUES ('oldboy',4000)"
# insertSQL1="UPDATE account2 set balance=balance-30 WHERE name='yuan'"
# insertSQL2="UPDATE account2 set balance=balance+30 WHERE name='xialv'"
#
# cursor = conn.cursor()
#
# cursor.execute(insertSQL0)
# conn.commit()
#
# cursor.execute(insertSQL1)
# raise Exception
# cursor.execute(insertSQL2)
# cursor.close()
# conn.commit()
#
# except Exception as e:
#
# conn.rollback()
# conn.commit()
#
#
# cursor.close()
# conn.close()
#——————————————————————————————————————————————————#
# 事务特性
# <1> 原子性(Atomicity):原子性是指事务是一个不可分割的工作单位,事务中的操作要么都发生,要么都不发生。
#
# <2> 一致性(Consistency):事务前后数据的完整性必须保持一致。
# 在事务执行之前数据库是符合数据完整性约束的,无论事务是否执行成功,
# 事务结束后的数据库中的数据也应该是符合完整性约束的。
# 在某一时间点,如果数据库中的所有记录都能保证满足当前数据库中的所有约束,
# 则可以说当前的数据库是符合数据完整性约束的。
# 比如删部门表前应该删掉关联员工(已经建立外键),如果数据库服务器发生错误,
# 有一个员工没删掉,那么此时员工的部门表已经删除,那么就不符合完整性约束了,所以这样的数据库也就性能太差啦!
#
# <3>隔离性(Isolation):事务的隔离性是指多个用户并发访问数据库时,
# 一个用户的事务不能被其它用户的事务所干扰,多个并发事务之间数据要相互隔离。
#
# <4>持久性(Durability):持久性是指一个事务一旦被提交,
# 它对数据库中数据的改变就是永久性的,接下来即使数据库发生故障也不应该对其有任何影响。
#
# 三、隔离性:
# 将数据库设计为串行化程的数据库,让一张表在同一时间内只能有一个线程来操作。
# 如果将数据库设计为这样,那数据库的效率太低了。
# 所以数据库的设计这没有直接将数据库设计为串行化,而是为数据库提供多个隔离级别选项,
# 使数据库的使用者可以根据使用情况自己定义到底需要什么样的隔离级别。
#
# 不考虑隔离性可能出现的问题:
# 脏读
# --一个事务读取到了另一个事务未提交的数据,这是特别危险的,要尽力防止。
# a 1000
# b 1000
# a:
# start transaction;
# update set money=money+100 where name=b;
# b:
# start transaction;
# select * from account where name=b;--1100
# commit;
# a:
# rollback;
# b: start transaction;
# select * from account where name=b;--1000
# 不可重复读
# --在一个事务内读取表中的某一行数据,多次读取结果不同。(一个事务读取到了另一个事务已经提交
# -- 的数据--增加记录、删除记录、修改记录),在某写情况下并不是问题,在另一些情况下就是问题。
#
# a:
# start transaction;
# select 活期账户 from account where name=b;--1000 活期账户:1000
# select 定期账户 from account where name=b;--1000 定期账户:1000
# select 固定资产 from account where name=b;--1000 固定资产:1000
# ------------------------------
# b:
# start transaction;
# update set money=0 where name=b;
# commit;
# ------------------------------
# select 活期+定期+固定 from account where name=b; --2000 总资产: 2000
# 虚读
# 是指在一个事务内读取到了别的事务插入的数据,导致前后读取不一致。
# (一个事务读取到了另一个事务已经提交的数据---增加记录、删除记录),在某写情况下并不是问题,在另一些情况下就是问题。
#
# b 1000
# c 2000
# d 3000
# a:
# start transaction
# select sum(money) from account;---3000 3000
# -------------------
# d:start transaction;
# insert into account values(d,3000);
# commit;
# -------------------
# select count(*)from account;---3 3
# 3000/3 = 1000 1000
# 四个隔离级别:
# Serializable:可避免脏读、不可重复读、虚读情况的发生。(串行化)
# Repeatable read:可避免脏读、不可重复读情况的发生。(可重复读)不可以避免虚读
# Read committed:可避免脏读情况发生(读已提交)
# Read uncommitted:最低级别,以上情况均无法保证。(读未提交)
#
# 安全性考虑:Serializable>Repeatable read>Read committed>Read uncommitted
# 数据库效率:Read uncommitted>Read committed>Repeatable read>Serializable
#
# 一般情况下,我们会使用Repeatable read、Read committed mysql数据库默认的数据库隔离级别Repeatable read
#
# mysql中设置数据库的隔离级别语句:
#
# 1
# set [global/session] transaction isolation level xxxx;
# 如果使用global则修改的是数据库的默认隔离级别,
# 所有新开的窗口的隔离级别继承自这个默认隔离级别如果使用session修改,
# 则修改的是当前客户端的隔离级别,和数据库默认隔离级别无关。
# 当前的客户端是什么隔离级别,就能防止什么隔离级别问题,和其他客户端是什么隔离级别无关。
# mysql中设置数据库的隔离级别语句:
#
# 1
# select @@tx_isolation; #——————————————————————————————————————————————————#
# 索引
# 索引在MySQL中也叫做“键”,是存储引擎用于快速找到记录的一种数据结构。索引对于良好的性能非常关键,
# 尤其是当表中的数据量越来越大时,索引对于性能的影响愈发重要。
#
# 索引优化应该是对查询性能优化最有效的手段了。
# 索引能够轻易将查询性能提高好几个数量级。
# 索引相当于字典的音序表,如果要查某个字,如果不使用音序表,则需要从几百页中逐页去查。
#
# 索引特点:创建与维护索引会消耗很多时间与磁盘空间,但查询速度大大提高!
# 二 索引语法
# --创建表时
# --语法:
# CREATE
# TABLE
# 表名(
# 字段名1
# 数据类型[完整性约束条件…],
# 字段名2
# 数据类型[完整性约束条件…],
# [UNIQUE | FULLTEXT | SPATIAL]
# INDEX | KEY
# [索引名](字段名[(长度)][ASC | DESC])
# );
#
# --------------------------------
#
# --创建普通索引示例:
#
# CREATE
# TABLE
# emp1(
# id
# INT,
# name
# VARCHAR(30),
# resume
# VARCHAR(50),
# INDEX
# index_emp_name(name)
# - -KEY
# index_dept_name(dept_name)
# );
#
#
#
# --创建唯一索引示例:
#
# CREATE
# TABLE
# emp2(
# id
# INT,
# name
# VARCHAR(30),
# bank_num
# CHAR(18)
# UNIQUE,
# resume
# VARCHAR(50),
# UNIQUE
# INDEX
# index_emp_name(name)
# );
#
# --创建全文索引示例:
#
# CREATE
# TABLE
# emp3(
# id
# INT,
# name
# VARCHAR(30),
# resume
# VARCHAR(50),
# FULLTEXT
# INDEX
# index_resume(resume)
# );
#
# --创建多列索引示例:
#
# CREATE
# TABLE
# emp4(
# id
# INT,
# name
# VARCHAR(30),
# resume
# VARCHAR(50),
# INDEX
# index_name_resume(name, resume)
# );
#
#
#
# ---------------------------------
#
# ---添加索引
#
# ---CREATE在已存在的表上创建索引
# CREATE[UNIQUE | FULLTEXT | SPATIAL]
# INDEX
# 索引名
# ON
# 表名(字段名[(长度)][ASC | DESC]);
#
# ---ALTER
# TABLE在已存在的表上创建索引
#
# ALTER
# TABLE
# 表名
# ADD[UNIQUE | FULLTEXT | SPATIAL]
# INDEX
# 索引名(字段名[(长度)][ASC | DESC]);
#
# CREATE
# INDEX
# index_emp_name
# on
# emp1(name);
# ALTER
# TABLE
# emp2
# ADD
# UNIQUE
# INDEX
# index_bank_num(band_num);
#
# -- 删除索引
#
# 语法:DROP
# INDEX
# 索引名
# on
# 表名
#
# DROP
# INDEX
# index_emp_name
# on
# emp1;
# DROP
# INDEX
# bank_num
# on
# emp2;
Pyhton学习——Day48的更多相关文章
- Pyhton学习——Day26
#多态:多态指的是一类事物有多种形态# import abc# class Animal(metaclass = abc.ABCMeta):# 同一类事物:动物# @abc.abstractclass ...
- pyhton 学习
官方学习文档 https://docs.python.org/3/tutorial/
- 20190320_head first pyhton学习笔记之构建发布
1.把代码nester.py放入文件夹nester中,在文件夹中再新建一个setup.py文件,文件内容如下: from distutils.core import setup setup( name ...
- Pyhton学习——Day2
Python开发IDE(工具)Pycharm.eclipse1.循环while 条件 #循环体 #条件为真则执行 #条件为假则执行break用于退出所有循环continue用于退出当前循环 2.Pyc ...
- Pyhton学习——Day28
#上下文协议:文件操作时使用with执行# with open('a.txt','w',encoding='utf-8') as f1:# with语句,为了让一个对象兼容with语句,必须在这个对象 ...
- Pyhton学习——Day27
# hasattr(obj,'name')-->obj.name# getattr(obj,'name',default = 'xxx')--->obj.name# setattr(obj ...
- Pyhton学习——Day25
#面向对象的几个方法#1.静态方法@staticmethod,不能访问类属性,也不能访问实例属性,只是类的工具包#2.类方法:@classmethod,在函数属性前加上类方法,显示为(cls)代表类, ...
- Pyhton学习——Day24
# #面向对象设计:# def dog(name,gender,type):# def jiao(dog):# print('One Dog[%s],wfwfwf'%dog['name'])# def ...
- Pyhton学习——Day23
#re模块方法:findall search#findall:返回所有满足匹配条件的数值,放在列表里#search : #函数会在字符串内查找模式匹配,只到找到第一个匹配然后返回一个包含匹配信息的对象 ...
随机推荐
- gazebo 7.0 升级到7.15 参考他人博客
gazebo 7.0 升级到7.14 网址:https://blog.csdn.net/riancy_riancy/article/details/84568322 编译后遇到报错 ,解决问题的网址: ...
- linu问题集锦
问题1 系统卡 慢 执行命令延迟/var/spool/mail下root文件过大导致/var磁盘空间92% cd / && du | sort -n | tail -n 10 查看排名 ...
- nyoj312-20岁生日
20岁生日 时间限制:1000 ms | 内存限制:65535 KB 难度:1 描述 路过这的20岁生日就要到了,他当然很开心,可是他突然想到一个问题,是不是每个人从出生开始,到达20岁生日时所经 ...
- JAVA基础知识复习小结
集合 Set集合 Set集合的基本特征是元素不允许重复.HashSet不保存元素顺序,LinkedHashSet用链表保持元素的插入顺序,TreeSet可定制排序规则. HashSet的底层是用Has ...
- 【hihocoder 1312】搜索三·启发式搜索(普通广搜做法)
[题目链接]:http://hihocoder.com/problemset/problem/1312?sid=1092352 [题意] [题解] 从末状态的123456780开始逆向搜; 看它能到达 ...
- 【codeforces 723F】st-Spanning Tree
[题目链接]:http://codeforces.com/contest/723/problem/F [题意] 给你一张图; 让你选择n-1条边; 使得这张图成为一颗树(生成树); 同时s的度数不超过 ...
- ZOJ 3891 K-hash
K-hash Time Limit: 2000ms Memory Limit: 131072KB This problem will be judged on ZJU. Original ID: 38 ...
- UVA11752 The Super Powers
/* UVA11752 The Super Powers https://vjudge.net/contest/153365#problem/Y 数论 注意a^n=b要用除法求,并且求得的n比实际大1 ...
- C#中的Attribute定义及用法
1.Attribute定义 公共语言运行时允许添加类似关键字的描述声明,叫做attributes, 它对程序中的元素进行标注,如类型.字段.方法和属性等.Attributes和Microsoft .N ...
- POJ 1950
直接DFS,因为实在没想到什么剪枝了... 注意一点是,10.11使用的是1011哦 #include <iostream> #include <cstdio> #includ ...