真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

吐血整理系列Redis與Jedis排序

在優(yōu)銳課學(xué)習(xí)筆記中,我們將討論redis SORT命令。

成都創(chuàng)新互聯(lián)專業(yè)提供成都主機(jī)托管四川主機(jī)托管成都服務(wù)器托管四川服務(wù)器托管,支持按月付款!我們的承諾:貴族品質(zhì)、平民價格,機(jī)房位于中國電信/網(wǎng)通/移動機(jī)房,西部信息服務(wù)器租用服務(wù)有保障!

Redis提供了SORT命令,我們可以使用該命令從LIST,SET或ZSET中檢索或存儲排序的值。

以最簡單的形式,我們可以在KEY上使用命令,如下面的示例所示:

SORT numbers_list

這將對鍵中包含的值進(jìn)行排序并返回它們。 該命令將值排序為數(shù)字。 因此,假設(shè)我們有一個包含以下值的列表:

1, 110, 5

上面的命令將返回:

1 5 110

我們可以指定使用ALPHA修飾符按字母順序?qū)χ颠M(jìn)行排序。 有許多修飾符。 我們將在下面的示例中查看其中的一些。 這些示例將使用Jedis API。
對于我們的示例,讓我們考慮一下我們有一個想法管理系統(tǒng)。 我們有一個包含系統(tǒng)中所有用戶名的列表:

all:users [junior, francisco, ribeiro, user4]

對于每個用戶名,將有一個包含用戶信息的哈希:

user:
user:junior
  - name: "Junior User"
  - num_ideas : "5"
  - email:"fjunior@email.com"
user:francisco
 - name: "Francisco User"
 - num_ideas: "4"
 - email: "francisco@email.com"
...

對于我們的示例,我們可以看到一個將填充Redis的類:


package br.com.xicojunior.redistest;
import java.util.HashMap;
import java.util.Map;
import redis.clients.jedis.Jedis;
public class App 
{
    public static Jedis jedis = new Jedis("localhost");   
    public static void main( String[] args ){
        String names[] = new String[]{"junior", "francisco", "ribeiro", "user4"};
        for(String name: names){
            jedis.lpush("all:users", name);
        }
        addUserHash(names[0], "Junior User", "junior@junior.com", "5");
        addUserHash(names[1], "Francisco User", "francisco@francisco.com", "4");
        addUserHash(names[2], "Ribeiro User", "ribeiro@ribeiro.com", "3");
        addUserHash(names[3], "User 4", "user@user.com", "2");
        for(String name: names){
            System.out.println(jedis.hgetAll("user:".concat(name)));
        }
        System.out.println(jedis.lrange("all:users", 0, -1));
    }
    public static void addUserHash(String username, String name, String email, String numberOfIdeas){
        Map userProp = new HashMap();
        userProp.put("name",name);
        userProp.put("email", email);
        userProp.put("num_ideas", String.valueOf(numberOfIdeas));
        jedis.hmset("user:".concat(username), userProp);
    }
}

讓我們看下面的代碼示例:

package br.com.xicojunior.redistest;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.SortingParams;
public class SortTest {
    public static void main(String[] args) {
        Jedis jedis = new Jedis("localhost");
        //[1]sorting the usernames
        System.out.println(jedis.sort("all:users"));
        //[ribeiro, francisco, junior, user4]
        //[2]sorting the username alpha
        //jedis sort method receives a SortingParams instance for modifiers
        System.out.println(jedis.sort("all:users", new SortingParams().alpha()));
        //[francisco, junior, ribeiro, user4]
    }
}

在上面的示例中,我們對鍵“ all:users”進(jìn)行排序。 第一次嘗試時,似乎沒有正確排序,因為默認(rèn)排序考慮了數(shù)字。 在第二個示例中,我們使用ALPHA修飾符。 我們可以通過使用重載版本的sort方法來做到這一點。 它接收SortingParams類的實例。 在這種情況下,我們看到用戶名已正確排序。

SORT命令的一個不錯的功能是我們可以使用外部值(其他鍵中的值)對列表進(jìn)行排序。 在下面的示例中,我們將按用戶給出的提示數(shù)對all:users鍵進(jìn)行排序。 可以使用“ BY”修飾符來完成,該修飾符接收要使用的鍵的模式。 讓我們看下面的例子:

package br.com.xicojunior.redistest;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.SortingParams;
public class SortTest {
    public static void main(String[] args) {
        Jedis jedis = new Jedis("localhost");
        //[1] Sorting the usernames by the number of ideas
        System.out.println(jedis.sort("all:users", new SortingParams().by("user:*->num_ideas")));
        //[user4, ribeiro, francisco, junior]
        //[1] Sorting the usernames by the number of ideas DESC
        System.out.println(jedis.sort("all:users", new SortingParams().by("user:*->num_ideas").desc()));
    }
}

在第二個示例中,我們通過一個外部值對用戶名進(jìn)行排序,在本例中,我們通過字段“ numideas”對用戶名進(jìn)行排序。因為我們按哈希字段排序,所以使用了以下模式“ user:-> numideas”。使用這種模式,我們說要查找鍵“ user:”,其中“ ”將被列表中的值替換。由于是散列,因此我們需要通知該字段。我們使用模式“-> fieldname”來完成。如果我們按字符串鍵排序,則可以使用模式“ numideas ”,因為有一個鍵可以存儲每個用戶的想法數(shù)。

在第一個調(diào)用中,它檢索了值-將它們排序為ASC。我們還可以使用DESC修飾符告訴reRediso將其排序為DESC。對于Jedis,BY和DESC是SortingParams中的方法。當(dāng)所有方法都返回實例時,我們可以鏈接所有調(diào)用,這使讀取代碼更容易。
使用SORT 命令,我們還可以從外部鍵檢索值,也可以從外部哈希檢索字段。我們可以使用GET修飾符進(jìn)行此操作,并且可以多次使用。讓我們在下面看到此修飾符的一些示例:

package br.com.xicojunior.redistest;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.SortingParams;
public class SortTest {
    public static void main(String[] args) {
        Jedis jedis = new Jedis("localhost");
        //[1] Sorting the usernames by the number of ideas and retrieving the user name
        System.out.println(jedis.sort("all:users", new SortingParams().by("user:*->num_ideas").get("user:*->name")));
        //[User 4, Ribeiro User, Francisco User, Junior User]
        //[2] Retrieving the name and email
        System.out.println(jedis.sort("all:users", new SortingParams().by("user:*->num_ideas").get("user:*->name","user:*->email")));
        //[User 4, user@user.com, Ribeiro User, ribeiro@ribeiro.com, Francisco User, francisco@francisco.com, Junior User, junior@junior.com]
        //[3] Retrieve the value of the key being sorted - Special pattern #
        System.out.println(jedis.sort("all:users", new SortingParams().by("user:*->num_ideas").get("user:*->name","user:*->email","#")));
        //[User 4, user@user.com, user4, Ribeiro User, ribeiro@ribeiro.com, ribeiro, Francisco User, francisco@francisco.com, francisco, Junior User, junior@junior.com, junior]
    }
}

在上面的代碼中,我們可以看到GET修飾符的使用。 為了返回一個散列字段,我們可以使用類似于在BY修飾符中使用的模式。 首先,我們只是返回名稱,但是正如我們所說的,我們可以多次使用GET。 在第二個中,我們從用戶那里檢索名稱和電子郵件。 我們還可以檢索使用特殊模式“?!迸判虻逆I的值。 GET方法接收一個變量,因此我們可以傳遞要從中檢索值的所有外部鍵。

我們可以做的另一件事是將排序結(jié)果存儲在一個鍵中。 在需要緩存排序結(jié)果的情況下很有用,我們可以為sort命令指定一個dest鍵。 結(jié)果將存儲為LIST。

package br.com.xicojunior.redistest;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.SortingParams;
public class SortTest {
    public static void main(String[] args) {
        Jedis jedis = new Jedis("localhost");
        jedis.sort("all:users","dest_key1");
        System.out.println(jedis.lrange("dest_key1", 0, -1));
        //[ribeiro, francisco, junior, user4]
        jedis.sort("all:users", new SortingParams().alpha().desc(), "dest_key2");
        System.out.println(jedis.lrange("dest_key2", 0, -1));
        //[user4, ribeiro, junior, francisco]
    }
}

SORT命令的一個非常有用的功能是我們只能將其用于從相關(guān)鍵中獲取值。 有一個修飾符指示不對NOSORT進(jìn)行排序:

package br.com.xicojunior.redistest;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.SortingParams;
public class SortTest {
    public static void main(String[] args) {
        Jedis jedis = new Jedis("localhost");
        System.out.println(jedis.sort("all:users", new SortingParams().get("user:*->name","user:*->email").nosort()));
        //[User 4, user@user.com, Ribeiro User, ribeiro@ribeiro.com, Francisco User, francisco@francisco.com, Junior User, junior@junior.com]
    }
}

這段代碼基本上為所有用戶檢索名稱和電子郵件。 如果我們不使用SORT命令,則至少需要兩個命令來執(zhí)行相同的操作:

LRANGE all:users 0 -1 //TO get all usernames

然后為每個用戶名分別調(diào)用HMGET,如下所示:

HMGET user:junior name email //TO get the name and email from a user

我們可以在redis網(wǎng)站上找到命令文檔。

抽絲剝繭,細(xì)說架構(gòu)那些事--優(yōu)銳課

文章寫道這里,歡迎朋友點贊關(guān)注,如有不足之處,歡迎評論交流!

吐血整理系列 Redis與Jedis排序


當(dāng)前標(biāo)題:吐血整理系列Redis與Jedis排序
URL鏈接:http://weahome.cn/article/jsppds.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部