redisTemplate.opsForValue().set(idKey, number);这样写代码,key的过期时间是多少
时间: 2024-04-30 14:20:58 浏览: 64
这个代码没有设置 key 的过期时间。如果需要设置过期时间,可以使用`redisTemplate.opsForValue().set(idKey, number, timeout, TimeUnit.SECONDS);`,其中 `timeout` 为过期时间,`TimeUnit.SECONDS` 表示过期时间的单位为秒。比如下面的代码设置了 key 的过期时间为 10 秒:
```
redisTemplate.opsForValue().set(idKey, number, 10, TimeUnit.SECONDS);
```
相关问题
以下这段代码中e.deviceId!中的!有什么作用if (['D1','RQ1','RQ2','RQ3'].includes(e.deviceId!)) { emissionsAll.set(key, Number((emissionsAll.get(key) ?? 0)) + Number((e.emissions ?? 0))); }
这个感叹号表示 e.deviceId 不为空,通过 ! 可以检测 e.deviceId 是否为 null 或 undefined,如果为空则会报错。这个代码段使用了 includes 方法来检查 e.deviceId 是否包含在 ['D1','RQ1','RQ2','RQ3'] 数组中,如果包含,则将 e.emissions 的值加到 emissionsAll 中对应的 key 值上。
SQL> -- 创建加密密钥 SQL> DECLARE 2 key_raw VARCHAR2(32) := 'mysecretkey1234567890123456789'; 3 key_blob BLOB; 4 BEGIN 5 key_blob := utl_raw.cast_to_raw(key_raw); 6 DBMS_CRYPTO.ENCRYPT_AES256(DBMS_CRYPTO.CBC_PKCS5, key_blob, NULL, key_blob); 7 INSERT INTO MY_KEYS (ID, KEY_BLOB) VALUES (1, key_blob); 8 END; 9 10 -- 加密 Price 字段 11 UPDATE PRODUCT 12 SET Price = DBMS_CRYPTO.ENCRYPT(UTL_I18N.STRING_TO_RAW(Price, 'AL32UTF8'), 13 DBMS_CRYPTO.AES256_CBC, 14 MY_KEYS.KEY_BLOB, 15 UTL_RAW.CAST_TO_RAW('1234567890123456')); 16 17 -- 解密 Price 字段 18 SELECT DBMS_CRYPTO.DECRYPT(Price, 19 DBMS_CRYPTO.AES256_CBC, 20 MY_KEYS.KEY_BLOB, 21 UTL_RAW.CAST_TO_RAW('1234567890123456')) 22 FROM PRODUCT; 23 24 -- 加密 PhoneNumber 字段 25 UPDATE CUSTOMER 26 SET PhoneNumber = DBMS_CRYPTO.ENCRYPT(UTL_I18N.STRING_TO_RAW(PhoneNumber, 'AL32UTF8'), 27 DBMS_CRYPTO.AES256_CBC, 28 MY_KEYS.KEY_BLOB, 29 UTL_RAW.CAST_TO_RAW('1234567890123456')); 30 31 -- 解密 PhoneNumber 字段 32 SELECT DBMS_CRYPTO.DECRYPT(PhoneNumber, 33 DBMS_CRYPTO.AES256_CBC, 34 MY_KEYS.KEY_BLOB, 35 UTL_RAW.CAST_TO_RAW('1234567890123456')) 36 FROM CUSTOMER; 37 / UPDATE PRODUCT * ERROR at line 11: ORA-06550: line 11, column 1: PLS-00103: Encountered the symbol "UPDATE"
这个错误可能是因为你在执行上面的 SQL 语句时没有先创建 MY_KEYS 表,导致 DBMS_CRYPTO.ENCRYPT_AES256 函数无法正常执行。你需要先创建 MY_KEYS 表并且确保它存在,然后再执行上面的加密和解密操作。以下是创建 MY_KEYS 表的示例代码:
```
CREATE TABLE MY_KEYS (
ID NUMBER PRIMARY KEY,
KEY_BLOB BLOB
);
```
另外,如果你在执行 SQL 语句时使用了客户端工具,例如 SQL*Plus 或 SQL Developer,那么你需要先使用 CONNECT 命令连接到数据库,并且使用正确的用户名和密码。如果你使用的是 SQL*Plus,可以执行以下命令:
```
CONNECT username/password@database
```
其中,username 是你的数据库用户名,password 是你的数据库密码,database 是你的数据库连接字符串。如果你没有设置密码,可以省略 /password 部分。
阅读全文