The difference between ${param} and #{param} in MySQL

The difference between ${param} and #{param} in MySQL

The parameter passed by ${param} will be treated as part of the SQL statement, such as passing the table name and field name

Example: (the value passed is id)

order by ${param}

The parsed SQL is:

order by id

#{parm} The data passed in is treated as a string, and double quotes are added to the automatically passed in data

Example: (the value passed is id)

select * from table where name = #{param}

The parsed SQL is:

select * from table where name = "id"

For security reasons, use # to pass parameters wherever possible, which can effectively prevent SQL injection attacks.

Introduction to SQL injection

I went directly to Baidu's example and it felt clear at a glance.

The SQL query code for login verification of a certain website is:

strSQL = "SELECT * FROM users WHERE (name = '" + userName + "') and (pw = '"+ passWord + "');"

Malicious entry
When userName = "1' OR '1'='1";與passWord = "1' OR '1'='1"; the original SQL string will be filled in as
strSQL = "SELECT * FROM users WHERE (name = '1' OR '1'='1') and (pw = '1' OR '1'='1'); "
That is, the SQL command actually executed will become the following strSQL = "SELECT * FROM users; "

This cleverly bypasses the verification during background account authentication, allowing users to log in to the website without an account or password. Therefore, SQL injection attacks are commonly known as hackers' fill-in-the-blank game.

This is the end of this article about the difference between ${param} and #{param} in MySQL. For more information about the difference between ${param} and #{param} in MySQL, please search for previous articles on 123WORDPRESS.COM or continue to browse the following related articles. I hope you will support 123WORDPRESS.COM in the future!

You may also be interested in:
  • The difference between ## and $$ in dynamic SQL under Mybatis
  • A brief discussion on the difference between # and $ in mybatis and how to prevent sql injection

<<:  Solve the problem of black screen when starting VMware virtual machine

>>:  An article to help you thoroughly understand position calculation in js

Recommend

22 Vue optimization tips (project practical)

Table of contents Code Optimization Using key in ...

CSS Transition expands and collapses elements by changing the Height

A common development need is that we want to coll...

Writing a web calculator using javascript

This article mainly records the effect of using j...

Detailed explanation of the order of JS object traversal

Some of you may have heard that the order of trav...

How to delete a property of an object in JavaScript

1. delete delete is the only real way to remove a...

Solution to the ineffective margin of div nested in HTML

Here's a solution to the problem where margin...

Detailed explanation of the basic usage of SSH's ssh-keygen command

SSH public key authentication is one of the SSH a...

Detailed explanation of Linux copy and paste in VMware virtual machine

1. Linux under VMware Workstation: 1. Update sour...

vue perfectly realizes el-table column width adaptation

Table of contents background Technical Solution S...

TypeScript enumeration basics and examples

Table of contents Preface What are enums in TypeS...

Font references and transition effects outside the system

Copy code The code is as follows: <span style=...

HTML dynamically loads css styles and js scripts example

1. Dynamically loading scripts As the demand for ...

How to fix the footer at the bottom of the page (multiple methods)

As a front-end Web engineer, you must have encoun...