How to Resolve Syntax Errors in Go for MySQL Queries Using SET Variables?

Susan Sarandon
Release: 2024-10-24 04:33:30
Original
777 people have browsed it

How to Resolve Syntax Errors in Go for MySQL Queries Using SET Variables?

MySQL Queries with SET Variables in Go

In Go, it's possible to use SET statements before running MySQL queries. However, there are certain syntax requirements that must be met. This article explores an issue encountered when attempting to execute such queries and provides a solution.

The original code snippet involves defining a function that selects records based on a user ID and a sorting parameter. It uses SET statements to assign values to variables before executing the query. However, this approach resulted in a syntax error when run through Go.

The error can be attributed to the way the query is constructed. Specifically, the SET statements need to be encapsulated in parentheses and placed before the SELECT statement. Additionally, the MySQL DSN should include the settings "multiStatements=true" and "interpolateParams=true."

The following updated code snippet resolves the issue:

<code class="go">func (d *DB) SelectByUserId(uid string, srt string, pg, lim int) ([]Inventory, error) {
    query := `
    (SET @user_id := ?, @orderBy := ?;)
    SELECT
        *
    FROM
        inventory
    WHERE
        user_id = @user_id
    ORDER BY
        (CASE WHEN @orderBy = 'type,asc' THEN type END),
        (CASE WHEN @orderBy = 'type,desc' THEN type END) DESC,
        (CASE WHEN @orderBy = 'visible,asc' THEN visible END),
        (CASE WHEN @orderBy = 'visible,desc' THEN visible END) DESC,
        (CASE WHEN @orderBy = 'create_date,asc' THEN create_date END),
        (CASE WHEN @orderBy = 'create_date,desc' THEN create_date END) DESC,
        (CASE WHEN @orderBy = 'update_date,asc' THEN update_date END),
        (CASE WHEN @orderBy = 'update_date,desc' THEN update_date END) DESC
    LIMIT ?,?;
    `

    dsn := d.dsn + "?multiStatements=true&interpolateParams=true"
    db, err := sql.Open("mysql", dsn)
    if err != nil {
        return nil, err
    }
    defer db.Close()

    rows, err := db.Query(
        query,
        uid,
        srt,
        pg*lim,
        lim,
    )

    if err != nil {
        return nil, err
    }
    defer rows.Close()

    result := make([]Inventory, 0)
    for rows.Next() {
        var inv Inventory
        if err := rows.Scan(
            &inv.Id,
            &inv.UserId,
            &inv.Type,
            &inv.Name,
            &inv.Description,
            &inv.Visible,
            &inv.CreateDate,
            &inv.UpdateDate); err != nil {
            return result, err
        }
        result = append(result, inv)
    }
    if err = rows.Err(); err != nil {
        return result, err
    }

    return result, nil
}</code>
Copy after login

By enclosing the SET statements in parentheses and enabling multi-statements and parameter interpolation in the DSN, the query successfully executes in Go without any syntax errors. Additionally, converting the database and tables to utf8mb4_general_ci collation resolves any potential issues related to character set compatibility.

The above is the detailed content of How to Resolve Syntax Errors in Go for MySQL Queries Using SET Variables?. For more information, please follow other related articles on the PHP Chinese website!

source:php
Statement of this Website
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
Latest Articles by Author
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template
About us Disclaimer Sitemap
php.cn:Public welfare online PHP training,Help PHP learners grow quickly!