python和mysql(二)

pandas与mysql

利用pymysql包能根据要求逐条或批量取出数据库中的数据。
若遇到将数据表全部导出成为一个DataFrame 或将整个DataFrame直接存储的情况,我们可以考虑用[sqlalchemy 包](http://www.sqlalchemy.org/)。

Pandas.dataframe直接存储Mysql数据库:

#建立连接
import pandas as pd
from sqlalchemy import create_engine
conn = create_engine('mysql+pymysql://root:Zs1tss11!@localhost:3306/guangzhouIC?charset=utf8')

create_engine()用来初始化数据库连接,用一个字符串连接数据库:

'数据库类型+数据库驱动名称://用户名:口令@机器地址:端口号/数据库名'

存储数据至数据库:

pd.io.sql.to_sql(df, table, conn, schema='guangzhouIC', if_exists='append', index=False)
df是需要存储的DataFrame
table 表示对应mysql 的表
scheme 表示对应mysql中的数据库名称
if_exists 有三个options:
fail ---- 如果表存在,什么也不执行
replace----如果表存在,则删除原表,再建立一个新表,将数据插入。
append----如果表存在,将数据在表后继续插入,如果表不存则创建一个新表插入数据。

从mysql中取出数据为DataFrame:

frame = pd.read_sql(sql, conn, index_col="IC_up_id")

sql :sql语句。
index_col:表示从数据库中导出的列作为DataFrame 的index。

mysql or 相当慢,多条件查询,请使用union。可以参考:
http://www.cnblogs.com/xh831213/archive/2012/05/09/2491272.html

mysql时间日期的处理

MySQL 日期、时间转换函数:date_format(date,format), time_format(time,format) 能够把一个日期/时间转换成各种各样的字符串格式。它是 str_to_date(str,format) 函数的 一个逆转换。
这里写图片描述
这里写图片描述

这里写代码片

mysql中datetime类型的怎么根据条件查询?

SELECT * from xxx_table WHERE DATE_FORMAT(date_col,'%Y-%m-%d') = DATE_FORMAT(NOW(),'%Y-%m-%d')

错误信息:

ValueError: unsupported format character ‘Y’ (0x59) at index 70

产生原因:
因为python执行的sql中存在类似DATE_FORMAT(MAX(CREATE_TIME), ‘%Y-%m-%d’) 的写法, 其中%Ypython的参数%s冲突

解决方法:将DATE_FORMAT(MAX(CREATE_TIME), ‘%Y-%m-%d’) 修改为DATE_FORMAT(MAX(CREATE_TIME), ‘%%Y-%%m-%%d’) 即可

sql = "select * from "+ sqlTable_ + " where date between date_format(\'"+ date_[0]+ "\',\'%%Y-%%m-%%d\') and date_format(\'" + date_[1] + "\',\'%%Y-%%m-%%d\')"
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

半九拾

援助一个bug吧

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值