通过PyMySQL

时间:2016-10-06 21:33:25

标签: python mysql python-3.x pymysql

我在下面提供了三个示例SQL查询。其中每个都可以正常工作,直接从MySQL [db] >环境中的终端执行时返回预期的表输出。

其他这些查询都保存在名为queries.py的python doc中。通过pymysql传递给db时,后两个查询工作正常,但第一个返回一个空数组。

我已经检出了this postthis postthis post,但似乎没有人解决这个问题。

以下是我用于在Python中测试的示例代码(版本3.5):

import pymysql
import params 
import queries 

conn = pymysql.connect(
  host = params.HOST,
  user = params.USER,
  password = params.PWD,
  db = 'db',
  charset='utf8',
  cursorclass=pymysql.cursors.DictCursor,
  autocommit = True)

test_queries = [queries.VETTED, queries.CREATED, queries.CLOSED_OPPS]
with conn.cursor() as cursor:
    for query in test_queries: 
        cursor.execute(query)
        print(cursor.fetchall())

() #..blank output -- doesn't make sense because corresponding query works in MySQL env
[...] #..expected output from query 2
[...] #..expected output from query 3

这是queries.py的样子。这些查询中的每一个在MySQL中执行时返回预期输出,但第一个查询VETTED在通过pymysql传递给数据库时返回空白数组:

VETTED = """
SELECT
  date_format(oa.logged_at, '%Y-%m-%d')  as `action_date`,
  count(1) `count`
FROM
  crm_audit_field oaf,
  crm_audit oa,
  crm_sales_lead lead
WHERE
  oa.id = oaf.audit_id AND
  oaf.field = 'status' AND
  (
    oaf.new_text = 'Qualified' OR
    oaf.new_text = 'Disqualified' OR
    oaf.new_text = 'Canceled'
  ) AND
  oa.object_class = 'CRM\\Bundle\\SalesBundle\\Entity\\Lead' AND
  lead.id = oa.object_id AND
  (lead.status_id = 'qualified' OR lead.status_id = 'canceled')
GROUP BY
  `action_date`;"""

CREATED = """
SELECT
  DATE_FORMAT(lead.createdat, '%Y-%m-%d') as `creation_date`,
  count(1)
FROM
  crm_sales_lead `lead`
GROUP BY
  creation_date;"""

CLOSED_OPPS = """
SELECT
  date_format(closed_at, '%Y-%m-%d') `close_date`,
  count(1) `count`
FROM
  crm_sales_opportunity
WHERE
  status_id = 'won'
GROUP BY
  `close_date`;"""

1 个答案:

答案 0 :(得分:1)

我认为你需要在Python字符串文字中使用四个反斜杠来表示MySQL所需的两个反斜杠字符,以表示反斜杠字符。

MySQL需要在字符串文字中使用两个反斜杠来表示反斜杠字符。您在MySQL中使用的SQL文本,因为字符串文字包含两个反斜杠字符。

但是在Python代码中,发送给MySQL的SQL语句只包含单个反斜杠字符。

这是因为Python在字符串文字中还需要两个反斜杠来表示反斜杠字符,就像MySQL一样。

所以,在Python ......

  """CRM\\Bundle"""
        ^^

表示仅包含一个反斜杠字符的字符串: 'CRM\Bundle'

获取包含两个反斜杠字符的字符串: 'CRM\\Bundle'

你需要在Python文字中使用四个反斜杠,如下所示:

  """CRM\\\\Bundle"""
        ^^^^