Home Database Mysql Tutorial hash主要操作函数

hash主要操作函数

Jun 07, 2016 pm 02:53 PM
hash main function operate

hash主要操作函数 hash是一些列key value(field value)的映射表。常常用其存储一些对象实例。相对于把一个对象的各个字段存储为string,存储为hash会占用更少的内存。为什么会更省内存呢?需要搞清楚两个配置(hash-max-zipmap-entries和hash-max-zipmap-v

hash主要操作函数

 

hash是一些列key value(field value)的映射表。常常用其存储一些对象实例。相对于把一个对象的各个字段存储为string,存储为hash会占用更少的内存。为什么会更省内存呢?需要搞清楚两个配置(hash-max-zipmap-entries和hash-max-zipmap-value)的含义,配置的详细介绍,我打算放在最后的配置优化环节讲。

1)新增  www.2cto.com  

 

a)hset

 

语法:hset key field value

 

解释:设置hash表key中的field的值。如果hash表不存在,则创建,并执行设置field的值,如果hash表存在,值field的值覆盖或新增

 

[plain] 

[root@xsf001 ~]# redis-cli   

redis 127.0.0.1:6379> hset user.1 name zhangsan    #设置key user.1 name域 的值  

(integer) 1  

redis 127.0.0.1:6379> hset user.1 age 45 #设置age域  

(integer) 1  

redis 127.0.0.1:6379> hset user.1 tech lisi  

(integer) 1  

 b)hmset

语法:hash key field value[key value]

 

解释:批量设置hash表key的域

  www.2cto.com  

[plain] 

redis 127.0.0.1:6379> hmset user.2 name niuer age 34 #同时设置name 和age域  

OK  

 c)hsetnx

语法:hsetnx key field value

 

解释:仅仅当field域不存在时,设置hash表field的值

 

[plain] 

redis 127.0.0.1:6379> hsetnx user.1 name lisi  #由于name域已经设置过,所以返回0  

(integer) 0  

redis 127.0.0.1:6379> hsetnx user.1 fri 5    

(integer) 1   #fri域没有设置过,所以hset并返回1  

 2)查询

a)hget

 

语法:hget key field

 

解释:获取哈希表key的field值

 

[plain] 

redis 127.0.0.1:6379> hget user.1 name  #存在的hash表及域  

"zhangsan"  

redis 127.0.0.1:6379> hget user.3 name  #不存在的hash表  

(nil)  

redis 127.0.0.1:6379> hget user.1 bb  #不存在的域  

(nil)  

 b)hmget

语法:hmget key field[field]

 

解释:批量获取hash表的filed

 

[plain] 

redis 127.0.0.1:6379> hmget user.1 name age fri tech  

1) "zhangsan"  

2) "45"  

3) "5"  

4) "lisi"  

redis 127.0.0.1:6379> hmget user.1 name age fri tech nofield #存在hash表中包含不存在的域nofield  

1) "zhangsan"  

2) "45"  

3) "5"  

4) "lisi"  

5) (nil)  

redis 127.0.0.1:6379> hmget user.3 name age fri #不存在的hash表  

1) (nil)  

2) (nil)  

3) (nil)  

 c)hgetall

语法:hgetall key

 

解释:获取hash表的所有域值

 

[plain] 

redis 127.0.0.1:6379> hgetall user.2  #存在的hash表  

1) "name"   #域  

2) "niuer"  #域name的值  

3) "age"    #域  

4) "34"     #域age的值  

redis 127.0.0.1:6379> hgetall user.3  #不存在的hansh表  

(empty list or set)  

   

d)hexists

语法:hexists key field

 

解释:判断hash表中是否存在某个域

 

[plain] 

redis 127.0.0.1:6379> hexists user.1 name  #存在  

(integer) 1  

redis 127.0.0.1:6379> hexists user.1 nofield  #不存在  

(integer) 0  

redis 127.0.0.1:6379> hexists use1 nofield #hash表不存在  

(integer) 0  

 

e)hkeys 

 

 语法:hkeys key

 

解释:获取hash表的所有域

 

[plain] 

redis 127.0.0.1:6379> hkeys user.1  #存在的hash表  

1) "name"  

2) "age"  

3) "tech"  

4) "fri"  

redis 127.0.0.1:6379> hkeys user.4 #不存在的hash  

(empty list or set)  

 

f)hvals

语法:hvals key

 

解释:获取hash表的所有域值

 

[plain] 

redis 127.0.0.1:6379> hvals user.1  #存在hash  

1) "zhangsan"  

2) "45"  

3) "lisi"  

4) "5"   

redis 127.0.0.1:6379> hvals user.4 #不存在  

(empty list or set)  

 3)修改

语法:hincrby key field increment

 

解释:hash表field域的数值增加步长increment,如果increment是负值,则是递减。如果域不存在,初始值视为0

 

[plain] 

redis 127.0.0.1:6379> hincrby user.1 age 2  #增加2  

(integer) 47  

redis 127.0.0.1:6379> hincrby user.1 age -3  #减少3  

(integer) 44  

redis 127.0.0.1:6379> hincrby user.1 age2 -3 #域不能存在,初始值是0  

(integer) -3  

 

4)删除

语法:hdel key field[field]

 

解释:删除hash的域,如果指定多个field,则删除多个

 

[plain] 

redis 127.0.0.1:6379> hkeys user.1  

1) "name"  

2) "age"  

3) "tech"  

4) "fri"  

5) "age2"  

redis 127.0.0.1:6379> hdel user.1 age2  #删除一个域  

(integer) 1  

redis 127.0.0.1:6379> hkeys user.1  

1) "name"  

2) "age"  

3) "tech"  

4) "fri"  

redis 127.0.0.1:6379> hdel user.1 fri tech #删除2个域  

(integer) 2  

redis 127.0.0.1:6379> hkeys user.1  

1) "name"  

2) "age"  

redis 127.0.0.1:6379> hdel user.1 bb #删除一个不存在的域   

(integer) 0 #返回0  

 

5)其他

语法:hlen key

 

解释:获取hash的域数量

 

[plain] 

redis 127.0.0.1:6379> hkeys user.1  

1) "name"  

2) "age"  

redis 127.0.0.1:6379> hlen user.1 #存在2个域  

(integer) 2  

redis 127.0.0.1:6379> hlen user.4  #不存在的hash  

(integer) 0  

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
Two Point Museum: All Exhibits And Where To Find Them
1 months ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Tips for dynamically creating new functions in golang functions Tips for dynamically creating new functions in golang functions Apr 25, 2024 pm 02:39 PM

Go language provides two dynamic function creation technologies: closure and reflection. closures allow access to variables within the closure scope, and reflection can create new functions using the FuncOf function. These technologies are useful in customizing HTTP routers, implementing highly customizable systems, and building pluggable components.

Considerations for parameter order in C++ function naming Considerations for parameter order in C++ function naming Apr 24, 2024 pm 04:21 PM

In C++ function naming, it is crucial to consider parameter order to improve readability, reduce errors, and facilitate refactoring. Common parameter order conventions include: action-object, object-action, semantic meaning, and standard library compliance. The optimal order depends on the purpose of the function, parameter types, potential confusion, and language conventions.

How to write efficient and maintainable functions in Java? How to write efficient and maintainable functions in Java? Apr 24, 2024 am 11:33 AM

The key to writing efficient and maintainable Java functions is: keep it simple. Use meaningful naming. Handle special situations. Use appropriate visibility.

Complete collection of excel function formulas Complete collection of excel function formulas May 07, 2024 pm 12:04 PM

1. The SUM function is used to sum the numbers in a column or a group of cells, for example: =SUM(A1:J10). 2. The AVERAGE function is used to calculate the average of the numbers in a column or a group of cells, for example: =AVERAGE(A1:A10). 3. COUNT function, used to count the number of numbers or text in a column or a group of cells, for example: =COUNT(A1:A10) 4. IF function, used to make logical judgments based on specified conditions and return the corresponding result.

Comparison of the advantages and disadvantages of C++ function default parameters and variable parameters Comparison of the advantages and disadvantages of C++ function default parameters and variable parameters Apr 21, 2024 am 10:21 AM

The advantages of default parameters in C++ functions include simplifying calls, enhancing readability, and avoiding errors. The disadvantages are limited flexibility and naming restrictions. Advantages of variadic parameters include unlimited flexibility and dynamic binding. Disadvantages include greater complexity, implicit type conversions, and difficulty in debugging.

What are the benefits of C++ functions returning reference types? What are the benefits of C++ functions returning reference types? Apr 20, 2024 pm 09:12 PM

The benefits of functions returning reference types in C++ include: Performance improvements: Passing by reference avoids object copying, thus saving memory and time. Direct modification: The caller can directly modify the returned reference object without reassigning it. Code simplicity: Passing by reference simplifies the code and requires no additional assignment operations.

What is the difference between custom PHP functions and predefined functions? What is the difference between custom PHP functions and predefined functions? Apr 22, 2024 pm 02:21 PM

The difference between custom PHP functions and predefined functions is: Scope: Custom functions are limited to the scope of their definition, while predefined functions are accessible throughout the script. How to define: Custom functions are defined using the function keyword, while predefined functions are defined by the PHP kernel. Parameter passing: Custom functions receive parameters, while predefined functions may not require parameters. Extensibility: Custom functions can be created as needed, while predefined functions are built-in and cannot be modified.

C++ Function Exception Advanced: Customized Error Handling C++ Function Exception Advanced: Customized Error Handling May 01, 2024 pm 06:39 PM

Exception handling in C++ can be enhanced through custom exception classes that provide specific error messages, contextual information, and perform custom actions based on the error type. Define an exception class inherited from std::exception to provide specific error information. Use the throw keyword to throw a custom exception. Use dynamic_cast in a try-catch block to convert the caught exception to a custom exception type. In the actual case, the open_file function throws a FileNotFoundException exception. Catching and handling the exception can provide a more specific error message.

See all articles