Golang连接postgresql示例

该代码示例展示了如何使用Golang的标准库`database/sql`和`github.com/lib/pq`驱动来连接到PostgreSQL数据库,执行查询并写入文件。程序从student表中检索数据,将结果追加到名为impala的文件中,并准备插入新数据的SQL语句。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

golang连接postgresql

package main

import (
   "bufio"
   "database/sql"
   "fmt"
   . "github.com/lib/pq"
   "log"
   "os"
)

func main() {
   //连接postgres
   connStr := "host=localhost port=5432 dbname=postgres user=postgres password=123456 sslmode=disable"
   db, err := sql.Open("postgres", connStr)
   if err != nil {
      log.Fatal(err)
   }
   rows, err := db.Query("select * from student")
   if err != nil {
      log.Fatal(err)
   }
   for rows.Next() {
      var id string
      var name string
      var age string
      err = rows.Scan(&id, &name, &age)
      if err != nil {
         log.Fatal(err)
      }
      //fmt.Print("id:" + id)
      //fmt.Print(" name:" + name)
      //fmt.Println(" age:" + age)
      file, err := os.OpenFile("impala", os.O_WRONLY|os.O_APPEND, 0644)
      defer file.Close()
      writer := bufio.NewWriter(file)
      writer.WriteString("id:" + id)
      writer.WriteString(" name:" + name)
      writer.WriteString(" age:" + age + "\n")
      writer.Flush()
      if err != nil {
         return

      }

      //db.Prepare("INSERT INTO student(id,name,age) VALUES('55','lisa','kook')")
   }
   ms, _ := os.ReadFile("impala")
   stmt, err := db.Prepare("INSERT INTO student(id,name,age) VALUES ($1,$2,$3) ")
   checkErr(err)
   fmt.Print(string(ms))
   stmt.Exec()

}

func checkErr(err error) {
   if err != nil {
      return
   }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值