node redis操作

1、redis 菜鸟驿站(先在在这里学习redis的安装、配置和命令行操作)   http://www.runoob.com/redis/redis-tutorial.html

2、再介绍一个redis 图形化工具(个人非常建议) redis desktop Manager   https://www.cnblogs.com/zheting/p/7670154.html

3、node_redis 官方文档                        https://github.com/NodeRedis/node_redis

4、参考网址

     https://www.cnblogs.com/harelion/p/5203710.html

  https://blog.csdn.net/helencoder/article/details/51784654

 
Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set:有序集合)。
概念理解网址  1、https://blog.csdn.net/wang379275614/article/details/47172469
       2、https://blog.csdn.net/tim_phper/article/details/51891097

string  常用命令:  除了get、set、incr、decr mget等操作外,Redis还提供了下面一些操作:获取字符串长度、往字符串append内容、设置和获取字符串的某一段内容、设置及获取字符串的某一位(bit)、批量设置一系列字符串的内容
hash 常用命令: hget,hset,hmset,hmget,hgetall 等。
list 常用命令: lpush,rpush,lpop,rpop,lrange,BLPOP(阻塞版)等。
set 常用命令: sadd,srem,spop,sdiff ,smembers,sunion 等。
zset 常用命令: zadd,zrange,zrem,zcard等

我不懂得解释,直接代码。能用就行
先声明版本
node 8.10.0
npm 5.8.0
redis 2.8.0(node_modules里的版本,不是软件版本)
  1 /*
  2 * 下面有些命令的开头是z 或者h 或者s的
  3 * z表示有序列表的数据类型
  4 * h表示hash的数据类型
  5 * s表示set集合的数据类型
  6 * l表示list列表的数据类型
  7 *
  8 * */
  9 
 10 const redis = require("redis"),
 11     RDS_PORT = 6379,            //服务器端口
 12     RDS_HOST = '127.0.0.1',     //服务器ip
 13     RDS_OPTS = {},              //设置值
 14     db = 1
 15     client = redis.createClient({RDS_PORT, RDS_HOST,RDS_OPTS, db});
 16 
 17 let test = {
 18     set: async () => {
 19         client.set('token', "普通的种下token", function(err, res) {
 20            console.log(err);
 21            console.log(res);
 22         });
 23         client.expire('token', 60*60*24*30);  //  缓存30天 设置失效时间
 24 
 25         /*
 26         * set 也允许设置失效时间
 27         * */
 28         // client.set('token', '普通的种下token', 'EX', 60*60*24*30);  //  缓存30天 设置失效时间
 29     },
 30     get: async () => {
 31         /*
 32         * 得到
 33         * */
 34         client.get('token', function(err, reply) {
 35            if(err) {
 36                console.log("报错了");
 37                console.log(err);
 38                throw err;
 39                // return;
 40            }
 41            if(reply)
 42                 console.log(reply);
 43            else
 44                console.log("没有值");
 45         });
 46 
 47         // let reply = await new Promise(function(resolve, reject) {
 48         //     client.get('token', function(err, reply) {
 49         //         resolve(reply?reply:'');
 50         //     });
 51         // });
 52         // if(reply)
 53         //     console.log(reply);
 54         // else
 55         //     console.log("没有值");
 56     },
 57     remove: async ()=>{
 58         client.del("token",function(err, res) {
 59             console.log(err);
 60             console.log(res);
 61         }); //删除
 62         // await client.del('token'); //删除  支持await
 63     },
 64     /*
 65     * 单个key存储  hash
 66     * */
 67     hset: async ()=> {
 68         client.hset('hset', 'key001', 'hello', function (err, res) {
 69             if (err) {
 70                 console.log(err);
 71             } else {
 72                 console.log('res:', res);
 73             }
 74         });
 75     },
 76     /*
 77     * 单个key获取  hash
 78     * */
 79     hget: async ()=> { //单个key获取  hash
 80         client.hget('hset', 'key001', function (err, getRslt) {
 81             if (err) {
 82                 console.log(err);
 83             } else {
 84                 console.log('getRslt:', getRslt);
 85                 client.quit();
 86             }
 87         });
 88     },
 89     /*
 90     * 多个key存储  hash
 91     * */
 92     hmset: async ()=> {
 93         // client.hmset("hosts", "mjr", "1", "another", "23", "home", "1234");
 94         client.hmset('hmset', {a:2,b:3,c:4}, function(err, response) {
 95             if (err) {
 96                 console.log(err);
 97             } else {
 98                 console.log(response);
 99                 // client.quit();
100             }
101         });
102     },
103     /*
104     * 多个key获取  hash
105     * */
106     hmget: async () => {
107         client.hmget("hosts", "mjr", "another", "home", function(err, res) {
108             if (err) {
109                 console.log(err);
110             } else {
111                 console.log(res);
112             }
113         });
114         client.hmget('hmset', ['a', 'c'], function (err, res) {
115             if (err) {
116                 console.log(err);
117             } else {
118                 console.log(res);
119             }
120         });
121     },
122     /*
123     *
124     * 参考网址 https://blog.csdn.net/qq_28893679/article/details/53005057
125     * 遍历查询所有的key
126     * 可以模糊查询  性能可能损耗,建议独立开一个db
127     * */
128     keys: async () => {
129         client.keys("605*", function (err, replies) {
130             console.log(replies.length + " replies:");
131             replies.forEach(function (reply, i) {
132                 console.log("    " + i + ": " + reply);
133             });
134             client.quit();
135         });
136     },
137     /*
138     * 获取hash数据类型键值为1的所有key值
139     * */
140     hkeys: async () => {
141         client.hkeys("1", function (err, replies) {
142             if(err) throw err;
143             console.log(replies);
144             client.quit();
145         });
146     },
147     /*
148     * 获取hash数据类型键值为1的所有键值对数据
149     * */
150     hgetall: async () => {
151         client.hgetall("1", function (err, obj) {
152             console.log("hgetall:",obj);
153         });
154     },
155     /*
156     * 无序集合
157     * */
158     sadd: async () => {
159         client.sadd("sadd", "a member", redis.print);
160         client.sadd("sadd", "another member", redis.print);
161         let set_size = 10;
162         while (set_size > 0) {
163             client.sadd("bigset", "member " + set_size,redis.print);
164             set_size -= 1;
165         }
166     },
167     /*
168     * 有序集合
169     * */
170     zadd: async () => {
171         client.zadd('zadd',[1,'one',2,'ninety-nine',3,'hello'], function(err, response){
172             if(err) throw err;
173             else {
174                 console.log('added '+response+' items.');
175             }
176         })
177     },
178     /*
179     * 返回无序集合 key 的基数(集合中元素的数量)。
180     * 也就是list数据类型里的列表长度
181     * 下面几种对应不同的数据结构
182     * scard zcard hcard
183     * */
184     scard: async () => {
185         client.scard("sadd",function(err,response){
186             console.log(response);
187             console.log("Number of key sadd:" + response);
188         });
189     },
190     zcard: async () => {
191         client.zcard("sadd",function(err,response){
192             console.log(response);
193             console.log("Number of key sadd:" + response);
194         });
195     },
196     rpush: async () => {
197         client.rpush("rpush", [1, 2, 3, 4, 5]);
198     },
199     /*
200     * 下面几种对应不同的数据结构
201     * hscan zscan sscan
202     * */
203     zscan: async () => {
204         client.zscan('bisset', 2, 'COUNT', '0', function(err, res) {
205              console.log(err);
206              console.log(res);
207              console.log(res[1].length);
208         });
209     },
210     sscan: async () => {
211         client.sscan('zadd', 2, 'COUNT', '0', function(err, res) {
212             console.log(err);
213             console.log(res);
214             console.log(res[1].length);
215         });
216     },
217     hscan: async () => {
218         client.hscan('z', 2, 'COUNT', '0', function(err, res) {
219             console.log(err);
220             console.log(res);
221             console.log(res[1].length);
222         });
223     },
224     /*
225    * zcount方法获取指定集合指定范围内的元素个数,设定为-Infinity, Infinity时,可以获取数组长度。
226    * */
227     zcount: async () => {
228         client.zrange('zadd', -Infinity, Infinity, function(err, resp) {
229             console.log(err);
230             console.log("resp:", resp);
231         });
232     },
233     /*
234     * 根据元素在有序排列中的位置
235     * zrange方法获取指定下标范围的内的所有key值,包括起始位置和终止位置。
236     * */
237     zrange: async () => {
238         client.zrange('zadd', 0, 1, function(err, resp) {
239             console.log(err);
240             console.log("resp:", resp);
241         });
242     },
243     /*
244     * 根据元素在有序排列中的位置
245     * 适用于列表数据类型的,set集合使用则会报错
246     * */
247     lrange: async () => {
248         client.lrange('rpush', 0, 1, function(err, resp) {
249             console.log(err);
250             console.log("resp:", resp);
251         });
252     },
253     /*
254     *  随机返回一个key键
255     * */
256     randomKey: async () => {
257         client.randomkey(function (err, reply) {
258             if (err) return false;
259             console.log(reply);
260         });
261     },
262 }
263 
264 // test.set();
265 // test.get();
266 // test.remove()
267 // test.hset();
268 // test.hget();
269 // test.hmset();
270 // test.hmget();
271 // test.keys();
272 // test.scard();
273 // test.zcard();
274 // test.rpush();
275 // test.sadd();
276 // test.zadd();
277 // test.zscan();
278 // test.sscan();
279 // test.hscan();
280 // test.zcount();
281 // test.zrange();
282 // test.lrange();
283 
284 // test.randomKey();
285 
286 // test.hkeys();
287 
288 // test.hgetall();
View Code

 



posted @ 2018-06-25 17:03  灬安  阅读(2108)  评论(0编辑  收藏  举报