【问题标题】:For INSERT, using LIKE statement with a variable对于 INSERT,使用带有变量的 LIKE 语句
【发布时间】:2012-01-23 20:41:25
【问题描述】:

如何使用 LIKE 正确编写以下 INSERT?

provider = provider
cursor.execute("""INSERT INTO raw_financials (provider, vendor_id) 
                  VALUES (%s, %s)""", 
                 ((SELECT provider FROM main_app_provider 
                   WHERE provider LIKE %s%, %provider), vendor_id)

例如,对于上述 LIKE 语句,“Apple”将匹配“Apple Inc.”。

【问题讨论】:

    标签: python mysql sql


    【解决方案1】:

    使用 INSERT 命令的INSERT ... SELECT ... FROM variant

    sql = """
        INSERT INTO raw_financials (provider, vendor_id)
        SELECT provider, %s
        FROM main_app_provider
        WHERE provider LIKE %s
        """ 
    args = (vendor_id, '%'+provider+'%')
    cursor.execute(sql, args)
    

    【讨论】:

      猜你喜欢
      • 2017-11-09
      • 2016-06-12
      • 1970-01-01
      • 2015-04-30
      • 2010-11-05
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多