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的操作基本总结完毕。

mysqloffersvariousStorageengines,每個suitedfordferentusecases:1)InnodBisidealForapplicationsNeedingingAcidComplianCeanDhighConcurncurnency,supportingtransactionsancions and foreignkeys.2)myisamisbestforread-Heavy-Heavywyworks,lackingtransactionsactionsacupport.3)記憶

MySQL中常見的安全漏洞包括SQL注入、弱密碼、權限配置不當和未更新的軟件。 1.SQL注入可以通過使用預處理語句防止。 2.弱密碼可以通過強制使用強密碼策略避免。 3.權限配置不當可以通過定期審查和調整用戶權限解決。 4.未更新的軟件可以通過定期檢查和更新MySQL版本來修補。

在MySQL中識別慢查詢可以通過啟用慢查詢日誌並設置閾值來實現。 1.啟用慢查詢日誌並設置閾值。 2.查看和分析慢查詢日誌文件,使用工具如mysqldumpslow或pt-query-digest進行深入分析。 3.優化慢查詢可以通過索引優化、查詢重寫和避免使用SELECT*來實現。

要監控MySQL服務器的健康和性能,應關注系統健康、性能指標和查詢執行。 1)監控系統健康:使用top、htop或SHOWGLOBALSTATUS命令查看CPU、內存、磁盤I/O和網絡活動。 2)追踪性能指標:監控查詢每秒數、平均查詢時間和緩存命中率等關鍵指標。 3)確保查詢執行優化:啟用慢查詢日誌,記錄並優化執行時間超過設定閾值的查詢。

MySQL和MariaDB的主要區別在於性能、功能和許可證:1.MySQL由Oracle開發,MariaDB是其分支。 2.MariaDB在高負載環境中性能可能更好。 3.MariaDB提供了更多的存儲引擎和功能。 4.MySQL採用雙重許可證,MariaDB完全開源。選擇時應考慮現有基礎設施、性能需求、功能需求和許可證成本。

MySQL使用的是GPL許可證。 1)GPL許可證允許自由使用、修改和分發MySQL,但修改後的分發需遵循GPL。 2)商業許可證可避免公開修改,適合需要保密的商業應用。

選擇InnoDB而不是MyISAM的情況包括:1)需要事務支持,2)高並發環境,3)需要高數據一致性;反之,選擇MyISAM的情況包括:1)主要是讀操作,2)不需要事務支持。 InnoDB適合需要高數據一致性和事務處理的應用,如電商平台,而MyISAM適合讀密集型且無需事務的應用,如博客系統。

在MySQL中,外鍵的作用是建立表與表之間的關係,確保數據的一致性和完整性。外鍵通過引用完整性檢查和級聯操作維護數據的有效性,使用時需注意性能優化和避免常見錯誤。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

WebStorm Mac版
好用的JavaScript開發工具

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!