python学习 第七篇 sql优化

简介:

查询单条语句:用来获取用户列表和单个用户

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
>>> fields = [ "id" , "name" , "name_cn" , "email" , "mobile" ]                
>>> sql = "select %s from users where name ='admin'"  %  ',' .join(fields)
>>> sql
"select id,name,name_cn,email,mobile from users where name ='admin'"
>>> cur.execute(sql)
1L
>>> res = cur.fetchone()
>>> res
( 16L , u 'admin' , u 'admin' , u '134556' , u '123455' )
>>> user = {}
>>>  for  i,k  in  enumerate (fields):
...    user[k] = res[i]
... 
>>> user
{ 'mobile' : u '123455' 'email' : u '134556' 'name_cn' : u 'admin' 'id' 16L 'name' : u 'admin' }
>>>  for  i,k  in  enumerate (fields):
...      print  i,k   i 是索引值,k是fields 里面的值
... 
0  id
1  name
2  name_cn
3  email
4  mobile
>>> res[ 1 ]
u 'admin'

插入语句:添加用户

1.0版本

1
2
3
4
5
6
>>> fields = [ "id" , "name" , "name_cn" , "email" , "mobile" , "role"
>>> fields
[ 'id' 'name' 'name_cn' 'email' 'mobile' 'role' ]
>>> sql = "insert into users (%s) values ('fujinzhou','fujinzhou','144@qq.com','136**','ops')"  %  ',' .join(fields)
>>> sql
"insert into users (id,name,name_cn,email,mobile,role) values ('fujinzhou','fujinzhou','144@qq.com','136**','ops')"

2.0版本

1
2
3
4
5
6
7
8
>>> fields = [ "name" , "name_cn" , "email" , "mobile" , "role" ]      
>>> data = { "name" : "fujinzhou" }
>>> data
{ 'name' 'fujinzhou' }
>>> data = { "name" : "fujinzhou" , "name_cn" : "fujinzhou" , "email" : "144@qq.com" , "mobile" : "1122" , "role" : "ops" }
>>> sql = "insert into users (%s) values %s"  % ( ',' .join(fields), ',' .join([ '"%s"'  % data[k]  for  in  fields]))
>>> sql
'insert into users (name,name_cn,email,mobile,role) values "fujinzhou","fujinzhou","144@qq.com","1122","ops"'


3.0版本

1
2
3
4
5
6
7
8
9
10
11
12
13
14
>>> fields = []
>>> values = []
>>> data = { "name" : "fujinzhou" , "name_cn" : "fujinzhou" , "email" : "144@qq.com" , "mobile" : "1122" , "role" : "ops" }  
>>>  for  k,v  in  data.items():
...     fields.append(k)
...     values.append( "'%s'"  %  v)
... 
>>> fields
[ 'mobile' 'role' 'name_cn' 'name' 'email' ]
>>> values
[ "'1122'" "'ops'" "'fujinzhou'" "'fujinzhou'" "'144@qq.com'" ]
>>> sql = "insert into users (%s) values (%s)"  % ( ',' .join(fields), ',' .join(values))
>>> sql
"insert into users (mobile,role,name_cn,name,email) values ('1122','ops','fujinzhou','fujinzhou','144@qq.com')"




本文转自 shouhou2581314 51CTO博客,原文链接:http://blog.51cto.com/thedream/1839868,如需转载请自行联系原作者
相关文章
|
5月前
|
存储 Java 数据处理
(numpy)Python做数据处理必备框架!(一):认识numpy;从概念层面开始学习ndarray数组:形状、数组转置、数值范围、矩阵...
Numpy是什么? numpy是Python中科学计算的基础包。 它是一个Python库,提供多维数组对象、各种派生对象(例如掩码数组和矩阵)以及用于对数组进行快速操作的各种方法,包括数学、逻辑、形状操作、排序、选择、I/0 、离散傅里叶变换、基本线性代数、基本统计运算、随机模拟等等。 Numpy能做什么? numpy的部分功能如下: ndarray,一个具有矢量算术运算和复杂广播能力的快速且节省空间的多维数组 用于对整组数据进行快速运算的标准数学函数(无需编写循环)。 用于读写磁盘数据的工具以及用于操作内存映射文件的工具。 线性代数、随机数生成以及傅里叶变换功能。 用于集成由C、C++
504 1
|
5月前
|
存储 JavaScript Java
(Python基础)新时代语言!一起学习Python吧!(四):dict字典和set类型;切片类型、列表生成式;map和reduce迭代器;filter过滤函数、sorted排序函数;lambda函数
dict字典 Python内置了字典:dict的支持,dict全称dictionary,在其他语言中也称为map,使用键-值(key-value)存储,具有极快的查找速度。 我们可以通过声明JS对象一样的方式声明dict
390 1
|
5月前
|
算法 Java Docker
(Python基础)新时代语言!一起学习Python吧!(三):IF条件判断和match匹配;Python中的循环:for...in、while循环;循环操作关键字;Python函数使用方法
IF 条件判断 使用if语句,对条件进行判断 true则执行代码块缩进语句 false则不执行代码块缩进语句,如果有else 或 elif 则进入相应的规则中执行
905 1
|
7月前
|
机器学习/深度学习 算法 安全
【PSO-LSTM】基于PSO优化LSTM网络的电力负荷预测(Python代码实现)
【PSO-LSTM】基于PSO优化LSTM网络的电力负荷预测(Python代码实现)
375 0
|
7月前
|
调度 Python
微电网两阶段鲁棒优化经济调度方法(Python代码实现)
微电网两阶段鲁棒优化经济调度方法(Python代码实现)
216 0
|
5月前
|
存储 Java 索引
(Python基础)新时代语言!一起学习Python吧!(二):字符编码由来;Python字符串、字符串格式化;list集合和tuple元组区别
字符编码 我们要清楚,计算机最开始的表达都是由二进制而来 我们要想通过二进制来表示我们熟知的字符看看以下的变化 例如: 1 的二进制编码为 0000 0001 我们通过A这个字符,让其在计算机内部存储(现如今,A 字符在地址通常表示为65) 现在拿A举例: 在计算机内部 A字符,它本身表示为 65这个数,在计算机底层会转为二进制码 也意味着A字符在底层表示为 1000001 通过这样的字符表示进行转换,逐步发展为拥有127个字符的编码存储到计算机中,这个编码表也被称为ASCII编码。 但随时代变迁,ASCII编码逐渐暴露短板,全球有上百种语言,光是ASCII编码并不能够满足需求
263 4
|
5月前
|
SQL 存储 监控
SQL日志优化策略:提升数据库日志记录效率
通过以上方法结合起来运行调整方案, 可以显著地提升SQL环境下面向各种搜索引擎服务平台所需要满足标准条件下之数据库登记作业流程综合表现; 同时还能确保系统稳健运行并满越用户体验预期目标.
336 6
|
6月前
|
JavaScript Java 大数据
基于python的网络课程在线学习交流系统
本研究聚焦网络课程在线学习交流系统,从社会、技术、教育三方面探讨其发展背景与意义。系统借助Java、Spring Boot、MySQL、Vue等技术实现,融合云计算、大数据与人工智能,推动教育公平与教学模式创新,具有重要理论价值与实践意义。
|
6月前
|
机器学习/深度学习 资源调度 算法
一种多尺度协同变异的粒子群优化算法(Python代码实现)
一种多尺度协同变异的粒子群优化算法(Python代码实现)
203 2

推荐镜像

更多