学习笔记——NoSQL数据库;Redis概述;redis中常用的数据类型(key、string)

2023-01-24

一、NoSQL 数据库

1、NoSQL 数据库的简介

NoSQL(NoSQL=Not Only SQL), 即“不仅仅是 SQL”,泛指非关系型的数据库。NosQL 不依赖业务逻辑方式存储,而以简单的 key-value 模式存储。因此大大的增加了数据库的扩展能力。

(1)不遵循 SQL 标准

(2)不支持 ACID。(原子、一致、隔离、持久)

(3)远超于 SQL 的性能

2、NoSQL 适用场景

(1)对数据高并发的读写

(2)海量数据的读写

(3)对数据高可扩展的

3、NoSQL 不适用场景

(1)需要事务支持

(2)基于 sql 的结构化查询存储,处理复杂的关系。

4、非关系型数据库

(1)Memcache

①不支持持久化

②支持类型单一

③一般是作为缓存数据库辅助持久化的数据库

(2)Redis

①支持持久化

②支持多种数据结构的存储,比如 list、set、hash、zset

③一般是作为缓存数据库辅助持久化的数据库

(3)MongDB

①高性能、开源、模式自由的文档型数据库

②数据都在内存中,如果内存不足,吧不常用的数据保存到硬盘

③虽然是 key-value 模式,但是对 value(尤其是 json)提供了丰富的查询功能

④支持二进制数据及大型对象

⑤可以根据数据的特点替代 RDBMS,成为独立的数据库。或者配合 RDBMS,存储特定的数据。

2023-01-25

一、Redis 概述

1、Redis 概述

(1)Redis 是一个开源的 key-value 存储系统。

(2)Redis(Remote Dictionary Service):远程字典服务,Redis 是一个开源的使用 ANSIC 语言编写、支持网络、可基于内存亦可持久化的日志型、key-value 数据库(NoSQL),并提供多种语言的 API。实际开发中,主要时用来做缓存,加快查询效率。

(3)支持存储的 value 类型相对更多,包括 string(字符串)、list(列表)、set(集合)、zset(有序集合)和 hash(哈希类型)

(4)这些数据类型都支持 push/pop、add/remove 及取交集并集和差集及更丰富的操作,而且这些操作都是原子性的。

(5)在此基础上,Redis 支持各种不同方式的排序。

(6)为了保证效率,数据都是缓存在内存中。

(7)redis 会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件。

(8)并且在此基础上实现了 master-slave(主从) 同步。

2、Redis 的下载路径

http://redis.cn/

二、redis 中常用的数据类型

1、Redis 键(key)

(1)查看当前库所有 key

keys *

(2)判断某个 key 是否存在

exists key

(3)查看存储的 key 是什么类型

type key

(4)删除指定的 key 数据

del key

(5)根据 value 选择非阻塞删除

仅将 keys 从 keyspace 元数据中删除,真正的删除会在后续异步操作

unlink key

(6)为给定的 key 设置过期时间(单位是秒)

expire key 10

(7)查看还有多少秒过期,-1 表示永不过期,-2 表示已过期

ttl key

(8)命令切换数据库

select 数字(一共有 16 个库,从 0-15)

(9)查看当前数据库的 key 的数量

dbsize

(10)清空当前库

flushdb

(11)通杀全部库

flushall

2、Redis 字符串(String)

String 类型是二进制安全的。即 redis 中的 string 可以包含任何数据。

string 类型是 redis 最基本的数据类型,一个 redis 中字符串 value 最多可以是 512M。

(1)将字符串值 value 关联到 key

set key 值 value 值

(2)查询对应键值

get key 值

(3)将给定的 value 值追加到原值的末尾

append key 值  value 值

(4)获得值的长度

strlen key 值

(5)只有在 key 不存在时,设置 key 的值

setnx  key 值  value 值

(6)将 key 中储存的数字值增 1。只能对数字值操作,如果为空,新增值为 1。

incr  key 值

(7)将 key 中储存的数字值减 1。只能对数字值操作,如果为空,新增值为 -1。

decr key 值

(8)将 key 中储存的数字值增减。自定义步长。

incrby /decrby

(9)同时设置一个或多个 key-value 对

mset key1 value1 key2 value2 ...

(9)同时获取一个或多个 value

mget key1 key2 ...

(10)同时设置一个或多个 key-value 对,当且仅当所有给定 key 都不存在

msetnx key1 value1 key2 value2 ...

(11)获得值的范围,类似于 java 中的 substring ,前包,后包

getrange key 起始位置 结束位置