操作mysql
增
package main
import (
"fmt"
"github.com/jmoiron/sqlx"
_ "github.com/go-sql-driver/mysql" //初始化一个mysql驱动,必须
)
type Person struct {
UserId int `db:"user_id"`
Username string `db:"username"`
Sex string `db:"sex"`
Email string `db:"email"`
}
type Place struct {
Country string `db:"country"`
City string `db:"city"`
TelCode int `db:"telcode"`
}
var Db *sqlx.DB
func init() {
//"mysql"指定数据库类型, /test指定数据库 root:123 冒号隔开密码 root账号 123密码
database, err := sqlx.Open("mysql", "root:930808@tcp(127.0.0.1:3306)/go_test")
if err != nil {
fmt.Println("open mysql failed,", err)
return
}
fmt.Println("连接数据库成功!")
Db = database
}
func main() {
//插入数据入表
r, err := Db.Exec("insert into person(username,sex,email)values(?,?,?)", "dave", "man", "dave@outlook.com")
if err != nil {
fmt.Println("exec failed,", err)
return
}
id, err := r.LastInsertId()
if err != nil {
fmt.Println("exec failed,", err)
return
}
fmt.Println("insert succ:", id)
}
删
package main
import (
"fmt"
_ "github.com/go-sql-driver/mysql"
"github.com/jmoiron/sqlx"
)
type Person struct {
UserId int `db:"user_id"`
Username string `db:"username"`
Sex string `db:"sex"`
Email string `db:"email"`
}
type Place struct {
Country string `db:"country"`
City string `db:"city"`
TelCode int `db:"telcode"`
}
var Db *sqlx.DB
func init() {
//初始化链接数据库
database, err := sqlx.Open("mysql", "root:930808@tcp(127.0.0.1:3306)/go_test")
if err != nil {
fmt.Println("open mysql failed,", err)
return
}
Db = database
}
func main() {
_, err := Db.Exec("delete FROM person where username=?", "dave")
if err != nil {
fmt.Println("exec failed,", err)
return
}
fmt.Println("delete succ")
}
改
package main
import (
"fmt"
_ "github.com/go-sql-driver/mysql"
"github.com/jmoiron/sqlx"
)
type Person struct {
UserId int `db:"user_id"`
Username string `db:"username"`
Sex string `db:"sex"`
Email string `db:"email"`
}
type Place struct {
Country string `db:"country"`
City string `db:"city"`
TelCode int `db:"telcode"`
}
var Db *sqlx.DB
func init() {
database, err := sqlx.Open("mysql", "root:930808@tcp(127.0.0.1:3306)/go_test")
if err != nil {
fmt.Println("open mysql failed,", err)
return
}
Db = database
}
func main() {
_, err := Db.Exec("update person set sex=? where username=?", "women", "dave")
if err != nil {
fmt.Println("exec failed,", err)
}
}
查
package main
import (
"fmt"
_ "github.com/go-sql-driver/mysql"
"github.com/jmoiron/sqlx"
)
type Person struct {
UserId int `db:"user_id"'`
Username string `db:"username"`
Sex string `db:"sex"`
Email string `db:"email"`
}
type Place struct {
Country string `db:"country"`
City string `db:"city"`
TelCode int `db:"telcode"`
}
var Db *sqlx.DB
func init() {
//初始化链接数据库
database, err := sqlx.Open("mysql", "root:930808@tcp(127.0.0.1:3306)/go_test")
if err != nil {
fmt.Println("open mysql failed", err)
return
}
Db = database
}
func main() {
var person []Person
err := Db.Select(&person, "select username,sex,email from person where username=?", "dave")
if err != nil {
fmt.Println("exec failed,", err)
return
}
fmt.Println("select succ:", person)
}
mysql事务
Db.Begin()
开始事务Db.Submit()
提交事务Db.Rollback()
回滚事务
示例:
package main
import (
"fmt"
_ "github.com/go-sql-driver/mysql" //初始化一个mysql驱动,必须
"github.com/jmoiron/sqlx"
)
type Person struct {
UserId int `db:"user_id"`
Username string `db:"username"`
Sex string `db:"sex"`
Email string `db:"email"`
}
type Place struct {
Country string `db:"country"`
City string `db:"city"`
TelCode int `db:"telcode"`
}
var Db *sqlx.DB
func init() {
//"mysql"指定数据库类型, /test指定打开的数据库 root:123 冒号隔开密码 root账号 123密码
database, err := sqlx.Open("mysql", "root:930808@tcp(127.0.0.1:3306)/go_test")
if err != nil {
fmt.Println("open mysql failed,", err)
return
}
Db = database
}
func main() {
//事务操作
conn, err := Db.Begin()
if err != nil {
return
}
//插入数据入表
r, err := Db.Exec("insert into person(username,sex,email)values(?,?,?)", "lee", "man", "lee@outlook.com")
if err != nil {
fmt.Println("exec failed,", err)
return
}
id, err := r.LastInsertId()
if err != nil {
fmt.Println("exec failed,", err)
//回滚
conn.Rollback()
return
}
fmt.Println("insert succ:", id)
//提交事务
conn.Commit()
}
操作Redis
安装导入
go get github.com/garyburd/redigo