pymysql

# 增删改操作

import pymysql

client=pymysql.connect(

host='127.0.0.1',

port=3306,

user='root',

password='egon123',

database='db2',

charset='utf8'

)

cursor=client.cursor()

# insert的三种方法:

# 方法一

sql='insert into t1 values(1,"egon"),(2,"lxx");'  # 原生sql语句

try:  # 下面省略异常捕捉

res=cursor.execute(sql)

print(res)  # 返回的是执行表操作条数

client.commit()  # 递交后才会改变数据

except Exception:

client.rollback()  # 如果字段有误就能恢复修改前数据

#方法二

userinfo=[

(3,"alex"),

(4,"lxx"),

(5,"yxx")

]

for user in userinfo:

sql = ‘insert into t1 values(%s,”%s”);’ %(user[0],user[1])

cursor.execute(sql)

#方法三

sql = ‘insert into t1 values(%s,%s);’

cursor.executemany(sql,userinfo)

# 删除方法

cursor.execute(‘delete from t1 where id=3;’)

client.commit()

cursor.close()

client.close()

#查询操作

Import pymysql

client=pymysql.connect(

host='127.0.0.1',

port=3306,

user='root',

password='egon123',

database='db6',

charset='utf8'

)

cursor =client.cursor()

inp_user=input('输入账号名: ').strip()

inp_pwd=input('输入密码: ').strip()

sql='select id from user where name = "%s" and pwd = password("%s");' %(inp_user,inp_pwd)

rows = cursor.execute(sql)

# 这个方法可以防止注入问题

# sql = 'select id from t1 where name =%s and password = %s; ' # 注意:账号密码不用引号了

# rows = cursor.execute(sql,(inp_user,inp_pwd))  # 这句防注入问题

if rows:

print(‘登录成功’)

else:

print(‘用户名或密码错误’)

cursor.close()

client.close()

# 不做任何处理会产生注入问题,比如输入账号时输入alex "-- sadafas

或   sadgasd " or 1=1 – sfaf类似的可以直接登录

视图

强调:1.字段名不能重复

2.视图是为了简化查询的sql语句,不应该修改视图中的记录

create view emp2dep as select emp.*,dep.name as dep_name from emp inner join dep on

emp.dep_id = dep.id;

触发器

准备表

CREATE TABLE cmd (

id INT PRIMARY KEY auto_increment,

USER CHAR (32),

priv CHAR (10),

cmd CHAR (64),

sub_time datetime, #提交时间

success enum ('yes', 'no') #0代表执行失败

);

CREATE TABLE errlog (

id INT PRIMARY KEY auto_increment,

err_id int

);

delimiter $$  # 改变结束条件

CREATE TRIGGER tri_after_insert_cmd AFTER INSERT ON cmd FOR EACH ROW # 创建触发器

BEGIN

if NEW.success = 'no' then  # if

insert into errlog(err_id) values(NEW.id);

end if;

END $$

delimiter ;  # 必须改回结束条件

INSERT INTO cmd (

USER,

priv,

cmd,

sub_time,

success

)

VALUES

('egon','0755','ls -l /etc',NOW(),'yes'),

('egon','0755','cat /etc/passwd',NOW(),'no'),

('egon','0755','useradd xxx',NOW(),'no'),

('egon','0755','ps aux',NOW(),'yes');

#查询错误日志,发现有两条

#触发器可用于插入删除更新的前后

删除触发器:drop trigger tri_after_insert_cmd;

transaction:事务,交易

# 1、原子性:事务可以包含一系列的sql语句,事务的执行具有原子性

#2、回滚:包含多条sql语句要么都执行成功,要么都执行不成功

create table user(

id int primary key auto_increment,

name char(32),

balance int

);

insert into user(name,balance)

values

('wsb',1000),

('egon',1000),

('ysb',1000);

#出现异常,回滚到初始状态

start transaction;

update user set balance=900 where name='wsb'; #买支付100元

update user set balance=1010 where name='egon'; #中介拿走10元

uppdate user set balance=1090 where name='ysb'; #卖家拿到90元,出现异常没有拿到

rollback;

commit;

存储过程

方案一:

应用程序:

mysql:编写存储过程

方案二:

应用程序:原生sql

mysql:

方案三:

应用程序:ORM(类/对象 --->原生sql)

mysql:

执行效率:

方案一 > 方案二 -> 方案三

开发效率:

方案一 > 方案三 -> 方案二

由于方案一所需的人员成本较高,我们一般使用方案三

# 无参

create table s1(

id int,

name varchar(20),

gender char(6),

email varchar(50)

)

delimiter $$

create procedure p2()

BEGIN

declare n int default 1;  #设置整型n的初始值为1

while (n < 100) do

insert into s1 values(n,concat(‘egon’,n),’male’,concat(‘egon’,n,’@163.com’));

set n = n+1  # 注意不能用 n+=1

end while;

END $$

delimiter;

# 有参

delimiter $$

create procedure p3(

in n int,  # 传入的值

out res int  # 传出的值

)

BEGIN

select * from blog where id >n;

set res = 0;

END $$

delimiter;

# 直接在mysql中调用:

mysql> set @x=111;
mysql> call p3(3,@x);
mysql> select @x;

可以查到@x的值变为了0

# 在python中调用:

cursor.callproc('p4',(3,111)) #set @_p4_0 =
3; set @_p4_1 = 111

print(cursor.fetchall())

cursor.execute('select @_p4_1;')

print(cursor.fetchone())

pymysql与mysql各功能的更多相关文章

  1. Python3中使用PyMySQL连接Mysql

    Python3中使用PyMySQL连接Mysql 在Python2中连接Mysql数据库用的是MySQLdb,在Python3中连接Mysql数据库用的是PyMySQL,因为MySQLdb不支持Pyt ...

  2. Python 3.2: 使用pymysql连接Mysql

    在python 3.2 中连接MYSQL的方式有很多种,例如使用mysqldb,pymysql.本文主要介绍使用Pymysql连接MYSQL的步骤 1        安装pymysql ·       ...

  3. pymysql:Mysql拒绝从远程访问的解决办法

    pymysql:Mysql拒绝从远程访问的解决办法 pymysql连接数据库 # 导入pymysql模块 import pymysql # 连接database conn = pymysql.conn ...

  4. pymysql操作mysql

    一.使用PyMySQL操作mysql数据库 适用环境 python版本 >=2.6或3.3 mysql版本>=4.1 安装 可以使用pip安装也可以手动下载安装.使用pip安装,在命令行执 ...

  5. Python3.x使用PyMysql连接MySQL数据库

    Python3.x使用PyMysql连接MySQL数据库 由于Python3.x不向前兼容,导致Python2.x中的很多库在Python3.x中无法使用,例如Mysqldb,我前几天写了一篇博客Py ...

  6. python基础学习24----使用pymysql连接mysql

    使用pymysql连接mysql 安装pymysql pymysql安装可以通过两种方式 使用pip安装 首先简单说一下pip的使用方法 获取帮助 pip --help 升级 pip pip inst ...

  7. MySQL日志功能详解

    MySQL日志功能详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.查询日志 它是用来保存所有跟查询相关的日志,这种日志类型默认是关闭状态的,因为MySQL的用户有很多,如果 ...

  8. Python3.x:使用PyMysql连接Mysql数据库

    Python3.x:使用PyMysql连接Mysql数据库 Python3.x完全不向前兼容,导致Python2.x中可以正常使用的库,到了Python3就用不了: 比如说mysqldb,目前MySQ ...

  9. mysql分区功能(三个文件储存一张表)(分区作用)(分区方式)

    mysql分区功能(三个文件储存一张表)(分区作用)(分区方式) 一.总结 1.mysql数据表的存储方式(三个文件储存一张表): 一张表主要对应着三个文件,一个是frm存放表结构的,一个是myd存放 ...

随机推荐

  1. HTML/CSS/JS编码规范

    最近整理了一份HTML/CSS/JS编码规范,供大家参考.目录:一.HTML编码规范二.CSS编码规范三.JS编码规范 一.HTML编码规范 1. img标签要写alt属性 根据W3C标准,img标签 ...

  2. js_实现给未来元素添加事件。

    未来元素:不是一个页面上的元素,是通过js或者通过后台直接渲染在页面上的元素,也就是说这些元素不是直接写在document中的. 1.对于未来元素,我们想直接用js或者jq操作它们是不起作用的. $( ...

  3. Linux 入门记录:十、Linux 下获取帮助

    一.获取帮助 Linux 提供了极为详细的帮助工具和文档,通过查阅相关文档,可以大大减少需要记忆的东西并提高效率. 二.--help参数 几乎所有命令都可以使用 -h 或 --help 参数获取命令的 ...

  4. [device tree] How to decompile a compiled .dtb (device tree blog) into .dts (device tree source).

    $ ./out/target/product/project_name/obj/KERNEL_OBJ/scripts/dtc/dtc -I dtb -O dts -o decompiled.dts ~ ...

  5. c++设计模式系列----单例模式(Singleton模式

    单例模式是为了解决唯一对象实例问题而提出来的,许多时候整个系统只需要拥有一个全局对象,这样有利于我们协调系统整体的行为.比如在某个服务器程序中,该服务器的配置信息存放在一个文件中,这些配置数据由一个单 ...

  6. C后端设计开发 - 第1章-流派-入我华山,学我剑法

    正文 第1章-流派-入我华山,学我剑法 后记 如果有错误, 欢迎指正. 有好的补充, 和疑问欢迎交流, 一块提高. 在此谢谢大家了.

  7. Phoenix批量修改数据

    很简单的一个东西,查了挺久的,浪费了很多的时间 直接用Upsert Into Select就可以了 例:把tables表中cloumn2列等于bbb的都改成aaa Upsert Into Table  ...

  8. JDBC数据源连接池(2)---C3P0

    我们接着<JDBC数据源连接池(1)---DBCP>继续介绍数据源连接池. 首先,在Web项目的WebContent--->WEB-INF--->lib文件夹中添加C3P0的j ...

  9. [PAT] 1141 PAT Ranking of Institutions(25 分)

    After each PAT, the PAT Center will announce the ranking of institutions based on their students' pe ...

  10. (转) Spring源码阅读 之 Spring整体架构

    标签(空格分隔): Spring 声明:本文系转载,原地地址:spring framework 4 源码阅读 Spring骨架 Spring的骨架,也是Spring的核心包.主要包含三个内容 cont ...