python实现一次性封装多条sql语句(begin end)


Posted in Python onJune 06, 2020

python封装利用begin end执行多条sql

因为业务需求,优化模型运行时间。考虑到sql语句每一次执行都要建立连接,查询,获取数据耗时过多。就想到将sql一起提交上去运行,能够节省很多时间。原本1.6-2.5秒耗时的sql语句经过修改后时间降到0.3-0.6秒,感觉性能提升挺好的。

当然还有一种想法,如果有python框架的orm可能会更快,相比来说耗时基本看不到了吧,这只是我的猜想,仅仅为了优化一个模型写一个框架的话 代码可能需要改的比较多,自我感觉付出和收获不一定会成正比,当然以后有时间可以试试。

这次优化基本代码逻辑没有动,利用了begin end进行sql整合。

公司用的是oracle,之前没用过但是感觉和mysql基本类似,如果是mysql的话该方法也可用

sql_str = ‘begin\n'
sql_str += ‘这里时需要执行的sql语句'
sql_str += ‘\ncommit;end;'

中间sql有多少条无所谓,看了一下运行时间感觉 我的一千行sql耗时 几乎就是这一千行里面耗时最长那个时间。是异步完成还是什么这个就不是很清楚了,主要是一次建立连接,省去网络传输数据和请求数据库的过程

网上好多begin end都是在可视化工具中的sql执行的,并不能在command中执行,这就意味中我们代码中封装的语句没有卵用,还好没放弃当时就研究了一下找到了解决办法

在end 提交一下就ok了,如果在command中运行一直未结束的话加一个 / 斜线就ok了

本次内容就此结束,下面是一些题外话。

在说一个其中遇到的问题吧,在进行sql封装后,其中很多表都很乱,约束很乱 而且逻辑并不严谨,但是模型正在运行还不让动 那只能按照这个规则来了

ORA 00001 违反唯一约束条件 其中出现了这个问题,意思就是唯一约束重复了,因为模型输入问题,处理出来的结果之前可能刚插入到数据库中(也就是 上面的sql_str 出现了两天相同的insert),这个东西很简单,加一个set判断一下就行,但是到这之后,一个bug就跳出来了,这个脚本计算的是因子重要度,结果预测可能每次都不相同,有些数据很小的可能就当成0扔进去了,所以我需要做的是将 相同数据的情况下插入较为重要的因子重要度(也无需要 ),这样的话简简单单的set就不行了,但是也不难 用来一下字典

importance_map = {}
 实现创建好字典
 if feature in importance_map:
        if importance_map[feature] < importance:
          sql_str +=‘***************‘'' 这里就是insert语句了
        else:
          continue
      else:
        importance_map[feature] = importance

其实这个东西也没有什么难点,但是做到这之后就有很多想法折射出来。

数据处理原本也可以用pandas进行,但是pandas是对所有数据进行操作,我一个set只对重复数据进行操作,切pandas内存消耗极为严重,前两天写的特征工程内存炸裂。表数据用完后内存并没有得到释放,这里面就涉及到python的垃圾回收,用法至今没有搞懂,还需要研究研究,gc是对循环引用进行垃圾回收,内存释放。但是这个pandas并不是循环引用,我认为是在存储在缓存区中,位置占死了,就很烦

模型毕竟是在服务器上面跑,尽量快切省内存,不然你把内存占了 别人的项目怎么玩。所以就用这种方法。

很少写博客,主要是记录一下问题以后 再出现了好应对。当然如果能够帮助正在修复bug中的你,也是乐意至极。那块说的有问题或者解释不清楚,可以留言。

补充知识:postgreSQL sql使用 %s时务必加引号,即为‘%s',否则报错

postgre sql使用 %s时务必加引号,即为‘%s',否则报错

if name == ‘main':

t="TDD-LTE_MRO"
sql="select * from lastftp where enbid = %d and keytype = %s"%(110001,t)

print(selectOperate(sql))

结果:

Traceback (most recent call last):
File “/home/eyann/mypython/t1/pgSQLoperate.py”, line 84, in
print(selectOperate(sql))
File “/home/eyann/mypython/t1/pgSQLoperate.py”, line 45, in selectOperate
cursor.execute(sql)
psycopg2.ProgrammingError: column “tdd” does not exist
LINE 1: …* from lastftp where enbid = 110001 and keytype = TDD-LTE_MR…
^

if name == ‘main':

t="TDD-LTE_MRO"
sql="select * from lastftp where enbid = %d and keytype = '%s'"%(110001,t)

print(selectOperate(sql))

结果:

[(‘test3', ‘TDD-LTE_MRO', ‘0114123000', ‘0012', 110001)]
[Finished in 0.1s]

以上这篇python实现一次性封装多条sql语句(begin end)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python获取当前公网ip并自动断开宽带连接实例代码
Jan 12 Python
Python DataFrame设置/更改列表字段/元素类型的方法
Jun 09 Python
Python实现的txt文件去重功能示例
Jul 07 Python
Python中staticmethod和classmethod的作用与区别
Oct 11 Python
详解python中的Turtle函数库
Nov 19 Python
Python二进制文件读取并转换为浮点数详解
Jun 25 Python
Python OpenCV视频截取并保存实现代码
Nov 30 Python
tensorflow实现二维平面模拟三维数据教程
Feb 11 Python
Python-opencv实现红绿两色识别操作
Jun 04 Python
Python爬虫教程知识点总结
Oct 19 Python
分享unittest单元测试框架中几种常用的用例加载方法
Dec 02 Python
利用Python网络爬虫爬取各大音乐评论的代码
Apr 13 Python
python 在sql语句中使用%s,%d,%f说明
Jun 06 #Python
解决python 执行sql语句时所传参数含有单引号的问题
Jun 06 #Python
pyMySQL SQL语句传参问题,单个参数或多个参数说明
Jun 06 #Python
python 解决mysql where in 对列表(list,,array)问题
Jun 06 #Python
在python中使用pyspark读写Hive数据操作
Jun 06 #Python
使用Python构造hive insert语句说明
Jun 06 #Python
Python通过kerberos安全认证操作kafka方式
Jun 06 #Python
You might like
php 分页类 扩展代码
2009/06/11 PHP
php DOS攻击实现代码(附如何防范)
2012/05/29 PHP
php创建和删除目录函数介绍和递归删除目录函数分享
2014/11/18 PHP
thinkphp文件引用与分支结构用法实例
2014/11/26 PHP
php实现过滤字符串中的中文和数字实例
2015/07/29 PHP
PHP编写RESTful接口
2016/02/23 PHP
Zend Framework教程之请求对象的封装Zend_Controller_Request实例详解
2016/03/07 PHP
javascript 嵌套的函数(作用域链)
2010/03/15 Javascript
javascript模拟订火车票和退票示例
2014/04/24 Javascript
js简单抽奖代码
2015/01/16 Javascript
浅谈Javascript的静态属性和原型属性
2015/05/07 Javascript
js+html5实现canvas绘制网页时钟的方法
2016/05/21 Javascript
浅析JavaScript中的array数组类型系统
2016/07/18 Javascript
js完整倒计时代码分享
2016/09/18 Javascript
jquery.multiselect多选下拉框实现代码
2016/11/11 Javascript
JS中的三个循环小结
2017/06/20 Javascript
动手写一个angular版本的Message组件的方法
2017/12/16 Javascript
详解Angular5 服务端渲染实战
2018/01/04 Javascript
node结合swig渲染摸板的方法
2018/04/11 Javascript
js中时间格式化的几种方法
2018/07/22 Javascript
基于JavaScript实现简单扫雷游戏
2021/01/02 Javascript
python 实现图片修复(可用于去水印)
2020/11/19 Python
HTML5中外部浏览器唤起微信分享
2020/01/02 HTML / CSS
HTML5中的网络存储实现方式
2020/04/28 HTML / CSS
广告学专业推荐信范文
2013/11/23 职场文书
最新奶茶店创业计划书
2014/01/25 职场文书
旅游管理专业大学生职业规划书
2014/02/27 职场文书
服装采购员岗位职责
2014/03/15 职场文书
出生证明公证书
2014/04/09 职场文书
2014工程部年度工作总结
2014/12/17 职场文书
办公室岗位职责
2015/02/04 职场文书
怎样写辞职信
2015/02/27 职场文书
基层党支部承诺书
2015/04/30 职场文书
初二物理教学反思
2016/02/19 职场文书
python实现学生信息管理系统(面向对象)
2022/06/05 Python
win10蓝屏0xc0000001安全模式进不了怎么办?win10出现0xc0000001的解决方法
2022/08/05 数码科技