riccio777
riccio777

Reputation: 191

pandas read_sql with parameters and wildcard operator

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

Answers (2)

Slizzard Wizzard
Slizzard Wizzard

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

Parfait
Parfait

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

Related Questions