【GO】 2.使用github.com/denisenkom/go-mssqldb操作数据库

  • 一.下载安装github.com/denisenkom/go-mssqldb包

安装需要输入命令:

go get github.com/denisenkom/go-mssqldb

正常情况下输入以上命令就已将包下载并安装完毕

然而这个包有一个依赖包cloud.google.com/go/civil,看到google有没有心头一怔。没错,这个地址GFW墙掉了,所以安装等待一段时间后会出现以下提示:

去包路径下看到github.com/denisenkom/go-mssqldb已经下载下来,由于缺少cloud.google.com/go/civil包所以并没有安装成功。

其实cloud.google.com/go/civil包在github上有相关项目,地址:https://github.com/googleapis/google-cloud-go可以找到

到这里只有曲线救国,我们把github上的这个项目下载下来,然后再gopath的src文件夹中创建cloud.google.com/go目录,再将civil文件夹复制过来,重新安装github.com/denisenkom/go-mssqldb

输入命令go install D:\GoPKG\src\github.com\denisenkom\go-mssqldb

这样这个包就安装好了

 

  • 二:一个示例程序

package main

import (
	"database/sql"
	"fmt"
	"log"
        "time"

	_ "github.com/denisenkom/go-mssqldb"
)

type Match struct {
	MatchID          int64
	MatchDescription string
	CreatedTime      time.Time
	UpdatedTime      time.Time
	IsDeleted        bool
}

func main() {
	var match Match
	connString := fmt.Sprintf("server=%s;user id=%s;password=%s;database=%s;encrypt=disable",
		"××", "××", "××", "××")

	conn, err := sql.Open("mssql", connString)
	if err != nil {
		log.Fatal("Open connection failed:", err.Error())
	}
    defer conn.Close()

	stmt, err := conn.Prepare(`select top 1 * from tmatch`)
	if err != nil {
		log.Printf("\nPrepare failed:%T %+v\n", err, err)

	}

	row := stmt.QueryRow()
	err = row.Scan(&match.MatchID, &match.MatchDescription, &match.CreatedTime, &match.UpdatedTime, &match.IsDeleted)
	if err != nil {
		log.Fatal("Scan failed:", err.Error())
	}
	fmt.Println(match)
}

注:time日期格式化 time.Time.Format("2006-01-02 15:04:05")其中2006-01-02 15:04:05是固定写法。(简单记为1-2-3-4-5)

  • 三.主键为自增字段时,不要用LastInsertId()方法获取插入的ID

这个包的LastInsertId()方法对sqlserver支持的不是很好,会报There is no generated identity value的错误

官方github readme文件中已经说明这个包对LastInsertId()不支持

当然,插入一条新纪录获取该记录的ID是很重要的,官方也给出了解决办法,在插入语句后面添加返回ID的语句,但这里不要用Exec()方法,个人推荐用QueryRow()方法来实现,代码如下:

func CreateMatch(match entities.Match, db *sql.DB) (int64, error) {
	tsql := fmt.Sprintf("INSERT INTO tMatch(MatchDescription, CreatedTime, UpdatedTime, IsDeleted) VALUES('%s', '%s', '%s', '%s') select ID = convert(bigint, SCOPE_IDENTITY());",
		match.MatchDescription, match.CreatedTime.Format("2006-01-02 15:04:05"), match.UpdatedTime.Format("2006-01-02 15:04:05"), "false")

	row := db.QueryRow(tsql)
	var MatchId int64
	err := row.Scan(&MatchId)
	if err != nil {
		fmt.Println("Error CreateMatch:" + err.Error())
		return -1, err
	}
	return MatchId, nil
}

 

以上是学习go操作sqlserver数据库过程中遇到的问题

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
golang-lru 是一个 Golang 语言实现的 LRU 缓存库,它提供了一个简单易用的 API 用于创建和使用 LRU 缓存。 下面是一个简单的使用示例: ```go package main import ( "fmt" "github.com/hashicorp/golang-lru" ) func main() { // 创建一个 LRU 缓存,容量为 2 cache, _ := lru.New(2) // 添加两个元素到缓存中 cache.Add("key1", "value1") cache.Add("key2", "value2") // 从缓存中获取一个元素 if v, ok := cache.Get("key1"); ok { fmt.Println(v.(string)) } // 添加一个新元素到缓存中,此时缓存容量已满,会自动淘汰最久未使用的元素 "key2" cache.Add("key3", "value3") // 遍历缓存中的所有元素 for _, k := range cache.Keys() { if v, ok := cache.Get(k); ok { fmt.Println(k, v.(string)) } } } ``` 运行上述代码,将会输出: ``` value1 key1 value1 key3 value3 ``` 在这个示例中,我们首先使用 `lru.New()` 函数创建了一个容量为 2 的 LRU 缓存。然后我们添加了两个元素到缓存中,并从缓存中获取了一个元素。接着我们添加了一个新元素,此时缓存已满,会自动淘汰最久未使用的元素 "key2"。最后我们遍历了缓存中的所有元素,输出了它们的键和值。 除了 `Add()` 和 `Get()` 方法外,golang-lru 还提供了 `Remove()` 和 `Contains()` 方法来删除和判断缓存中是否存在某个元素,以及 `Len()` 和 `Clear()` 方法来获取缓存中元素的数量和清空缓存。 golang-lru 还支持并发安全,你可以通过 `NewWithOptions()` 函数创建一个并发安全的 LRU 缓存,具体用法请参考官方文档:https://pkg.go.dev/github.com/hashicorp/golang-lru。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值