當前位置:首頁 » 存儲配置 » redis對象存儲

redis對象存儲

發布時間: 2022-04-28 04:03:23

① 怎麼把一個實體對象存入redis裡面

Redis是Key-Value型內存資料庫,不能直接存儲對象,如果實體對象可以序列化,可以將序列化後的內容存入一個Value中。

② redis 存儲java對象是json字元串還是序列化

是進行序列化存儲的。 Redis存儲對象時,要對這個對象進行序列化。序列化還有一個作用是可以將對象序列化之後通過socket進行傳輸。那麼,JSON也是一個進行數據交換的格式。何不將對象轉為JSON字元串然後當作String存在Value中也是可以的。redis 存儲java對象是json字元串還是序列化

③ redis存儲對象大小2m

Redis 存儲字元串和對象
1 測試類
import redis.clients.RedisClinet;
import redis.clients.SerializeUtil;
import redis.clients.jedis.Jedis;

public class Test {

/**
* Administrator
* @param args
*/
public static void main(String[] args) {

// 操作單獨的文本串
Jedis redis= new Jedis( "10.2.31.38", 6379);

redis.set( "key", "value");
System. out.println(redis.get( "key"));
System. out.println(redis.del( "key"));

// 操作實體類對象
Goods good= new Goods(); // 這個Goods實體我就不寫了啊
good.setName( "洗衣機" );
good.setNum(400);
good.setPrice(19l);
redis.set( "good".getBytes(), SerializeUtil. serialize(good));
byte[] value = redis.get( "good".getBytes());
Object object = SerializeUtil. unserialize(value);
if(object!= null){
Goods goods=(Goods) object;
System. out.println(goods.getName());
System. out.println(goods.getNum());
System. out.println(goods.getPrice());
}
System. out.println(redis.del( "good".getBytes()));

// 操作實體類對象2(實際上和上面是一樣的)
String key= "goods-key";
Goods g= new Goods();
g.setName( "電風扇--d" );
g.setNum(200);
String temp=RedisClinet. getInstance().set(g, key);
System. out.println(temp);

Object o=RedisClinet. getInstance().get(key);
if(o!= null)
{
Goods g1=(Goods)o;
System. out.println(g1.getName());
System. out.println(g1.getNum());
}
System. out.println(RedisClinet. getInstance().del(key));

}
}

2 RedisClinet 客戶端類
package redis.clients;
import redis.clients.jedis.Jedis;
/**
*
* @author ajun
*
*/
public class RedisClinet {
private static final String ip= "10.2.31.38";
private static final int port=6379;
protected static RedisClinet redis = new RedisClinet ();
protected static Jedis jedis = new Jedis( ip, port);;
static {

}
protected RedisClinet(){
System. out.println( " init Redis ");
}
public static RedisClinet getInstance()
{
return redis;
}

/**set Object*/
public String set(Object object,String key)
{
return jedis.set(key.getBytes(), SerializeUtil.serialize(object));
}

/**get Object*/
public Object get(String key)
{
byte[] value = jedis.get(key.getBytes());
return SerializeUtil. unserialize(value);
}

/**delete a key**/
public boolean del(String key)
{
return jedis.del(key.getBytes())>0;
}

}

3 序列化工具類

/**
*
*/
package redis.clients;

import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;

/**
* @author Administrator
*
*/
public class SerializeUtil {
public static byte[] serialize(Object object) {
ObjectOutputStream oos = null;
ByteArrayOutputStream baos = null;
try {
// 序列化
baos = new ByteArrayOutputStream();
oos = new ObjectOutputStream(baos);
oos.writeObject(object);
byte[] bytes = baos.toByteArray();
return bytes;
} catch (Exception e) {

}
return null;
}

public static Object unserialize( byte[] bytes) {
ByteArrayInputStream s = null;
try {
// 反序列化
s = new ByteArrayInputStream(bytes);
ObjectInputStream ois = new ObjectInputStream(s);
return ois.readObject();
} catch (Exception e) {

}
return null;
}
}

④ redis可以直接存儲對象嗎

Redis是Key-Value型內存資料庫,不能直接存儲對象,如果實體對象可以序列化,可以將序列化後的內容存入一個Value中。

⑤ Redis在實際項目怎麼把一個對象,和list集合存進去,用哪種數據類型

如果需要用到Redis存儲List對象,而list又不需要進行操作,可以按照MC的方式進行存儲,不過Jedis之類的客戶端沒有提供API,可以有兩種思路實現:
1. 分別序列化 elements ,然後 set 存儲
2. 序列化List對象,set存儲
這兩種方法都類似MC的 Object方法存儲,運用這種方式意味著放棄redis對List提供的操作方法。

⑥ 對象存儲oss和redis的區別

為了支持雲服務,MySQL的備份做了極大地改進,比如Global Transaction Identifiers (GTIDs). GTIDs可以輕松地跟蹤和比較master和slave伺服器之間的進度狀態。
在2013年4月,Oracle發布了針對Hadoop的MySQL Applier。Nokia首先將MySQL應用於大數據環境中,包括集中的Hadoop集群等等。

⑦ Redis怎麼存儲List對象比較好

方案一:
直接使用List結構,List裡面存儲二進制的任務Bean信息,這樣做查詢全部任務很方便,查詢單條任務速度較慢,並且刪除和修改狀態很麻煩;
方案二:
直接使用Hash結構,Hash的key存儲任務ID,value存儲二進制的Bean信息,這樣做查詢所有任務、查詢單條任務以及刪除任務都很快,但是修改狀態也必須先取出數據再修改再插入!

⑧ redis怎麼存儲list對象

方案一:直接使用List結構,List裡面存儲二進制的任務Bean信息,這樣做查詢全部任務很方便,查詢單條任務速度較慢,並且刪除和修改狀態很麻煩;方案二:直接使用Hash結構,Hash的key存儲任務ID,value存儲二進制的Bean信息,這樣做查詢所有任務、查詢單條任務以及刪除任務都很快,但是修改狀態也必須先取出數據再修改再插入!

熱點內容
金士頓硬體加密u盤 發布:2024-11-18 10:34:23 瀏覽:1000
小數乘小數的演算法 發布:2024-11-18 10:28:52 瀏覽:912
vga編程器 發布:2024-11-18 10:07:17 瀏覽:924
反編譯應用分身 發布:2024-11-18 10:04:07 瀏覽:61
飛天加密狗 發布:2024-11-18 10:00:29 瀏覽:443
dayz手動伺服器ip 發布:2024-11-18 09:59:57 瀏覽:387
oracle資料庫清理 發布:2024-11-18 09:57:02 瀏覽:224
手機我的世界伺服器外掛 發布:2024-11-18 09:52:28 瀏覽:67
崩與壓縮機 發布:2024-11-18 09:48:55 瀏覽:699
ping不通雲伺服器ip原因 發布:2024-11-18 09:38:56 瀏覽:420