Golang连接Redis基本操作

目录

下载redis

下载相关redis包启用命令:go get github.com/gomodule/redigo/redis

获取到:
Golang连接Redis基本操作
引入:
Golang连接Redis基本操作
Golang连接Redis基本操作

案例

案例一

通过go,向redis写入数据string[key-val]

package main

import (
	"fmt"
	"github.com/gomodule/redigo/redis"	//引入redis
)

func main() {
	
	//通过go向redis写入数据和读取数据
	//1.连接到redis
	conn, err := redis.Dial("tcp", "localhost:6379")
	if err != nil {
		fmt.Println("redis.Dial err=", err)
		return
	}
	fmt.Println("conn succ...", conn)
	defer conn.Close()	//关闭...
	//2.通过go,向redis写入数据string[key-val]
	_, err = conn.Do("Set", "name", "tomjerry")
	if err != nil {
		fmt.Println("set err=", err)
		return
	}
	r, err := redis.String(conn.Do("Get", "name"))
	if err != nil {
		fmt.Println("set err=", err)
		return
	}//因为返回的r是Interface{}
	//因为name对应的值是string,因此我们需要转换
	fmt.Println("操作ok ",r)
}

案例二

通过go,向redis写入数据hash[key-val]

package main

import (
	"fmt"
	"github.com/gomodule/redigo/redis"	//引入redis
)

func main() {
	
	//通过go向redis写入数据和读取数据
	//1.连接到redis
	conn, err := redis.Dial("tcp", "localhost:6379")
	if err != nil {
		fmt.Println("redis.Dial err=", err)
		return
	}
	// fmt.Println("conn succ...", conn)
	defer conn.Close()	//关闭...
	//2.通过go,向redis写入数据hash[key-val]
	_, err = conn.Do("HSet", "user01", "name", "john")
	if err != nil {
		fmt.Println("hset err=", err)
		return
	}
	_, err = conn.Do("HSet", "user01", "age", 18)
	if err != nil {
		fmt.Println("hset err=", err)
		return
	}
	//2.通过go,向redis读入数据hash[key-val]
	r1, err := redis.String(conn.Do("HGet", "user01", "name"))
	if err != nil {
		fmt.Println("hgetr1 err=", err)
		return
	}
	r2, err := redis.Int(conn.Do("HGet", "user01", "age"))
	if err != nil {
		fmt.Println("hgetr2 err=", err)
		return
	}//因为返回的r是Interface{}
	//因为name对应的值是string,因此我们需要转换
	fmt.Printf("操作ok r1=%v ,r2=%v", r1, r2)
}

小练习

  1. Monster信息[name, age, skill]
  2. 通过终端输入三个monster的信息,使用golang操作redis,存放到redis中[用hash数据类型]
  3. 遍历出所有的Monster信息,并显示在终端
  4. 保存monster可以使用hash数据类型,遍历时先取出所有的keys,比如keys monster*
package main

import (
	"fmt"
	"github.com/gomodule/redigo/redis"	//引入redis
)

type Monster struct {
	Name string
	Age int	
	Skill string
}

func monsterProcess(name string, age int, skill string) {
	
	//连接本地redis
	conn, err := redis.Dial("tcp", "localhost:6379")
	if err != nil {
		fmt.Println("redis.Dial err=", err)
		return
	}
	defer conn.Close()	//关闭...
	_, err = conn.Do("HmSet", "monster", "name", name,
				"age", age, "skill", skill)		//写入redis
	if err != nil {
		fmt.Println("hset err=", err)
		return
	}
	r, err := redis.Strings(conn.Do("HMGet", "monster", 
				"name", "age", "skill"))
	for i, v := range r {
		fmt.Printf("r[%d]=%v\n",i,v)
	}
}

func main() {
	var monster Monster
	fmt.Println("请输入姓名:")
	fmt.Scanln(&monster.Name)
	fmt.Println("请输入年龄:")
	fmt.Scanln(&monster.Age)
	fmt.Println("请输入技能:")
	fmt.Scanln(&monster.Skill)
	monsterProcess(monster.Name ,monster.Age, monster.Skill)
}
上一篇:Linux-组管理


下一篇:C++设计模式——原型(Prototype)模式