hiredis的api

hiredis是redis数据库的C接口,目前只能在linux下使用,几个基本的函数就可以操作redis数据库了

 (1)连接数据库

函数原型:redisContext *redisConnect(const char *ip, int port)

说明:该函数用来连接redis数据库,参数为数据库的ip地址和端口,一般redis数据库的端口为6379

该函数返回一个结构体redisContext。

 (2)执行命令

函数原型:void *redisCommand(redisContext *c, const char *format, ...);

说明:该函数执行命令,就如sql数据库中的SQL语句一样,只是执行的是redis数据库中的操作命令,第一个参数为连接数据库时返回的redisContext,剩下的参数为变参,就如C标准函数printf函数一样的变参。返回值为void*,一般强制转换成为redisReply类型的进行进一步的处理。

 (3)释放结果集内存

函数原型void freeReplyObject(void *reply);

说明:释放redisCommand执行后返回的redisReply所占用的内存

 (4)释放连接

函数原型:void redisFree(redisContext *c);

说明:释放redisConnect()所产生的连接。


代码如下:

#include <stdio.h>  
#include <stdlib.h>  
#include <stddef.h>  
#include <stdarg.h>  
#include <string.h>  
#include <assert.h>  
#include <hiredis/hiredis.h>  
  
void doTest()  
{  
    //redis默认监听端口为6387 可以再配置文件中修改  
    redisContext* c = redisConnect("127.0.0.1", 6379);  
    if ( c->err)  
    {  
        redisFree(c);  
        printf("Connect to redisServer faile\n");  
        return ;  
    }  
    printf("Connect to redisServer Success\n");  
      
    const char* command1 = "set stest1 value1";  
    redisReply* r = (redisReply*)redisCommand(c, command1);  
      
    if( NULL == r)  
    {  
        printf("Execut command1 failure\n");  
        redisFree(c);  //释放连接
        return;  
    }  
    if( !(r->type == REDIS_REPLY_STATUS && strcasecmp(r->str,"OK")==0))  
    {  //执行失败
        printf("Failed to execute command[%s]\n",command1);  
        freeReplyObject(r);//释放结果集  
        redisFree(c);  //释放连接
        return;  
    }     
    freeReplyObject(r);  
    printf("Succeed to execute command[%s]\n", command1);  
      
    const char* command2 = "strlen stest1";  
    r = (redisReply*)redisCommand(c, command2);  
    if ( r->type != REDIS_REPLY_INTEGER)  
    {  //执行失败
        printf("Failed to execute command[%s]\n",command2);  
        freeReplyObject(r);//释放结果集  
        redisFree(c);  //释放连接
        return;  
    }  
    int length =  r->integer;  //获取结果
    freeReplyObject(r);  //释放结果集
    printf("The length of 'stest1' is %d.\n", length);  
    printf("Succeed to execute command[%s]\n", command2);  
      
    const char* command3 = "get stest1";  
    r = (redisReply*)redisCommand(c, command3);//执行命令  
    if ( r->type != REDIS_REPLY_STRING)  
    {  //执行失败
        printf("Failed to execute command[%s]\n",command3);  
        freeReplyObject(r);  //释放结果集
        redisFree(c);  .//释放连接
        return;  
    }  
    printf("The value of 'stest1' is %s\n", r->str);  
    freeReplyObject(r);  
    printf("Succeed to execute command[%s]\n", command3);  
      
    const char* command4 = "get stest2";  
    r = (redisReply*)redisCommand(c, command4);  
    if ( r->type != REDIS_REPLY_NIL)  
    {  
        printf("Failed to execute command[%s]\n",command4);  
        freeReplyObject(r);  
        redisFree(c);  
        return;  
    }  
    freeReplyObject(r);  //释放结果集
    printf("Succeed to execute command[%s]\n", command4);     
      
    redisFree(c);  //释放连接
}  
  
int main()  
{  
    doTest();  
    return 0;  
} 


执行结果为:

hiredis的api_第1张图片



你可能感兴趣的:(hiredis的api)