一、Redis支持数据类型简介

Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set:有序集合)。

二、String类型

  1. String类型是Redis最基本的数据类型,String存储是以Key-Value的形式存储的
  2. string类型是二进制安全的。意思是redis的string可以包含任何数据。比如jpg图片或者序列化的对象 。
  3. string类型是Redis最基本的数据类型,一个键最大能存储512MB。

1、GET和SET命令:

#set   <key> <value>添加键值对,get   <key>询对应键值
127.0.0.1:6379> set k "www.baidu.com" #将www.baidu.com存储到k值
OK
127.0.0.1:6379> get k #查看key值对应的值
"www.baidu.com"
127.0.0.1:6379>

2、key命令(查看所有的key值):

127.0.0.1:6379> keys *     #查看所有的key值
1) "age"
2) "k"
3) "name"
127.0.0.1:6379>

3、exists命令(判断某个key是否存在):

#语法:exists key                    #判断key值是否存在,存在返回1,不存在返回0。
127.0.0.1:6379> keys * #查看所有的key值
1) "age"
2) "k"
3) "name"
127.0.0.1:6379> exists age #判断key值为age是否存在,存在返回1,
(integer) 1
127.0.0.1:6379> exists www #判断key值为www是否存在,不存在返回0
(integer) 0
127.0.0.1:6379>

4、append 将给定的value追加到原值的末尾(类似java里面String的append方法)

#语法 append  <key><value>
127.0.0.1:6379> keys * #查看当前库的所有key值
1) "age"
2) "k"
3) "name"
127.0.0.1:6379> get name #获取key为name的value值。
"zhangsan"
127.0.0.1:6379> append name " is my friend" #在zhangsan后面追加 is my friend
(integer) 21
127.0.0.1:6379> get name #再次获取key为name的value值
"zhangsan is my friend"
127.0.0.1:6379>

5、strlen 获得key对应值的长度

127.0.0.1:6379> keys *				#获取所有的key值
1) "age"
2) "k"
3) "name"
127.0.0.1:6379> get name
"zhangsan is my friend"
127.0.0.1:6379> strlen name #查看name对应的value的长度,即value值的长度
(integer) 21
127.0.0.1:6379>

6、setnx <key> <value>只有在 key 不存在时 设置 key 的值

#语法:etnx  <key><value>    只有在 key 不存在时    设置 key 的值
127.0.0.1:6379> keys *
1) "age"
2) "k"
3) "name"
127.0.0.1:6379> get k
"www.baidu.com"
127.0.0.1:6379> setnx k "lisi" #先判断是否存在K,存在返回0,不修改value值
(integer) 0
127.0.0.1:6379> setnx k1 "lisi" #判断是否存在k1,不存在返回1,修改value值为 "lisi"
(integer) 1
127.0.0.1:6379> keys * #查看所有的key,新创建一个k1
1) "age"
2) "k"
3) "k1"
4) "name"
127.0.0.1:6379> get k1 #获取k1的值,验证
"lisi"
127.0.0.1:6379>

7、incr <key> 将 key 中储存的数字值增1 只能对数字值操作,如果为空,新增值为1

127.0.0.1:6379> keys *                    #当前数据库为空
(empty array)
127.0.0.1:6379> set age 12 #存值
OK
127.0.0.1:6379> incr age #让age加一
(integer) 13 #看到返回结果为13
127.0.0.1:6379> keys *
1) "age"
127.0.0.1:6379> incr name #创建一个新的key值为name,并且value值为1
(integer) 1
127.0.0.1:6379>

原子操作:对incr <key>实行原子性操作。

所谓原子操作是指不会被线程调度机制打断的操作;这种操作一旦开始,就一直运行到结束,中间不会有任何 context switch (切换到另一个线程)。

(1)在单线程中, 能够在单条指令中完成的操作都可以认为是"原子操作",因为中断只能发生于指令之间。

(2)在多线程中,不能被其它进程(线程)打断的操作就叫原子操作。

原子操作主要得益于redis的单线程。

    8、incr <key> 将 key 中储存的数字值减1 只能对数字值操作,如果为空,新增值为-1

127.0.0.1:6379> keys *
1) "age"
127.0.0.1:6379> get age
"13"
127.0.0.1:6379> decr age #年龄减一
(integer) 12
127.0.0.1:6379> decr name #创建一个新的key值为name,并且value值为-1
(integer) -1
127.0.0.1:6379>

9、incrby <key> <步长> 将 key中存储的数字值增加指定的步长

127.0.0.1:6379> set views 1              #新增一个String
OK
127.0.0.1:6379> incrby views 10 #在原来的基础上增加10
(integer) 11
127.0.0.1:6379> get views
"11"
127.0.0.1:6379> incrby test 10 #若不存在test,新建test,初始值为0加上步长10
(integer) 10
127.0.0.1:6379> get test
"10"
127.0.0.1:6379>

10、decrby <key> <步长> 将 key中存储的数字值减少指定的步长

127.0.0.1:6379> keys *
1) "views"
2) "test"
127.0.0.1:6379> get views
"11"
127.0.0.1:6379> decrby views 10 #在原来的基础上减少10
(integer) 1
127.0.0.1:6379> decrby ww 10 #初始默认为0,减少10
(integer) -10
127.0.0.1:6379>

11、Mset 命令用于同时设置一个或多个 key-value 对。

127.0.0.1:6379> keys *
(empty array)
127.0.0.1:6379> mset k1 v1 k2 v2 k3 v3 k4 v4 #进行设置多个值
OK
127.0.0.1:6379> keys *
1) "k2"
2) "k4"
3) "k3"
4) "k1"
127.0.0.1:6379>

12、Mget 命令返回所有(一个或多个)给定 key 的值。 如果给定的 key 里面,有某个 key 不存在,那么这个 key 返回特殊值 nil 。

127.0.0.1:6379> keys *
1) "k2"
2) "k4"
3) "k3"
4) "k1"
127.0.0.1:6379> mget k1 k2 k6 #k6不存在,返回null
1) "v1"
2) "v2"
3) (nil)
127.0.0.1:6379>

13、Getrange 命令用于获取存储在指定 key 中字符串的子字符串。字符串的截取范围由 start 和 end 两个偏移量决定(包括 start 和 end 在内)。

127.0.0.1:6379> set name "hello,redis world"        #设置字符串
OK
127.0.0.1:6379> get name
"hello,redis world"
127.0.0.1:6379> getrange name 0 5 #截取范围0-5的字符串
"hello,"
127.0.0.1:6379> getrange name 0 -1 #查看字符串,相当于get <key>
"hello,redis world"
127.0.0.1:6379>

14、Setrange 命令用指定的字符串覆盖给定 key 所储存的字符串值,覆盖的位置从偏移量 offset 开始到结束。

127.0.0.1:6379> keys *
1) "name"
127.0.0.1:6379> get name
"hello,redis world"
127.0.0.1:6379> setrange name 12 study #覆盖偏移量之后所有字符串
(integer) 18
127.0.0.1:6379> get name
"hello,redis studyd"
127.0.0.1:6379>

15、命令用于设置指定 key 的值,并返回 key 旧的值。

127.0.0.1:6379> set name zhangsan
OK
127.0.0.1:6379> keys *
1) "name"
127.0.0.1:6379> getset name lisi #获取原来的值,并将新的值存入当前key对应的value。
"zhangsan"
127.0.0.1:6379> get name
"lisi"
127.0.0.1:6379>

5、Redis五大基本数据类型——String类型的更多相关文章

  1. ***Redis hash是一个string类型的field和value的映射表.它的添加、删除操作都是O(1)(平均)。hash特别适合用于存储对象

    http://redis.readthedocs.org/en/latest/hash/hset.html HSET HSET key field value   (存一个对象的时候key存) 将哈希 ...

  2. Redis hash 是一个 string 类型的 field 和 value 的映射表.它的添加、删除操作都是 O(1)(平均)。

    2.3 hashes 类型及操作 Redis hash 是一个 string 类型的 field 和 value 的映射表.它的添加.删除操作都是 O(1)(平均).hash 特别适合用于存储对象.相 ...

  3. redis中关于使用string类型还是hash类型

    前篇:最近在做一个将redis中大数据量进行合并缩减优化的工作,其中一项按月将数据进行合并.将一个月的数据放入一个key-value键值对中. 例:p2d20180901-3.p2d20180902- ...

  4. JS基础_数据类型-String类型

    <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title&g ...

  5. redis 模拟jedis 操作string类型数据

    一.思路分析 redis数据传输遵循resp协议,只需要按照resp协议并通过socket传递数据到redis服务器即可 resp数据格式: 二.具体实现 package com.ahd.jedis; ...

  6. laravel-- 在laravel操作redis数据库的数据类型(string、哈希、无序集合、list链表、有序集合)

    安装redis和连接redis数据库 在controller头部引入 一.基本使用 public function RedisdDbOne() { // 清空Redis数据库 Redis::flush ...

  7. Redis和nosql简介,api调用;Redis数据功能(String类型的数据处理);List数据结构(及Java调用处理);Hash数据结构;Set数据结构功能;sortedSet(有序集合)数

    1.Redis和nosql简介,api调用 14.1/ nosql介绍 NoSQL:一类新出现的数据库(not only sql),它的特点: 1.  不支持SQL语法 2.  存储结构跟传统关系型数 ...

  8. redis学习笔记-01 string类型命令

    一.set key value set joker 123456 #设定key为joker,value为123456的数据 二.keys * keys * #用于查看该数据库中所有的key值 三.se ...

  9. redis 五大数据类型之string篇

    一: 1:string(字符串) string是redis最基本的类型,你可以理解成与Memcached一模一样的类型,一个key对应一个value. string类型是二进制安全的.意思是redis ...

随机推荐

  1. 04373 C++程序设计 2019版 第一章习题五、程序设计题

    题目: 1.编写一个程序,将从键盘输入的n个字符串保存在一个一维数组A中.在输入字符串之前,先输入n的值.要求,数组A需要动态申请空间,程序运行结束前再释放掉. #include <iostre ...

  2. [loj6031]字符串

    为了方便,用$N=10^{5}$来描述复杂度 (对原串建立SAM)注意到$\sum|w|=qk\le N$,考虑对$q$和$k$的大小关系分类讨论: 1.若$q\le k$,即询问次数较少,将其与原串 ...

  3. [atAGC045D]Lamps and Buttons

    由于$p_{i}$是随机的,不断选择最小的.未被操作过的$i$并处理其所在的环一定是最优的,而这样与已知$p_{i}$的区别是,当选择了一个$i=p_{i}$,那么必然失败(而已知$p_{i}$时不会 ...

  4. [loj3329]有根树

    题目即求$\min_{C}\max(|C|,\min_{x\notin C}w_{x})$,考虑将$w$从大到小排序,即为$\min_{1\le k\le n}\max(k,w_{k+1})$ 考虑若 ...

  5. springboot配置自动提示插件-IDEA

    社区版的IDEA编辑spring boot项目的properties或者yml文件不会自动提醒.可手动安装IDEA的插件解决. Setting >> Plugins >> 搜索 ...

  6. Identity Server 4 从入门到落地(一)—— 从IdentityServer4.Admin开始

    最近项目中需要使用Identity Server 4,以前对这个技术只是有些了解,没有系统研究过,网上相关的资料不少,大多是从编写一个简单的认证服务开始,离能够落地使用有相当的距离,理论学习如何不结合 ...

  7. 洛谷 P3994 高速公路(斜率优化)

    题目链接 题意:给出一棵树,\(1\) 号点为根,边上有边权. 每个点有两个参数 \(p_i,q_i\) 如果你想从 \(i\) 号点到与其距离为 \(d\) 的 \(j\) 号点,那么你需花费 \( ...

  8. Codeforces 1499G - Graph Coloring(带权并查集+欧拉回路)

    Codeforces 题面传送门 & 洛谷题面传送门 一道非常神仙的题 %%%%%%%%%%%% 首先看到这样的设问,做题数量多一点的同学不难想到这个题.事实上对于此题而言,题面中那个&quo ...

  9. 洛谷 P5853 - [USACO19DEC]Tree Depth P(生成函数+背包)

    洛谷题面传送门 神仙题. 首先考虑一个点的深度是什么,注意到对于笛卡尔树而言直接从序列的角度计算一个点的深度是不容易的,因为这样会牵扯到序列中多个元素,需要 fixed 的东西太多,计算起来太复杂了. ...

  10. DTOJ 3999: 游戏

    题目描述这个游戏是这样的,你有一个初始序列S ,你每次可以选择一段任意长度的连续区间,把他们+1 再膜k,给定目标序列,你需要尝试用尽量少的操作次数将初始序列变为目标序列.作为一名优秀的OIer,您认 ...