Reputation: 191
I am trying to retrieve data from sql through python with the code:
query = ("SELECT stuff FROM TABLE WHERE name like %%(this_name)s%")
result = pd.read_sql(query,con=cnx,params={'this_name':some_name})
The code above works perfectly when I don't have to pass the wildcard operator %. However, in this case the code doesn't work. How can I pass in the query the wildcard operator? Thank you.
Upvotes: 2
Views: 8338
Reputation: 66
Try using a docstring and some quotes around the like pattern. It appears you are using the pyformat paramstyle.
query = """SELECT stuff FROM TABLE WHERE name LIKE '%%(this_name)s%'"""
results = pd.read_sql(query, con=cnx, params={'this_name': some_name})
Upvotes: 0
Reputation: 107652
Consider concatenating the wildcard operator, %
, to passed in value:
query = ("SELECT stuff FROM TABLE WHERE name LIKE %(this_name)s")
result = pd.read_sql(query,con=cnx, params={'this_name': '%'+ some_name +'%'})
Upvotes: 3