我的编程空间,编程开发者的网络收藏夹
学习永远不晚

redis应用之——标签

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

redis应用之——标签

mysql:

create table book (

bookid int,

title char(20)

)engine myisam charset utf8;

 

insert into book values

(5 , 'PHP圣经'),

(6 , 'ruby实战'),

(7 , 'mysql运维')

(8, 'ruby服务端编程');

 

 

create table tags (

tid int,

bookid int,

content char(20)

)engine myisam charset utf8;

 

insert into tags values

(10 , 5 , 'PHP'),

(11 , 5 , 'WEB'),

(12 , 6 , 'WEB'),

(13 , 6 , 'ruby'),

(14 , 7 , 'database'),

(15 , 8 , 'ruby'),

(16 , 8 , 'server');

 

# 既有web标签,又有PHP,同时还标签的书,要用连接查询

 

select * from tags inner join tags as t on tags.bookid=t.bookid

where tags.content='PHP' and t.content='WEB';

 

 


换成key-value存储

用kv 来存储

set book:5:title 'PHP圣经'

set book:6:title 'ruby实战'

set book:7:title 'mysql运难'

set book:8:title ‘ruby server’

 

sadd tag:PHP 5

sadd tag:WEB 5 6

sadd tag:database 7

sadd tag:ruby 6 8

sadd tag:SERVER 8

 

查: 既有PHP,又有WEB的书

Sinter tag:PHP tag:WEB  #查集合的交集

 

查: 有PHP或有WEB标签的书

Sunin tag:PHP tag:WEB

 

查:含有ruby,不含WEB标签的书

Sdiff tag:ruby tag:WEB #求差集


假设需要需要查询既属于,又属于,又属于的情况,以mysql为例,用到join(如果取交集的标签够多,join的量会够多),语句会很长,很耗资源。而redis能轻松解决这个问题:


有若干本书,分别属于若干个标签(类型):

    'php圣经','java圣经','C++圣经','asp圣经','php从入门到放弃','go圣经','linux内核编程','python圣经'

    

属于php的:

    'php圣经','php从入门到放弃'

属于web的:

    'php圣经','asp圣经','php从入门到放弃'

属于code的:

    'php圣经','java圣经','C++圣经','asp圣经','php从入门到放弃','go圣经','python圣经'

属于system的:

    'linux内核编程


接下来,字段设置:

    先将书设置好:

        set book:1:title 'php圣经'

        set book:2:title 'java圣经'

        set book:3:title 'C++圣经'

        set book:4:title 'asp圣经'

        set book:5:title 'php从入门到放弃'

        set book:6:title 'go圣经'

        set book:7:title 'linux内核编程'

        set book:8:title 'python圣经'

    将书签设置好:

        sadd tag:php    1 5

        sadd tag:web    1 4 5

        sadd tag:code   1 2 3 4 5 6 8

        sadd tag:system 7 


用集合,取交集的方式迅速求出

    既属于php标签又属于web标签的:

    127.0.0.1:6379> sinter tag:php tag:web

    1

    5

    既属于php标签又属于web标签又属于code标签的:

    127.0.0.1:6379> sinter tag:php tag:web tag:code

    1

    5


获取1、5的书名:

    127.0.0.1:6379> get book:1:title

    php圣经

    127.0.0.1:6379> get book:5:title

    php从入门到放弃


注意:正常情况下redis命令窗口不显示中文,要显示中文要加上--raw参数

    [lzw@localhost bin]$ redis-cli

    127.0.0.1:6379> get book:1:title

    "php\xe5\x9c\xa3\xe7\xbb\x8f"

    127.0.0.1:6379> 

    [lzw@localhost bin]$ redis-cli --raw

    127.0.0.1:6379> get book:1:title

    php圣经

    

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

redis应用之——标签

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Spring之Bean标签怎么使用

今天小编给大家分享一下Spring之Bean标签怎么使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。Bean标签基本配置用
2023-07-02

html5各种标签的应用方法

html5 增加了新的元素和属性,以增强网站结构、语义和交互性。其标签应用包括:语义标记:用于定义文档结构,如页眉、页脚和导航。媒体元素:允许嵌入视频、音频和创建交互式图形。数据存储:提供本地存储、会话存储和索引数据库,用于数据持久化。表单
html5各种标签的应用方法
2024-04-21

Struts2之UI标签的作用是什么

Struts2的UI标签用于快速生成HTML页面元素,如表单、输入框、按钮、下拉菜单等。它的作用是简化页面开发,减少手动编写HTML代码的工作量,提高开发效率。使用UI标签,开发人员只需要在Struts2配置文件中定义标签的属性和值,然后在
2023-09-25

HTML列表标签的特殊应用场景:解锁标签的无限潜力

HTML列表标签不仅可以罗列项目,还可以制作菜单、导航栏、表格,实现更有创意和美观的效果。
HTML列表标签的特殊应用场景:解锁标签的无限潜力
2024-02-11

编程热搜

目录