string主要操作函数 1、新增 www.2cto.com a)set 语法:set key value 解释:把值value赋给key,如果key不存在,新增;否则,更新 [plain] [root@xsf001 ~]# redis-cli redis 127.0.0.1:6379 set user.1.name zhangsan #设置user.1.name 为zhangsan OK redi
string主要操作函数
1、新增
www.2cto.com
a)set
语法:set key value
解释:把值value赋给key,如果key不存在,新增;否则,更新
[plain]
[root@xsf001 ~]# redis-cli
redis 127.0.0.1:6379> set user.1.name zhangsan #设置user.1.name 为zhangsan
OK
redis 127.0.0.1:6379> set user.name 45 #设置user.1.name 为45
OK
b)setnx
语法:setnx key value
www.2cto.com
解释:只insert不update,即,仅仅key不存在时,则设置key的值为value,并返回1,否则返回0 。setnx 是set if not exists 的缩写
[plain]
redis 127.0.0.1:6379> setnx user.1.name zhangsan #user.1.name已经存在,则返回0
(integer) 0
redis 127.0.0.1:6379> setnx user.2.name zhangsan #user.2.name不存在,则设置
(integer) 1
c)setex
语法: setex key seconds value
解释:设置key的过期时间和值。过期时间seconds单位是秒。设置过期时间和值是原子操作,如果redis仅仅当做缓存,这个很命令很有用。
[plain]
redis 127.0.0.1:6379> setex user.2.age 2 14 #把user.2.age 的值设14 并且2秒后过期失效
OK
redis 127.0.0.1:6379> get user.2.age #失效前
"14"
redis 127.0.0.1:6379> get user.2.age #失效后
(nil)
d)mset
语法:mset key value [key value ...]
www.2cto.com
解释:同时设置多个key-value
[plain]
redis 127.0.0.1:6379> mset user.4.name lisi user.4.age 34 #设置user.4.name=lisi,user.4.age=34
OK
redis 127.0.0.1:6379> get user.4.name
"lisi"
redis 127.0.0.1:6379> get user.4.age
"34"
e)msetnx
语法:msetnx key value [key value ...]
解释:所有key都不存在才执行set操作
[plain]
redis 127.0.0.1:6379> msetnx user.4.name lisi user.4.age 34 #key 都设置过,无法再次set
(integer) 0
redis 127.0.0.1:6379> msetnx user.4.name lisi user.4.std 3 #key user.4.name 曾设置过,无法再次设置
(integer) 0
redis 127.0.0.1:6379> msetnx user.4.tech lisi user.4.std 3 #key都没有设置过,可以再次设
(integer) 1
2、查询
a)get
语法:get key
解释:获取key所set的值
www.2cto.com
[plain]
redis 127.0.0.1:6379> get user.4.name #获取user.4.name 的值
"lisi"
redis 127.0.0.1:6379> get user.4.age
"34"
redis 127.0.0.1:6379> get user.4.tech
"lisi"
redis 127.0.0.1:6379> get user.4.std
"3"
b)mget
语法: get key [key]
解释:批量获取key的值。程序一次获取多个值,可以减少网络连接损耗。
[plain]
redis 127.0.0.1:6379> mget user.4.name user.4.age user.4.std #批量获取存在key的值
1) "lisi" #user.4.name的值
2) "34" #user.4.age 的值
3) "3" #user.4.std 的值
redis 127.0.0.1:6379> mget user.4.name user.4.age user.4.std user.4.fri #key user.4.fri 不存在仍然可以返回
1) "lisi"
2) "34"
3) "3"
4) (nil) #user.4.fri 的值
c)getrange
语法:getrange key star end
解释:获取存储在key中value的字串。字符串的截取有star和end决定,字符串的第一个字符编号是0,第二个是1,一次类推;如果是负数,-1是最后一个字符,-2是倒数第二个字符,一次类推。
[plain]
redis 127.0.0.1:6379> get user.4.name
"lisi"
redis 127.0.0.1:6379> getrange user.4.name 0 3 # 0 表示开始
"lisi"
redis 127.0.0.1:6379> getrange user.4.name 1 2
"is"
redis 127.0.0.1:6379> getrange user.4.name 1 -2 #-2 表示倒数第二
"is"
redis 127.0.0.1:6379> getrange user.4.name -1 -2 # end 》 start
""
redis 127.0.0.1:6379> getrange user.4.name 1 66 #end 》 值的长度
"isi"
3、修改
a)getset
语法:getset key value
解释:设置key的值,并返回key的旧值。
[plain]
redis 127.0.0.1:6379> get user.4.name #存在的key
"lisi"
redis 127.0.0.1:6379> getset user.4.name wangwu #把存在的user.4.name设置为wagnwu
"lisi"
redis 127.0.0.1:6379> get user.4.name
"wangwu"
redis 127.0.0.1:6379> get user.5.name #不存在的key
(nil)
redis 127.0.0.1:6379> getset user.5.name lisi
(nil)
redis 127.0.0.1:6379> get user.5.name
"lisi"
b) append
语法:append key value
www.2cto.com
解释:key存在,在旧值的后面追加value;key不存在,直接set
[plain]
redis 127.0.0.1:6379> get user.4.name #存在的key
"wangwu"
redis 127.0.0.1:6379> append user.4.name 01
(integer) 8
redis 127.0.0.1:6379> get user.4.name
"wangwu01"
[plain]
redis 127.0.0.1:6379> get user.6.name #不能存在的key
(nil)
redis 127.0.0.1:6379> append user.6.name jim
(integer) 3
redis 127.0.0.1:6379> get user.6.name
"jim"
c)setrange
语法:setrange key offset value
解释:用value重写key值的一部分,偏移量由offset指定
[plain]
redis 127.0.0.1:6379> get user.4.name #key存在
"wangwu01"
redis 127.0.0.1:6379> setrange user.4.name 0 lisi
(integer) 8
redis 127.0.0.1:6379> get user.4.name
"lisiwu01"
redis 127.0.0.1:6379> setrange user.4.name 9 lisi # offset 》字符串长度
(integer) 13
redis 127.0.0.1:6379> get user.4.name
"lisiwu01\x00lisi"
redis 127.0.0.1:6379> setrange user.4.name 8 lisi
(integer) 13
redis 127.0.0.1:6379> get user.4.name
"lisiwu01lisii"
redis 127.0.0.1:6379> get user.6.std #key 不存在
(nil)
redis 127.0.0.1:6379> setrange user.6.std 0 3
(integer) 1
redis 127.0.0.1:6379> get user.6.std
"3"
d)incr
语法:incr key
解释:key中如果存储的是数字,则可以通过incr递增key的值,返回递增后的值。如果key不能存在,视为初始值为0
[plain]
redis 127.0.0.1:6379> get user.7.age #key不存在 ,初始值视为0,
(nil)
redis 127.0.0.1:6379> incr user.7.age
(integer) 1
redis 127.0.0.1:6379> get user.7.age
"1"
redis 127.0.0.1:6379> incr user.7.age
(integer) 2
e)incrby
语法:incrby key increment
解释:用指定的步长增加key存储的数字。如果步长increment是负数,则减
[plain]
redis 127.0.0.1:6379> get user.7.age
"3"
redis 127.0.0.1:6379> incrby user.7.age 15 #增加15
(integer) 18
redis 127.0.0.1:6379> get user.7.age
"18"
redis 127.0.0.1:6379> incrby user.7.fri 18 #key不能存在,原值视为0
(integer) 18
redis 127.0.0.1:6379> get user.7.fri
"18"
redis 127.0.0.1:6379> incrby user.7.age -1 #步长为负
(integer) 17
redis 127.0.0.1:6379> get user.7.age
"17"
f)decr
语法:decr key
解释:递减key保存的数字,如果key不存在,初始值视为0
[plain]
redis 127.0.0.1:6379> get user.7.age
"17"
redis 127.0.0.1:6379> decr user.7.age
(integer) 16
redis 127.0.0.1:6379> decr user.7.num #key 不存在,初始值视为0
(integer) -1
redis 127.0.0.1:6379> decr user.7.num
(integer) -2
g)decrby
语法:decrby key decrement
解释:用指定的步长递减key的值,如果步长decrment是负值,则递增
www.2cto.com
[plain]
redis 127.0.0.1:6379> decrby user.7.num 4 #递减
(integer) -6
redis 127.0.0.1:6379> decrby user.7.num -9 #负值,递增
(integer) 3
注意:递增递减系列的函数,只能对保存的是数字的key操作,不能是字符串
4)删除
语法:del key [key]
解释:删除指定的key,返回删除key的个数
[plain]
redis 127.0.0.1:6379> del user.7.num
(integer) 1
redis 127.0.0.1:6379> get user.7.num
(nil)
redis 127.0.0.1:6379> del user.7.age user.7.fri #删除多个key
(integer) 2
redis 127.0.0.1:6379> mget user.7.age user.7.fri
1) (nil)
2) (nil)
5)其他
语法:strlen key
解释:获取key中所存储值的长度
[plain]
redis 127.0.0.1:6379> get user.1.name
"45"
redis 127.0.0.1:6379> strlen user.1.name #user.1.name 长度
(integer) 2
redis 127.0.0.1:6379> strlen user.8.name #key不存在
(integer) 0
通过上面的大量demo,对string的操作基本总结完毕。

MySQL使用的是GPL许可证。1)GPL许可证允许自由使用、修改和分发MySQL,但修改后的分发需遵循GPL。2)商业许可证可避免公开修改,适合需要保密的商业应用。

选择InnoDB而不是MyISAM的情况包括:1)需要事务支持,2)高并发环境,3)需要高数据一致性;反之,选择MyISAM的情况包括:1)主要是读操作,2)不需要事务支持。InnoDB适合需要高数据一致性和事务处理的应用,如电商平台,而MyISAM适合读密集型且无需事务的应用,如博客系统。

在MySQL中,外键的作用是建立表与表之间的关系,确保数据的一致性和完整性。外键通过引用完整性检查和级联操作维护数据的有效性,使用时需注意性能优化和避免常见错误。

MySQL中有四种主要的索引类型:B-Tree索引、哈希索引、全文索引和空间索引。1.B-Tree索引适用于范围查询、排序和分组,适合在employees表的name列上创建。2.哈希索引适用于等值查询,适合在MEMORY存储引擎的hash_table表的id列上创建。3.全文索引用于文本搜索,适合在articles表的content列上创建。4.空间索引用于地理空间查询,适合在locations表的geom列上创建。

toCreateAnIndexinMysql,usethecReateIndexStatement.1)forasingLecolumn,使用“ createIndexIdx_lastNameEnemployees(lastName); 2)foracompositeIndex,使用“ createIndexIndexIndexIndexIndexDx_nameOmplayees(lastName,firstName,firstName);” 3)forauniqe instex,creationexexexexex,

MySQL和SQLite的主要区别在于设计理念和使用场景:1.MySQL适用于大型应用和企业级解决方案,支持高性能和高并发;2.SQLite适合移动应用和桌面软件,轻量级且易于嵌入。

MySQL中的索引是数据库表中一列或多列的有序结构,用于加速数据检索。1)索引通过减少扫描数据量提升查询速度。2)B-Tree索引利用平衡树结构,适合范围查询和排序。3)创建索引使用CREATEINDEX语句,如CREATEINDEXidx_customer_idONorders(customer_id)。4)复合索引可优化多列查询,如CREATEINDEXidx_customer_orderONorders(customer_id,order_date)。5)使用EXPLAIN分析查询计划,避

在MySQL中使用事务可以确保数据一致性。1)通过STARTTRANSACTION开始事务,执行SQL操作后用COMMIT提交或ROLLBACK回滚。2)使用SAVEPOINT可以设置保存点,允许部分回滚。3)性能优化建议包括缩短事务时间、避免大规模查询和合理使用隔离级别。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

适用于 Eclipse 的 SAP NetWeaver 服务器适配器
将Eclipse与SAP NetWeaver应用服务器集成。

DVWA
Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

记事本++7.3.1
好用且免费的代码编辑器

VSCode Windows 64位 下载
微软推出的免费、功能强大的一款IDE编辑器