一.Redis的数据类型
1.String类型及操作
String是最简单的类型,一个key对应一个value,string类型是二进制安全的。Redis的string可以包含任何数据,比如jpg图片或者序列化的对象。
Set方法:设置key对应的值为string类型的value
例如:我们添加一个name=lili的键值对
redis 127.0.0.1:6379> set name lili OK
Setnx:设置key对应的值为string类型的value,如果key已经存在,返回0,nx是not exist的意思。
例如:我们添加一个name=lili_new的键值对。
redis 127.0.0.1:6379> get name "lili" redis 127.0.0.1:6379> setnx name lili_new (integer) 0 redis 127.0.0.1:6379> get name "lili" redis 127.0.0.1:6379> setnx age 20 (integer) 1
Setex:设置key对应的值为string类型的value,并指定此键值对应的有效期。
例如:我们添加一个haircolor=red的键值对,并指定有效期为10秒
redis 127.0.0.1:6379> setex haircolor 10 red OK redis 127.0.0.1:6379> get haircolor "red" redis 127.0.0.1:6379> get haircolor (nil)
nil:表示空
Setrange:设置指定key的value值的子字符串
例如:我们希望将lili的126邮箱替换为gmail邮箱
redis 127.0.0.1:6379> get name "lili@126.com" redis 127.0.0.1:6379> setrange name 6 gmail.com (integer) 14 redis 127.0.0.1:6379> get name "lili@gmail.com" redis 127.0.0.1:6379> set email lijie@lampbrother.net OK redis 127.0.0.1:6379> get email "lijie@lampbrother.net" redis 127.0.0.1:6379> setrange email 6-li-jie.me (integer) 21 redis 127.0.0.1:6379> get email "lijie@li-jie.meer.net"
mset:一次设置多个key的值,成功返回ok表示所有的值都设置了,失败返回0表示没有任何值被设置。
redis 127.0.0.1:6379> mset key1 lijie1 key2 lijie2 OK redis 127.0.0.1:6379> get key1 "lijie1" redis 127.0.0.1:6379> get key2 "lijie2"
msetnx:一次设置多个key的值,成功返回ok表示所有的值都设置了,失败返回0表示没有任何值被设置,但是不会覆盖已经存在的key。
redis 127.0.0.1:6379> msetnx key3 lijie3 key2 30 (integer) 0 redis 127.0.0.1:6379> get key3 (nil) redis 127.0.0.1:6379> msetnx key3 lijie3 key4 30 (integer) 1 redis 127.0.0.1:6379> get key3 "lijie3" redis 127.0.0.1:6379> get key4 "30"
get:获取key对应的string值,如果key不存在返回nil。
getset:设置key的值,并返回key的旧值。
redis 127.0.0.1:6379> getset key4 40 "30" redis 127.0.0.1:6379> get key4 "40"
getrange:获取key的value值的子字符串。
redis 127.0.0.1:6379> get email "lijie@li-jie.meer.net" redis 127.0.0.1:6379> getrange email 0 4 "lijie"
mget:一次获取多个key的值,如果对应key不存在则对应返回nil。
redis 127.0.0.1:6379> mget key1 key2 key3 1) lijie1 2) lijie2 3) lijie3
incr:对key的值做加加操作,并返回新的值。
redis 127.0.0.1:6379> incr key4 (integer) 41 redis 127.0.0.1:6379> incr key4 (integer) 42 redis 127.0.0.1:6379> get key4 "42" redis 127.0.0.1:6379> incr key7 (integer) 1 redis 127.0.0.1:6379> incr key7 (integer) 2 redis 127.0.0.1:6379> get key7 "2"
incrby:同incr类似,加指定值,key不存在时候会设置key,并认为原来的value是0。
redis 127.0.0.1:6379> incrby key4 5 (integer) 47 redis 127.0.0.1:6379> get key4 "47" redis 127.0.0.1:6379> incrby key4 -5 (integer) 42 redis 127.0.0.1:6379> get key4 "42"
decr:对key的值做减减操作。
decrby:同decr类似,减指定值。
redis 127.0.0.1:6379> get key6 "39" redis 127.0.0.1:6379> decr key6 (integer) 38 redis 127.0.0.1:6379> decrby key6 -3 (integer) 41 redis 127.0.0.1:6379> decrby key6 3 (integer) 38
append:给指定key的字符串追加value,返回新字符串值的长度。
redis 127.0.0.1:6379> get name "test" redis 127.0.0.1:6379> append name .net (integer) 8 redis 127.0.0.1:6379> get name "test.net"
strlen:取指定key的value值的长度。
redis 127.0.0.1:6379> strlen name (integer) 8
2.hash类型及操作
Redis hash是一个string类型的field和value的映射表。它的添加、删除操作都是0(1)(平均)。hash特别适合用于存储对象。相较于将对象的每个字段存成单个string类型。将一个对象存储在hash类型中会占用更少的内存,并且可以更方便的存取整个对象。
hset:设置hash field为指定值,如果key不存在,则先创建。
redis 127.0.0.1:6379> hset user:001 name lijie (integer) 1 redis 127.0.0.1:6379> hget user:001 name "lijie"
hsetnx:设置hash field为指定值,如果key不存在,则先创建。如果存在返回0。
redis 127.0.0.1:6379> hsetnx user:002 name lamp (integer) 1 redis 127.0.0.1:6379> hget user:002 name "lamp" redis 127.0.0.1:6379> hsetnx user:002 name lampbrother (integer) 0 redis 127.0.0.1:6379> hget user:002 name "lamp"
hmset:同时设置hash的多个field。
redis 127.0.0.1:6379> hmset user:003 name lijie age 20 sex 1 OK redis 127.0.0.1:6379> hget user:003 name "lijie" redis 127.0.0.1:6379> hget user:003 age "20" redis 127.0.0.1:6379> hget user:003 sex "1"
hget:获取指定的hash field。
hmget:获取全部指定的hash field。
redis 127.0.0.1:6379> hmget user:003 name age sex 1) "lijie" 2) "20" 3) "1"
hincrby:指定的hash field加上给定值。
redis 127.0.0.1:6379> hincrby user:003 age 5 (integer) 25 redis 127.0.0.1:6379> hget user:003 age "25"
hexists:测试指定field是否存在。
redis 127.0.0.1:6379> hexists user:003 age (integer) 1 redis 127.0.0.1:6379> hexists user:001 sex (ingeger) 0
hlen:返回指定hash的field数量
redis 127.0.0.1:6379> hlen user:001 (integer) 1 redis 127.0.0.1:6379> hlen user:003 (integer) 3
hdel:删除指定hash的field
redis 127.0.0.1:6379> hget user:003 age "25" redis 127.0.0.1:6379> hdel user:003 age (integer) 1 redis 127.0.0.1:6379> hget user:003 age (nil)
hkeys:返回hash的所有field
redis 127.0.0.1:6379> hkeys user:001 1) "name" redis 127.0.0.1:6379> hkeys user:003 1) "name" 2) "sex"
hvals:返回hash的所有value
redis 127.0.0.1:6379> hvals user:003 1) "lijie" 2) "1"
hgetall:获取某个hash中全部的field及value
redis 127.0.0.1:6379> hgetall user:003 1) "name" 2) "lijie" 3) "sex" 4) "1"
说明:本文是我网上学习LAMP兄弟连李捷老师《NoSQL数据库之Redis数据库管理》的学习笔记。
相关推荐
总结,Redis作为NoSQL数据库的一员,凭借其高效、灵活的特性和丰富多样的数据类型,为开发人员提供了强大且便捷的数据管理工具。理解和掌握Redis的使用,对于提升应用程序的性能和扩展性至关重要。
本篇文章将主要聚焦于Redis中的两种基础数据类型——String和Hash,以及它们在数据库管理中的应用。 首先,让我们深入了解String类型。在Redis中,String是最基本的数据类型,可以存储字符串、整数或浮点数。例如,...
它支持多种数据结构,包括字符串(String)、哈希(Hash)、列表(List)、集合(Set)和有序集合(Sorted Set)。在本篇文章中,我们将深入探讨其中的字符串类型和哈希类型。 ### 字符串类型(String) **1. 基本...
### NoSQL数据库之Redis知识点详解 #### 一、NoSQL数据库概述 - **NoSQL**:Not Only SQL,指的是非关系型数据库。这类数据库的设计旨在处理海量数据,并且支持高并发访问,通常用于大规模分布式存储环境中。 - *...
### NoSQL数据库-MongoDB和Redis #### 一、NoSQL简述 NoSQL数据库的出现是为了应对传统关系型数据库无法解决的一些问题,特别是在大规模数据处理方面。CAP理论(Consistency,Availability,Partition Tolerance)...
作为一个NoSQL数据库,Redis不使用传统的表结构,而是采用键(key)和值(value)的数据模型,其中值可以是字符串、哈希、列表、集合、有序集合等多种类型。这种设计使得Redis在处理大量数据时具有高速读写性能。 ...
NoSQL 之 Redis 配置与优化 一、关系型数据库与非关系型数据库 关系型数据库是一个结构化的数据库,创建在关系模型(二维表格模型)基础上,一般面向于记录。SQL 语句(标准数据查询语言)就是一种基于关系型...
redis是一款特殊的数据库软件,它是一款高性能的NOSQL系列的非关系型...和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)、zset(sorted set --有序集合)和hash(哈希类型)
Redis client提供兼容Redis协议的接口,支持多种数据类型如String、Hash、Bitmap、Set和Sorted Set;FastLoad平台处理数据导入导出;而DataNode和masterslave结构则构成了分布式存储集群,保证数据的安全和一致性。 ...
此外,Redis提供了丰富的数据类型和操作命令,比如字符串(String)、哈希表(Hash)、列表(List)、集合(Set)和有序集合(Sorted Set),这些数据结构设计巧妙,使得在实现各种业务逻辑时更加灵活高效。...
Redis 是一个基于内存的 Key-Value 数据库,主要用于缓存、会话管理和消息队列等场景。它的高性能和低延迟使其非常适合需要快速访问数据的应用场景。 MongoDB 是一个基于文档的 NoSQL 数据库,主要用于大规模数据...
数据类型包括string、list、set、zset和hash,支持主从复制和两种持久化方式(快照和AOF)。 - **Neo4j**:适合存储节点和关系,适用于社交网络分析,提供ACID支持和高速检索。 - **HBase**:列存储,适用于大数据...
Redis(NoSql)数据库详解 Redis是一种开源、基于内存的数据结构存储,用于数据库、缓存和消息代理。它支持丰富的数据类型,包括String、...通过上述指令,可以对Redis数据库进行操作和管理,满足各种应用场景的需求。
Redis是一种基于内存的NoSQL数据库,具有高性能、可扩展性和灵活性等特点。以下是Redis的详细知识点: 安装和启动 * 安装Redis可以通过下载软件包或使用yum、apt-get等安装工具进行安装。 * 启动Redis可以通过前台...
在《狂神说Redis笔记》...通过狂神的Redis笔记,我们可以系统地学习Redis的使用和管理,同时也能够从NoSQL的角度理解数据库的选择和应用,这对于我们理解和应用NoSQL数据库,尤其是Redis,提供了非常宝贵的参考和帮助。
Redis 支持丰富的数据类型,包括 String, List, Hash, Set 及 Ordered Set 数据类型操作。Redis 的所有操作都是原子性的,意思就是要么成功执行要么失败完全不执行。 Redis 优点 Redis 的优点包括: 1. 高性能 2....
Redis作为一款高性能的键值存储数据库,支持多种数据类型,包括String、List、Set、ZSet和Hash,并且提供了数据持久化的机制,包括快照(Snapshot)和AOF(Append Only File)两种方式。在Java操作方面,可以利用...
Redis是一种开源的、基于键值对的NoSQL数据库,它支持多种数据结构,包括字符串(String)、哈希(Hash)、列表(List)、集合(Set)和有序集合(Sorted Set)。在本讲座中,我们主要关注Redis中的字符串操作方法。...
1)Redis是一种基于键值对的NoSQL数据库(非关系型数据库);是一个key-value存储系统 2)高性能、可靠性 Redis将数据存储在内存中,读写性能高;Redis提供了 RDB和AOF持久化,可将内存数据存盘,避免断电数据丢失 ...
【Redis的安装与连接】 Redis 是一款高性能的内存数据存储系统,常被用作数据库、缓存和...然而,NoSQL数据库也有其局限性,如缺乏标准查询语言、事务支持不完善等,因此在选择数据库时需权衡业务需求和数据库特性。