【捷哥浅谈PHP】第十八弹---NoSQL数据库Redis之莫问剑(String类型)的修炼

本文主要是介绍【捷哥浅谈PHP】第十八弹---NoSQL数据库Redis之莫问剑(String类型)的修炼,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

上文我给大家详细介绍了Redis数据库以及它的安装过程,及适用场景,上文我们说了,Redis数据库是基于
内存的数据库,速度极快,那今天我们来看看这种超级牛X的数据库的操作使用方法,还记得我上文提过的

Redis的七种数据类型吧,我们这里把它称之为Redis七剑下天山,即为:莫问剑,游龙剑,青干剑,舍神剑,

天瀑剑,日月剑,竞星剑

现在,为师来分别传授给大家每一把剑的奥妙及使用方法:
首先我们来启动Redis的客户端,启动Redis客户端的命令我们使用 src/redis-cli命令启动,即可进入Redis的

shell客户端,一切准备就绪,咱们开始学习这七把剑....

第一把----------------------莫问剑String类型

介绍:String是最简单的类型,你可以理解成与Memcached是一模一样的类型,一个Key对应一个Value,目前

你可以完全实现Memcached的功能,而且效率要比Memcached高很多,同时可以设置Redis的定时数据持久

化,操作日志的记录以及主从复制等功能

技能:

1.set

设置Key对应的值为string类型的value。

例如我来设置一个name = MoWenJian 的键值对,可以这样做:

[root@localhost src]# /usr/local/redis/src/redis-cli
redis 127.0.0.1:6379> set name MoWenJian
OK
redis 127.0.0.1:6379>

2.setnx

设置key 对应的值为string 类型的value。如果key 已经存在,返回0,nx 是not exist 的意思。

例如我们添加一个name= MoWenJian_New 的键值对,可以这样做:

redis 127.0.0.1:6379> get name
"
MoWenJian"
redis 127.0.0.1:6379> setnx name
MoWenJian_New
(integer) 0
redis 127.0.0.1:6379> get name
"
MoWenJian_New"
redis 127.0.0.1:6379>

由于原来name 有一个对应的值,所以本次的修改不生效,且返回码是0。

3.setex
设置一个键对应的值,并对此键值对设置一个有效期。

例如:我们指定一个键值对 lampbrother = success,并且设置一个有效期为10秒,我们来这样做:


redis 127.0.0.1:6379> set lampbrother 10 success
OK
redis 127.0.0.1:6379> get lampbrother

"success"
redis 127.0.0.1:6379> get
lampbrother
(nil)
redis 127.0.0.1:6379>


由于第二次调用已经超过10秒,所以无法取到lampbrother的值了!!!


4.setrange


设置指定键的值的子字符串。


例如:我现在要把 jiege 的邮箱 lijie@ li-jie.me 改为 lijie@lampbrother.net


redis 127.0.0.1:6379> get jiege
"lijie@li-jie.me"
redis 127.0.0.1:6379> setrange jiege 6
lampbrother.net
(integer) 21
redis 127.0.0.1:6379> get
lampbrother
"lijie@lampbrother.net"
redis 127.0.0.1:6379>



5.mset


同时设置多个键值对,成功返回ok表示所有键设置成功,失败则返回0表示所有键设置都不成功


例如:我们同时设置 李文凯 的多个爱好:


redis 127.0.0.1:6379> mset hobby1 smoke hobby2 beer hobby3 girl
OK
redis 127.0.0.1:6379> get hobby1

"smoke"
redis 127.0.0.1:6379> get
hobby3
"girl"
redis 127.0.0.1:6379>



6.msetnx


同时设置多个键值对,同样失败返回0表示所有键都没有设置成功,成功返回OK表示所有键都设置成功,但

不同于mset的是本方法不会设置已经存在的键值对!


redis 127.0.0.1:6379> get hobby1
"smoke"
redis 127.0.0.1:6379> get
hobby3
"girl"
redis 127.0.0.1:6379> msetnx hobby1 chouyan hobby4 hejiu
(integer) 0
redis 127.0.0.1:6379> get hobby4
(nil)
redis 127.0.0.1:6379> get hobby3
"girl"



可以看出如果这条命令返回0,那么里面操作都会回滚,都不会被执行。


7.get


获取某个键对应的值,如果不存在则返回 nil


redis 127.0.0.1:6379> get hobby4
(nil)
redis 127.0.0.1:6379> get hobby3
"girl"



如上例,hobby3存在,并且值为"girl",hobby4不存在,则返回 nil


8.getset


设置某一个键的值,并且返回该键的旧值,如果该键不存在,则返回 nil,然后再设置新的值


例如:


redis 127.0.0.1:6379> getset hobby4 football
(nil)
redis 127.0.0.1:6379> getset hobby3 basketball
"girl"
redis 127.0.0.1:6379> get hobby4
"football"
redis 127.0.0.1:6379> get hobby3
"basketball"



9.getrange


获取指定键的值的子字符串


例如:

redis 127.0.0.1:6379> getrange jiege 0 4
"lijie"
redis 127.0.0.1:6379> getrange jiege -15 -1
"lampbrother.net"
redis 127.0.0.1:6379> getrange jiege 0 100
"lijie@lampbrother.net"



上例中, getrange jiege 0 4 表示获取 jiege 这个键的值的下标为 0~4 的所有字符


同样, getrange jiege -15 -1 表示获取 jiege 这个键的值的下标从后数第15个到最后一个的所有字符


getrange jiege 0 100 则表示全部输出 jiege 这个键的值的所有字符,因为最后一个字符的下标 小于 100,


当下标超出字符串长度时,将默认为是同方向的最大下标。


10.mget


一次性获取多个键的值,如果键不存在,则返回 nil


例如:


redis 127.0.0.1:6379> mget hobby1 hobby2 hobby5
1) "smoke"
2) "beer"
3) (nil)
redis 127.0.0.1:6379>



hobby5不存在,所以返回nil。


11.incr


对一个键的值做加加操作,并返回新的值,如果该键的值类型不是int类型,将会报错,如果该键不存在,则设置该键为1


例如:


redis 127.0.0.1:6379> set age 20
OK
redis 127.0.0.1:6379> incr age
(integer) 21
redis 127.0.0.1:6379> get age
"21"
redis 127.0.0.1:6379> get age1
(nil)
redis 127.0.0.1:6379> incr age1
(integer) 1
redis 127.0.0.1:6379> get age1
"1"



12.incrby


类似于incr,但是incrby可以指定增加的值


例如:


redis 127.0.0.1:6379> incrby age 5
(integer) 26
redis 127.0.0.1:6379> get age
"26"
redis 127.0.0.1:6379> incrby age -1
(integer) 25
redis 127.0.0.1:6379> get age

"25"



大家可以看到,5代表给age键增加5,而-1表示给age键减1,即正数为加,负数为减


13.decr


对某一个键做减减操作,同incr


例如:


redis 127.0.0.1:6379> set age 20
OK
redis 127.0.0.1:6379> decr age
(integer) 19
redis 127.0.0.1:6379> get age
"19"
redis 127.0.0.1:6379> get age1
(nil)
redis 127.0.0.1:6379> decr age1
(integer) -1
redis 127.0.0.1:6379> get age1
"-1"



14.decrby


同incrby,给某一键减去指定的值


redis 127.0.0.1:6379> decrby age 5
(integer) 14
redis 127.0.0.1:6379> get age
"14"



decrby 完全是为了可读性,我们完全可以通过incrby 一个负值来实现同样效果,反之一样。


15.append


给指定key 的字符串值追加value,返回新字符串值的长度。


例如:


redis 127.0.0.1:6379> set name lijie
OK
redis 127.0.0.1:6379> get name
"lijie"
redis 127.0.0.1:6379> append name
@li-jie.me
(integer) 15
redis 127.0.0.1:6379> get name
"lijie@li-jie.me"



16.strlen


取指定key 的value 值的长度。


例如:


redis 127.0.0.1:6379> get name
"lijie@li-jie.me"
redis 127.0.0.1:6379> strlen name
(integer) 15
redis 127.0.0.1:6379> get age

"20"
redis 127.0.0.1:6379> strlen age
(integer) 2




好了,这就是我们的莫问剑(String类型)的所有技能,为师已经传授给各位,不知各位能否深刻领悟,


如有无法体悟之处,请跟帖回复,切勿自行闭门修炼,以免走火入魔


今天咱们就练到这里,下文将给大家详细介绍Redis的第二把剑---------游龙剑(hashes 类型)的操作,敬请期待!!!

原文地址:http://bbs.lampbrother.net/read-htm-tid-122275.html

<script type=text/javascript charset=utf-8 src="http://static.bshare.cn/b/buttonLite.js#style=-1&uuid=&pophcol=3&lang=zh"></script> <script type=text/javascript charset=utf-8 src="http://static.bshare.cn/b/bshareC0.js"></script>
阅读(49) | 评论(0) | 转发(0) |
0

上一篇:【分享】DolrPHP模板引擎DolrViews分享

下一篇:项目心得

相关热门文章
  • 《数字技术与应用》征稿**投稿...
  • 关于分库分表(Mysql篇)
  • 数据库性能监控工具ORATOP...
  • 欢迎shuziliang在ChinaUnix博...
  • PHP程序员战地日记
  • 毕业五年(续)
  • 毕业五年
  • 职业生涯规划
  • 中国软件开发工程师之痛...
  • 闲置书处理!
  • 大家都是用什么来管理hadoop集...
  • 网站被人挂了吗,添加了些程序...
  • Nginx如何保证不走宕机的那个...
  • 大家谈谈MYSQL客户端和服务器...
  • 以下代码运行后为何会输出5?...
给主人留下些什么吧!~~
评论热议

这篇关于【捷哥浅谈PHP】第十八弹---NoSQL数据库Redis之莫问剑(String类型)的修炼的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1074268

相关文章

Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式

《Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式》本文详细介绍如何使用Java通过JDBC连接MySQL数据库,包括下载驱动、配置Eclipse环境、检测数据库连接等关键步骤,... 目录一、下载驱动包二、放jar包三、检测数据库连接JavaJava 如何使用 JDBC 连接 mys

Knife4j+Axios+Redis前后端分离架构下的 API 管理与会话方案(最新推荐)

《Knife4j+Axios+Redis前后端分离架构下的API管理与会话方案(最新推荐)》本文主要介绍了Swagger与Knife4j的配置要点、前后端对接方法以及分布式Session实现原理,... 目录一、Swagger 与 Knife4j 的深度理解及配置要点Knife4j 配置关键要点1.Spri

MySQL数据库中ENUM的用法是什么详解

《MySQL数据库中ENUM的用法是什么详解》ENUM是一个字符串对象,用于指定一组预定义的值,并可在创建表时使用,下面:本文主要介绍MySQL数据库中ENUM的用法是什么的相关资料,文中通过代码... 目录mysql 中 ENUM 的用法一、ENUM 的定义与语法二、ENUM 的特点三、ENUM 的用法1

Redis出现中文乱码的问题及解决

《Redis出现中文乱码的问题及解决》:本文主要介绍Redis出现中文乱码的问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 问题的产生2China编程. 问题的解决redihttp://www.chinasem.cns数据进制问题的解决中文乱码问题解决总结

Java中调用数据库存储过程的示例代码

《Java中调用数据库存储过程的示例代码》本文介绍Java通过JDBC调用数据库存储过程的方法,涵盖参数类型、执行步骤及数据库差异,需注意异常处理与资源管理,以优化性能并实现复杂业务逻辑,感兴趣的朋友... 目录一、存储过程概述二、Java调用存储过程的基本javascript步骤三、Java调用存储过程示

Go语言数据库编程GORM 的基本使用详解

《Go语言数据库编程GORM的基本使用详解》GORM是Go语言流行的ORM框架,封装database/sql,支持自动迁移、关联、事务等,提供CRUD、条件查询、钩子函数、日志等功能,简化数据库操作... 目录一、安装与初始化1. 安装 GORM 及数据库驱动2. 建立数据库连接二、定义模型结构体三、自动迁

嵌入式数据库SQLite 3配置使用讲解

《嵌入式数据库SQLite3配置使用讲解》本文强调嵌入式项目中SQLite3数据库的重要性,因其零配置、轻量级、跨平台及事务处理特性,可保障数据溯源与责任明确,详细讲解安装配置、基础语法及SQLit... 目录0、惨痛教训1、SQLite3环境配置(1)、下载安装SQLite库(2)、解压下载的文件(3)、

MySQL数据库的内嵌函数和联合查询实例代码

《MySQL数据库的内嵌函数和联合查询实例代码》联合查询是一种将多个查询结果组合在一起的方法,通常使用UNION、UNIONALL、INTERSECT和EXCEPT关键字,下面:本文主要介绍MyS... 目录一.数据库的内嵌函数1.1聚合函数COUNT([DISTINCT] expr)SUM([DISTIN

MySQL追踪数据库表更新操作来源的全面指南

《MySQL追踪数据库表更新操作来源的全面指南》本文将以一个具体问题为例,如何监测哪个IP来源对数据库表statistics_test进行了UPDATE操作,文内探讨了多种方法,并提供了详细的代码... 目录引言1. 为什么需要监控数据库更新操作2. 方法1:启用数据库审计日志(1)mysql/mariad

postgresql数据库基本操作及命令详解

《postgresql数据库基本操作及命令详解》本文介绍了PostgreSQL数据库的基础操作,包括连接、创建、查看数据库,表的增删改查、索引管理、备份恢复及退出命令,适用于数据库管理和开发实践,感兴... 目录1. 连接 PostgreSQL 数据库2. 创建数据库3. 查看当前数据库4. 查看所有数据库