RM新时代网站-首页

電子發(fā)燒友App

硬聲App

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內(nèi)不再提示
創(chuàng)作
電子發(fā)燒友網(wǎng)>電子資料下載>電子資料>mysql_redis在MySQL中操作Redis?

mysql_redis在MySQL中操作Redis?

2022-06-22 | zip | 0.01 MB | 次下載 | 2積分

資料介紹

授權(quán)協(xié)議 BSD
開發(fā)語言 C/C++
軟件類型 開源軟件

軟件簡介

MySQL-Redis

什么是 MySQL-Redis ?

MySQL-Redis?是一款可以在?MySQL?中操作?Redis?的一個UDF (MySQL 用戶自定義函數(shù)插件)

MySQL-Redis 可以操作 Redis 集群嗎?

可以的,?MySQL-Redis?可以操作單例或者集群?Redis,操作的唯一的區(qū)別就是?MySQL?函數(shù)不一樣而已

性能怎么樣?

性能這個取決于網(wǎng)絡, 實例操作 Redis 速度很快。因為使用 C 語言開發(fā)

使用場景 ?

可以使用在需要 Redis 和 MySQL 數(shù)據(jù)一致性的地方。

示例

SELECT RedisConnect("127.0.0.1", 6379);

BEGIN;

UPDATE books SET price = 10.5 WHERE id = 10;
SELECT RedisRawCommand("SET id:10:price 10.5");

COMMIT;

SELECT RedisConnectFree();

上面示例展示了,在事務中處理數(shù)據(jù),達到?Redis?和?MySQL?數(shù)據(jù)一致性的解決辦法,當然也可以在觸發(fā)器中使用。

MySQL-Redis 函數(shù)

  • RedisConnect("127.0.0.1", 6379)

    單例 Redis 連接,第二個參數(shù)可以省略,默認端口 6379

    對應 SQL 代碼:

    SELECT RedisConnect("127.0.0.1", 6379);
  • RedisClusterConnect

    Redis 集群連接

    對應 SQL 代碼:

    SELECT RedisClusterConnect("127.0.0.1:6379,127.0.0.2:6379");

    多個機器之間采用,隔開

  • RedisConnectFree

    對應?RedisConnect() 的連接釋放

    操作完成后,如果需要手動釋放,需要調(diào)用本方法,目前暫未實現(xiàn)連接池,后續(xù)版本實現(xiàn)

    對應 SQL 代碼:

    SELECT RedisConnectFree();
  • RedisClusterConnectFree

    對應?RedisClusterConnect() 的連接釋放

    操作完成后,如果需要手動釋放,需要調(diào)用本方法,目前暫未實現(xiàn)連接池,后續(xù)版本實現(xiàn)

    使用方法:

    SELECT RedisClusterConnectFree();
  • RedisSet

    設置鍵值對的快捷方法

    對應 SQL 代碼:

    SELECT RedisSet("a", 1); -- 等同于 Redis中的語句: SET a 1
  • RedisClusterSet

    設置鍵值對的集群方法方法,參數(shù)等同于 RedisSet 函數(shù),見上面

  • RedisExecCommand

    執(zhí)行 Redis 語句,包含三個或者兩個參數(shù),如下 SQL:

    三個參數(shù)的 SQL 方法:

    SELECT RedisExecCommand("SET", "a", 1);

    兩個參數(shù)的 SQL 方法:

    SELECT RedisExecCommand("SELECT", 1);
  • RedisClusterExecCommand

    集群操作方法,參數(shù)等同于上面單例:RedisExecCommand

  • RedisRawCommand

    執(zhí)行 Redis 語句,由用戶提供一個完整的 Redis 語句

    SQL 代碼如下:

    SELECT RedisRawCommand("SET Hello World");
  • RedisClusterRawCommand

    集群模式的?RedisClusterRawCommand?方法,參數(shù)等同于 單例的?RedisRawCommand

  • RedisListIndex

    獲取 Redis List 數(shù)據(jù)結(jié)構(gòu)的某一項,第一項表示 Redis 數(shù)據(jù)結(jié)構(gòu),第二項表示索引值,如:

    SELECT RedisListIndex(RedisRawCommand("LRANGE score_lists 0 10"), 1);
  • RedisListJoin

    將 Redis List 數(shù)據(jù)結(jié)構(gòu)的所有項通過第二個參數(shù)合并為一個字符串,如:

    SELECT RedisListJoin(RedisRawCommand("LRANGE score_lists 0 10"), "-");
    // 假設 Redis List score_lists結(jié)構(gòu)如下:
    // 0 1 2
    // 那么合并結(jié)果:
    // 0-1-2

返回值

1:

RedisSET?、?RedisClusterSet?、RedisConnect?、RedisConnectFree?、?RedisClusterConnect?、?RedisClusterConnectFree?成功的情況下返回 1,否則 SQL 語句錯誤

2:

RedisExecCommand?、?RedisClusterExecCommand?、RedisRawCommand?、RedisClusterRawCommand、RedisListIndex?、RedisListJoin?返回字符串,具體如下:

  • OK

    在執(zhí)行 Redis SET 命令的時候返回 "OK" 表示成功,否則就表示錯誤信息

  • 其他字符串

    執(zhí)行 GET 命令的時候 返回具體值

怎么安裝 ?

前提條件:

電腦安裝?Redis?、MySQL?(開發(fā)機器 MySQL 5.7.22)、hiredis-vip

準備好前提條件后,開始 MySQL-Redis 插件的編譯安裝過程

  1. git clone 代碼庫

    git clone  https://gitee.com/josinli/mysql_redis.git
  2. 修改 CMakeLists.txt 文件,因為代碼庫采用 CMake 編譯系統(tǒng):

    cmake_minimum_required(VERSION 3.13)
    project(udf_str C)
    
    set(CMAKE_C_STANDARD 99)
    
    include_directories(
        .
        /usr/local/mysql/include/      # 把這行更改為您系統(tǒng)安裝mysql的頭文件目錄
        /usr/local/include/hiredis-vip # 把這行更改為您系統(tǒng)安裝hiredis-vip的頭文件目錄
    )
    
    link_directories(
        /usr/local/lib    						 # 把這行更改為您洗的 hiredis-vip的lib安裝目錄
    )
    
    add_library(udf_redis SHARED library.c library.h)
    
    target_link_libraries(udf_redis hiredis_vip)
  3. 更改完成后,執(zhí)行下面的操作

    cd build
    cmake ..
    make 
  4. 可以看到 build 目錄生成了庫文件?libudf_redis.so?或者?libudf_redis.dylib

  5. 進入您的 MySQL,執(zhí)行如下 SQL 語句找到您的 MySQL 插件目錄:

    SHOW VARIABLES LIKE 'plugin_dir%';
  6. 拷貝上面第四步中的 libudf_redis.so 或者 libudf_redis.dylib 到第五步中的目錄中

  7. 針對您的系統(tǒng),linux 系統(tǒng)拷貝 create_function_linux.sql 或者 OSX 系統(tǒng)拷貝 create_function_osx.sql 并執(zhí)行

  8. 重啟您的 MySQL,開始在 SQL 中愉快的體驗 Redis 吧!

?

下載該資料的人也在下載 下載該資料的人還在閱讀
更多 >

評論

查看更多

下載排行

本周

  1. 1山景DSP芯片AP8248A2數(shù)據(jù)手冊
  2. 1.06 MB  |  532次下載  |  免費
  3. 2RK3399完整板原理圖(支持平板,盒子VR)
  4. 3.28 MB  |  339次下載  |  免費
  5. 3TC358743XBG評估板參考手冊
  6. 1.36 MB  |  330次下載  |  免費
  7. 4DFM軟件使用教程
  8. 0.84 MB  |  295次下載  |  免費
  9. 5元宇宙深度解析—未來的未來-風口還是泡沫
  10. 6.40 MB  |  227次下載  |  免費
  11. 6迪文DGUS開發(fā)指南
  12. 31.67 MB  |  194次下載  |  免費
  13. 7元宇宙底層硬件系列報告
  14. 13.42 MB  |  182次下載  |  免費
  15. 8FP5207XR-G1中文應用手冊
  16. 1.09 MB  |  178次下載  |  免費

本月

  1. 1OrCAD10.5下載OrCAD10.5中文版軟件
  2. 0.00 MB  |  234315次下載  |  免費
  3. 2555集成電路應用800例(新編版)
  4. 0.00 MB  |  33566次下載  |  免費
  5. 3接口電路圖大全
  6. 未知  |  30323次下載  |  免費
  7. 4開關(guān)電源設計實例指南
  8. 未知  |  21549次下載  |  免費
  9. 5電氣工程師手冊免費下載(新編第二版pdf電子書)
  10. 0.00 MB  |  15349次下載  |  免費
  11. 6數(shù)字電路基礎pdf(下載)
  12. 未知  |  13750次下載  |  免費
  13. 7電子制作實例集錦 下載
  14. 未知  |  8113次下載  |  免費
  15. 8《LED驅(qū)動電路設計》 溫德爾著
  16. 0.00 MB  |  6656次下載  |  免費

總榜

  1. 1matlab軟件下載入口
  2. 未知  |  935054次下載  |  免費
  3. 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
  4. 78.1 MB  |  537798次下載  |  免費
  5. 3MATLAB 7.1 下載 (含軟件介紹)
  6. 未知  |  420027次下載  |  免費
  7. 4OrCAD10.5下載OrCAD10.5中文版軟件
  8. 0.00 MB  |  234315次下載  |  免費
  9. 5Altium DXP2002下載入口
  10. 未知  |  233046次下載  |  免費
  11. 6電路仿真軟件multisim 10.0免費下載
  12. 340992  |  191187次下載  |  免費
  13. 7十天學會AVR單片機與C語言視頻教程 下載
  14. 158M  |  183279次下載  |  免費
  15. 8proe5.0野火版下載(中文版免費下載)
  16. 未知  |  138040次下載  |  免費
RM新时代网站-首页