SQLite parameter substitution and quotes

前端 未结 6 1025
爱一瞬间的悲伤
爱一瞬间的悲伤 2020-11-28 14:41

I have this line that works OK:

c.execute(\'select cleanseq from cleanseqs WHERE newID=\"%s\"\'%name)

But I want to use SQLite parameter su

相关标签:
6条回答
  • 2020-11-28 15:10

    The library will handle quoting and escaping for you. Simply write your query like this:

    c.execute('SELECT cleanseq FROM cleanseqs WHERE newID=?', (name,))
    
    0 讨论(0)
  • 2020-11-28 15:11

    about """If I delete the quotes sourronding the ?, it works. But I want the quotes to remain there since I remember that there are cases where I need them."""

    What you remember from when you were building the whole SQL statement yourself is irrelevant.

    The new story is: mark with a ? each place in the SQL statement where you want a value substituted then pass in a tuple containing one value per ? -- it's that simple; the wrapper will quote any strings to make sure that they are acceptable SQL constants.

    0 讨论(0)
  • 2020-11-28 15:11

    Regular User

    just noticed that you'll have to do this manual by using the unsecure method of sql_string = "other sql surger here.. fieldname=\""+value+"\";"

    its the only way you'll get it to parse correctly. using SQLite for win ce. and well left me with no other alternative, just escape your values before putting them in else you'll most likely end up with a very sad database from sql injections :'( lol

    0 讨论(0)
  • 2020-11-28 15:13

    I find the named-parameter binding style much more readable -- and sqlite3 supports it:

    c.execute('SELECT cleanseq FROM cleanseqs WHERE newID=:t', locals())
    

    Note: passing {'t': t} or dict(t=t) instead of locals() would be more punctiliously correct, but in my opinion it would interfere with readability when there are several parameters and/or longer names. In any case, I do find the :t better than the ?;-).

    0 讨论(0)
  • 2020-11-28 15:20

    Lose the quotes around ?

    c.execute('select cleanseq from cleanseqs WHERE newID=?',(t,))
    

    It's treating it as the string "?".

    Do you need to use double quotes around the whole expression, instead of singles?

    0 讨论(0)
  • 2020-11-28 15:28

    To anyone who like me found this thread and got really frustrated by people ignoring the fact that sometimes you can't just ignore the quotes (because you're using say a LIKE command) you can fix this by doing something to the effect of:

    var = name + "%"
    c.execute('SELECT foo FROM bar WHERE name LIKE ?',(var,))
    

    This will allow you to substitute in wildcards in this situation.

    0 讨论(0)
提交回复
热议问题