V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
The Go Programming Language
http://golang.org/
Go Playground
Go Projects
Revel Web Framework
suueyoung
V2EX  ›  Go 编程语言

请问, 在 Golang 里面如何实现以下的 SQL?

  •  
  •   suueyoung · 2022-04-22 15:48:41 +08:00 · 2078 次点击
    这是一个创建于 987 天前的主题,其中的信息可能已经有所发展或是发生改变。
    SET SESSION block_encryption_mode = 'aes-256-ecb';
    
    SELECT filed
    FROM schema.table
    WHERE encrypted_field in (
        SELECT HEX(AES_ENCRYPT('123', 'secret'))
    );
    

    只知道一步一步地执行, 但是遇上这样的, 就不知道怎么办了.

    pluvet
        1
    pluvet  
       2022-04-22 16:04:22 +08:00
    Golang 不支持 SQL 语法
    codefever
        2
    codefever  
       2022-04-22 16:39:40 +08:00
    在用 Golang 进行开发的时候,如果需要在和数据库交互,则可以使用 database/sql 包。这是一个对关系型数据库的通用抽象,它提供了标准的、轻量的、面向行的接口。
    morty0
        3
    morty0  
       2022-04-22 16:58:51 +08:00
    Prepare 应该就可以吧
    PeterYang1996
        4
    PeterYang1996  
       2022-04-22 17:02:01 +08:00
    为什么一定要用 sql 实现呢
    seakingii
        5
    seakingii  
       2022-04-22 17:04:24 +08:00
    复杂的 SQL 可以做成存储过程供 GO 调用.
    MoYi123
        6
    MoYi123  
       2022-04-22 17:24:36 +08:00
    放事务里,分 2 句跑.
    lasuar
        7
    lasuar  
       2022-04-22 17:27:21 +08:00
    db.InTransaction( your_logic() )
    lesismal
        8
    lesismal  
       2022-04-22 23:08:03 +08:00   ❤️ 1
    注意注释地方:

    ```golang
    package main

    import (
    "database/sql"
    "log"

    _ "github.com/go-sql-driver/mysql"
    )

    func main() {
    // 默认不支持 multi statements ,要设置 multiStatements=true ,否则无法在一个 Exec/Query 里执行多条语句
    db, err := sql.Open("mysql", "root:123qwe@tcp(127.0.0.1:3306)/?charset=utf8mb4&multiStatements=true")
    if err != nil {
    log.Fatal(err)
    }

    result, err := db.Query(`
    SET SESSION block_encryption_mode = 'aes-256-ecb';

    SELECT filed
    FROM schema.table
    WHERE encrypted_field in (
    SELECT HEX(AES_ENCRYPT('123', 'secret'))
    );
    `)
    if err != nil {
    log.Fatal(err)
    }

    defer result.Close()
    for result.Next() {
    var filed string
    err = result.Scan(&filed)
    if err != nil {
    log.Fatal(err)
    }
    log.Println("filed:", filed)
    }
    }
    ```
    suueyoung
        9
    suueyoung  
    OP
       2022-04-23 10:03:43 +08:00
    太感谢了!
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2875 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 22ms · UTC 02:30 · PVG 10:30 · LAX 18:30 · JFK 21:30
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.