Golang 数据库 “增、删、改、查”

本文介绍使用Go语言通过标准库sql包操作MySQL数据库的方法,包括数据的增加、删除、修改及查询,并实现数据库间的数据迁移。

1、增

func insert() {
	db1, err := sql.Open("mysql", "root:root@tcp(127.0.0.1:3306)/cy?parseTime=true")
	if err != nil{
		fmt.Println(err)
	}
	defer db1.Close()
	stmt, err := db1.Prepare("insert into person(user_id,username,sex,email)value (?,?,?,?)")
	res, err := stmt.Exec("user_id","username","sex","email")
	if err != nil {
		log.Fatal(err)
	}
	lastId, err := res.LastInsertId()
	if err != nil {
		log.Fatal(err)
	}
	fmt.Println(lastId)
}

2、删

func del() {
	db1, err := sql.Open("mysql", "root:root@tcp(127.0.0.1:3306)/cy?parseTime=true")
	if err != nil{
		fmt.Println(err)
	}
	defer db1.Close()
	stmt, err := db1.Prepare("delete from person where user_id=?")
	res, err := stmt.Exec("user_id")
	if err != nil {
		log.Fatal(err)
	}
	num, err := res.RowsAffected()
	if err != nil {
		log.Fatal(err)
	}
	fmt.Println(num)
}

3、改

func update() {
	db1, err := sql.Open("mysql", "root:root@tcp(127.0.0.1:3306)/cy?parseTime=true")
	if err != nil{
		fmt.Println(err)
	}
	defer db1.Close()
	stmt, err := db1.Prepare("update person set username=?,sex=?,email=? where user_id=?")
	res, err := stmt.Exec("username","sex","email","user_id")
	if err != nil {
		log.Fatal(err)
	}
	num, err := res.RowsAffected()
	if err != nil {
		log.Fatal(err)
	}
	fmt.Println(num)
}

4、查

func query()  {
	db, err := sql.Open("mysql", "root:root@tcp(127.0.0.1:3306)/cyball?parseTime=true")
	if err != nil{
		fmt.Println(err)
	}
	defer db.Close()
	//查询数据,取所有字段
	rows2, _ := db.Query("select * from person")
	//返回所有列
	cols, _ := rows2.Columns()
	//这里表示一行所有列的值,用[]byte表示
	vals := make([][]byte, len(cols))
	//这里表示一行填充数据
	scans := make([]interface{}, len(cols))
	//这里scans引用vals,把数据填充到[]byte里
	for k, _ := range vals {
		scans[k] = &vals[k]
	}
	i := 0
	result := make(map[int]map[string]string)
	for rows2.Next() {
		//填充数据
		rows2.Scan(scans...)
		//每行数据
		row := make(map[string]string)
		//把vals中的数据复制到row中
		for k, v := range vals {
			key := cols[k]
			//这里把[]byte数据转成string
			row[key] = string(v)
		}
		//放入结果集
		result[i] = row
		i++
	}
	println(result)
}

5、数据库数据转移(可加逻辑)

func mains() {
	db, err := sql.Open("mysql", "root:root@tcp(127.0.0.1:3306)/cyball?parseTime=true")
	if err != nil{
		fmt.Println(err)
	}
	defer db.Close()
	//查询数据,取所有字段
	rows2, _ := db.Query("select * from person")
	//返回所有列
	cols, _ := rows2.Columns()
	//这里表示一行所有列的值,用[]byte表示
	vals := make([][]byte, len(cols))
	//这里表示一行填充数据
	scans := make([]interface{}, len(cols))
	//这里scans引用vals,把数据填充到[]byte里
	for k, _ := range vals {
		scans[k] = &vals[k]
	}
	i := 0
	result := make(map[int]map[string]string)
	for rows2.Next() {
		//填充数据
		rows2.Scan(scans...)
		//每行数据
		row := make(map[string]string)
		//把vals中的数据复制到row中
		for k, v := range vals {
			key := cols[k]
			//这里把[]byte数据转成string
			row[key] = string(v)
		}
		//放入结果集
		result[i] = row
		i++
	}

	db1, err := sql.Open("mysql", "root:root@tcp(127.0.0.1:3306)/cy?parseTime=true")
	if err != nil{
		fmt.Println(err)
	}
	defer db1.Close()
	for _, value := range result {
		stmt, err := db1.Prepare("insert into person(user_id,username,sex,email)value (?,?,?,?)")
		res, err := stmt.Exec(value["user_id"],value["username"],value["sex"],value["email"])
		if err != nil {
			log.Fatal(err)
		}
		lastId, err := res.LastInsertId()
		if err != nil {
			log.Fatal(err)
		}
		fmt.Println(lastId)
	}
	//fmt.Println(result)
}

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值