Detailed explanation of the use of custom parameters in MySQL

Detailed explanation of the use of custom parameters in MySQL

MySQL variables include system variables and system variables. The learning task this time is user-defined variables. User variables mainly include local variables and session variables.

The declaration method of user-defined variables is as follows: @var_name, where the variable name consists of letters, numbers, ".", "_", and "$". Of course, you can include other characters when referring to a string or identifier (for example: @'my-var', @"my-var", or @my-var).

User-defined variables are session-level variables. The scope of its variables is limited to the client link in which it is declared. When the client disconnects, all its session variables will be released.

User-defined variables are not case-sensitive.

Use the SET statement to declare user-defined variables:

SET @my_var = 1; 
SET @my_var := 1;

When not using set, use := assignment because using = may be considered as a comparison operator.

The following is an example:

Write a SQL query to implement score ranking. If two scores are the same, then the two score ranks should be the same. Note that the next rank number after a tie should be the next consecutive integer value. In other words, there should be no "holes" between the rows and columns.

+—-+——-+
| Id | Score |
+—-+——-+
| 1 | 3.50 |
| 2 | 3.65 |
| 3 | 4.00 |
| 4 | 3.85 |
| 5 | 4.00 |
| 6 | 3.65 |
+—-+——-+

For example, given the Scores table above, your query should produce the following report (sorted by highest score):

+——-+——+
| Score | Rank |
+——-+——+
| 4.00 | 1 |
| 4.00 | 1 |
| 3.85 | 2 |
| 3.65 | 3 |
| 3.65 | 3 |
| 3.50 | 4 |
+——-+——+

Query statement:

select Score, @rank := @rank + (@pre <> (@pre:=Score)) Rank 
from Scores ,(SELECT @rank := 0,@pre := -1) INIT 
ORDER BY Score DESC

Note:

@rank indicates the ranking of grades

@pre indicates the score of the previous person

When the score is different from the previous one, @rank = @rank + 1, otherwise, @rank = rank.

Initialize @rank to 1 and @pre to -1.

The experimental results are:

The above detailed explanation of the use of custom parameters in MySQL is all the content that the editor shares with you. I hope it can give you a reference. I also hope that you will support 123WORDPRESS.COM.

You may also be interested in:
  • Detailed explanation of the definition and usage of MySQL stored functions (custom functions)
  • Detailed explanation of the entry-level use of MySql stored procedure parameters
  • Detailed explanation of MYSQL configuration parameter optimization

<<:  Vue.js implements timeline function

>>:  Analysis of Linux boot system methods

Recommend

Detailed explanation of three commonly used web effects in JavaScript

Table of contents 1 element offset series 1.1 Off...

Summary of various methods of MySQL data recovery

Table of contents 1. Introduction 2. Direct recov...

You Probably Don’t Need to Use Switch Statements in JavaScript

Table of contents No switch, no complex code bloc...

How to implement web page compression in Nginx optimization service

Configure web page compression to save resources ...

Guide to using env in vue cli

Table of contents Preface Introduction-Official E...

Install Windows Server 2019 on VMware Workstation (Graphic Tutorial)

If prompted to enter a key, select [I don’t have ...

Centos7.5 configuration java environment installation tomcat explanation

Tomcat is a web server software based on Java lan...

MySQL query_cache_type parameter and usage details

The purpose of setting up MySQL query cache is: C...

Docker configuration Alibaba Cloud image acceleration pull implementation

Today I used docker to pull the image, but the sp...

MySQL 5.7.15 installation and configuration method graphic tutorial (windows)

Because I need to install MySQL, I record the ins...

Layui implements sample code for multi-condition query

I recently made a file system and found that ther...

Detailed explanation of how to restore database data through MySQL binary log

Website administrators often accidentally delete ...

Vue3.x uses mitt.js for component communication

Table of contents Quick Start How to use Core Pri...

uniapp realizes the recording upload function

Table of contents uni-app Introduction HTML part ...