# 3.4.1 字符串
String 數據結構是簡單的 key-value 類型,value 不僅可以是 String,也可以是數字。使用 Strings 類型,可以完全實現目前
Memcached 的功能,并且效率更高。還可以享受 Redis 的定時持久化(可以選擇 RDB 模式或者 AOF 模式). string類型是二進制安全的。意思是redis的string可以包含任何數據,比如jpg圖片或者序列化的對象。從內部實現來看其實string可以看作byte數組,最大上限是1G字節,
下面是string類型的定義:
```cpp
struct sdshdr {
long len;
long free;
char buf[];
};
```
len是buf數組的長度。
free是數組中剩余可用字節數,由此可以理解為什么string類型是二進制安全的了,因為它本質上就是個byte數組,當然可以包含任何數據了
buf是個char數組用于存貯實際的字符串內容。
另外string類型可以被部分命令按int處理.比如incr等命令,如果只用string類型,redis就可以被看作加上持久化特性的 memcached。當然redis對string類型的操作比memcached還是多很多的.
具體操作方法如下:
### 命令示例:
`set` -- 設置key對應的值為string類型的value。
```bash
> set name itcast
```
`setnx` -- 設置key對應的值為string類型的value。如果key已經存在,值不變,返回0,nx是not exist的意思。
```bash
?> getname
"itcast"
> setnx name itcast_new
(integer)0
>getname
"itcast"
```
`setex` -- 設置key對應的值為string類型的value,并指定此鍵值對應的有效期。
```bash
> setex color 10 red
> get color
"red"
10秒后...
> get color (nil)
```
`setrange` -- 設置指定key的value值的子字符串。
```bash
> set email liudanbing@itcast.cn
> get email
"liudanbing@itcast.cn"
> setrange email 10 gmail.com
> get email
"liudanbing@itcast.com"
```
其中的4是指從下標為4(包含4)的字符開始替換
`mset` -- 一次設置多個key的值,成功返回ok表示所有的值都設置了,失敗返回0表示沒有任何值被設置。
```bash
> mset key1 python key2 c++
OK
```
`msetnx` -- 一次設置多個key的值,成功返回ok表示所有的值都設置了,失敗返回0表示沒有任何值被設置。
```bash
> get key1 "python"
```
`get` -- 獲取key對應的string值,如果key不存在返回nil。
```bash
> get name
"itcast"
```
`getset` -- 設置key的值,并返回key的舊值。
```bash
> get name
"itcast"
> getset name itcast_new
"itcast"
> get name "itcast_new"
```
`getrange` -- 獲取指定key的value值的子字符串。
```bash
> getrange name 0 4
"itcas"
```
`mget` -- 一次獲取多個key的值,如果對應key不存在,則對應返回nil。
```bash
> mget key1 key2 key3
1) "python"
2) "c++"
3) (nil)
```
`incr` -- 對key的值做加加操作
```bash
> set age 20
> incr age
(integer) 21
```
`incrby` -- 同incr類似,加指定值 ,key不存在時候會設置key,并認為原來的value是 0
```bash
> incrby age 5
(integer) 5
```
`decr` -- 對key的值做的是減減操作,decr一個不存在key,則設置key為-1
`decrby` -- 同decr,減指定值
`append` -- 給指定key的字符串值追加value,返回新字符串值的長度。例如我們向name的值追加一個"redis"字符串:
```bash
> append name redis
> get name
```
- 概要
- 1 分布式存儲fastDFS
- 1.1 fastDFS 通用介紹
- 1.2 fastDFS安裝和使用
- 1.3 基于fastDFS實現分布式
- 2 緩存數據庫redis快速搭建
- 2.1 環境安裝
- 2.2 redis數據類型
- 2.3 redis訂閱發布模式
- 2.4 redis事務
- 2.5 redis備份
- 3 redis詳細攻略
- 3.1 redis簡介
- 3.2 redis使用場景
- 3.3 redis基本操作
- 3.4 redis數據類型
- 3.4.1 字符串
- 3.4.2 HASH-字典
- 3.4.3 List-列表
- 3.4.4 Set-集合
- 3.4.5 Sorted Set-有序集合
- 3.4.6 訂閱-發布
- 3.4.7 事務
- 3.5 redis配置文件
- 3.6 持久化
- 3.7 redis性能測試
- 3.8 redis-C-API
- 3.9 redis-C++-API
- 3.10 總結與建議
- 4 memcache緩存數據庫
- 4.1 什么是memcached
- 4.2 memcached的特征
- 4.3 memcached的內存管理
- 4.4 如何使用memcached
- 4.5 memcached參數詳解
- 4.6 memcached安裝
- 4.7 memcached-C客戶端
- 4.8 memcached-C++客戶端
- 5 Nginx
- 6 FastCGI
- 6.1 CGI
- 6.2 FastCGI
- 6.3 Nginx與FastCGI
- 7 Nginx上部署fastDFS
- 8 項目概要
- 8.1 上傳文件功能
- 8.2 主界面顯示與下載文件功能
- 8.3 注冊功能
- 8.4 登陸功能
- 8.5 文件分類功能
- 8.6 個人網盤功能
- 8.8 秒傳功能