douhengdao4499 2018-03-28 22:24
浏览 1993
已采纳

如何在Golang中使用命令执行SQL文件

everyone, I have some troubles with postgresql in golang. I have an sql file (database.sql), and before starting my server I want to exec some command, it look's like that

CREATE TABLE forums (
  id BIGSERIAL primary key,
  slug TEXT NOT NULL UNIQUE,
  title TEXT,
  author TEXT references users(login),
  threads BIGINT DEFAULT 0,
  posts BIGINT DEFAULT 0
);

I know, that I should use db.Exec(request), but i have many requests ("CREATE TABLE user" and others...)

I have no idea, how to do that

Help, and thanks a lot!

  • 写回答

1条回答 默认 最新

  • doushuangdui5419 2018-03-29 07:34
    关注

    You can read the file's contents into a string and pass that to Exec.

    query, err := ioutil.ReadFile("path/to/database.sql")
    if err != nil {
        panic(err)
    }
    if _, err := db.Exec(query); err != nil {
        panic(err)
    }
    

    If your database.sql is formated in such a way, or it contains queries that break db.Exec, then you could use os/exec together with psql (if it's installed on the machine on which the code is being run).

    cmd := exec.Command("psql", "-d", "database_name", "-f", "path/to/database.sql")
    stderr, err := cmd.StderrPipe()
    if err != nil {
        panic(err)
    }
    
    if err := cmd.Start(); err != nil {
        panic(err)
    }
    
    errout, _ := ioutil.ReadAll(stderr)
    if err := cmd.Wait(); err != nil {
        fmt.Println(errout)
        panic(err)
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥20 docker里部署springboot项目,访问不到扬声器
  • ¥15 netty整合springboot之后自动重连失效
  • ¥15 悬赏!微信开发者工具报错,求帮改
  • ¥20 wireshark抓不到vlan
  • ¥20 关于#stm32#的问题:需要指导自动酸碱滴定仪的原理图程序代码及仿真
  • ¥20 设计一款异域新娘的视频相亲软件需要哪些技术支持
  • ¥15 stata安慰剂检验作图但是真实值不出现在图上
  • ¥15 c程序不知道为什么得不到结果
  • ¥40 复杂的限制性的商函数处理
  • ¥15 程序不包含适用于入口点的静态Main方法