Home >Backend Development >Python Tutorial >How Can I Safely Use Variables in Python SQL INSERT Statements?

How Can I Safely Use Variables in Python SQL INSERT Statements?

Mary-Kate Olsen
Mary-Kate OlsenOriginal
2025-01-01 03:13:09725browse

How Can I Safely Use Variables in Python SQL INSERT Statements?

Using Variables in SQL Statements in Python

When inserting data into an SQL table, it's essential to utilize parameters to pass variable values safely and effectively. Let's explore how to write variable names in Python code without including them as part of the query text.

Consider the following code:

cursor.execute("INSERT INTO table VALUES var1, var2, var3")

where var1 is an integer and var2 and var3 are strings. How can you avoid Python incorporating these variables into the query string?

Solution:

To achieve this, pass the variables as a tuple to the execute() method:

cursor.execute("INSERT INTO table VALUES (%s, %s, %s)", (var1, var2, var3))

Explanation:

  • The %s placeholders represent the variables that will be substituted into the query.
  • The tuple (var1, var2, var3) provides the actual values for the placeholders.
  • The Python code now looks like a parameter substitution statement instead of string manipulation.

Important Note:

The database API performs proper escaping and quoting of variables. Avoid using string formatting operators (%) for parameter substitution, as they:

  • Do not offer escaping or quoting protection.
  • Make the code vulnerable to SQL injection attacks.

The above is the detailed content of How Can I Safely Use Variables in Python SQL INSERT Statements?. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn