Parameterized Statements
The following code example shows how to bind parameters to create parameterized statements.
Single-Use Statements
The execute method accepts an additional sequence for binding query parameters to values.
cursor.execute("SELECT ObjectID, AccountName FROM AccountCollection WHERE AccountName = ?", ("MyAccount",)) for (ObjectID, AccountName) in cursor: print("ObjectID = {}, AccountName = {}".format(ObjectID, AccountName))
Multi-Use Statements
The executemany method can be used to execute the same query repeatedly with different sets of parameters. Instead of a sequence of parameters, executemany accepts a nested sequence of parameters which are used for each execution.
executemany works only with INSERT, UPDATE and DELETE statements. It cannot be used with any operation that returns results, such as a SELECT or an EXECUTE.
params = [ ("John 1",), ("John 2",), ("John 3",), ] cursor.executemany("INSERT INTO AccountCollection (AccountName) VALUES (?)", params)