Redis
 sql >> Datenbank >  >> NoSQL >> Redis

wie man viele-zu-viele-Beziehungen in Redis hat

Bei Redis werden Beziehungen typischerweise durch Mengen dargestellt. Eine Menge kann verwendet werden, um eine Einwegbeziehung darzustellen, daher benötigen Sie eine Menge pro Objekt, um eine Viele-zu-Viele-Beziehung darzustellen.

Es ist ziemlich sinnlos zu versuchen, ein relationales Datenbankmodell mit Redisdata-Strukturen zu vergleichen. Bei Redis wird alles denormalisiert gespeichert. Beispiel:

# Here are my categories
> hset category:1 name cinema  ... more fields ...
> hset category:2 name music   ... more fields ...
> hset category:3 name sports  ... more fields ...
> hset category:4 name nature  ... more fields ...

# Here are my users
> hset user:1 name Jack   ... more fields ...
> hset user:2 name John   ... more fields ...
> hset user:3 name Julia  ... more fields ...

# Let's establish the many-to-many relationship
# Jack likes cinema and sports
# John likes music and nature
# Julia likes cinema, music and nature

# For each category, we keep a set of reference on the users
> sadd category:1:users 1 3
> sadd category:2:users 2 3
> sadd category:3:users 1
> sadd category:4:users 2 3

# For each user, we keep a set of reference on the categories
> sadd user:1:categories 1 3
> sadd user:2:categories 2 4
> sadd user:3:categories 1 2 4

Sobald wir diese Datenstruktur haben, ist es einfach, sie mit der Mengenalgebra abzufragen:

# Categories of Julia
> smembers user:3:categories
1) "1"
2) "2"
3) "4"

# Users interested by music
> smembers category:2:users
1) "2"
2) "3"

# Users interested by both music and cinema
> sinter category:1:users category:2:users
1) "3"