- Hive中常用函数 wm_concat & concat_ws & collect_set & sort_array总结
Lens5935
Hive数据库数据分析hive大数据sql数据库postgresql
concat_ws&collect_set:应用1:usereach_iduser_id1id1user_id1id2user_id2id1user_id2id2user_id2id3user_id3id1useridsuser_id1id1,id2user_id2id1,id2,id3user_id3id1selectdt,user_id,concat_ws(',',collect_set(ea
- oracle listagg替代wm_concat()函数 解决wm_concat()查询速率过低问题
ExiFengs
sqlmacsql数据库
原sql:selecte.comment_id,e.evaluate_type,wmsys.wm_concat(evaluate_label)labelsfromevaluating_labelewhereexists(select*fromevaluationowhereo.order_id='123'ande.comment_id=o.id)groupbye.comment_id,e.eval
- Oracle listagg,wm_concat函数行转列结果去重Oracle 11g/19c版本
SUMMERENT
数据库OracleSQLoracle数据库sql
1、准备数据表2、根据学生名(stu_name)分组,学生名相同的,学生年龄(stu_age)用逗号拼接,使用listagg()函数法拼接3、上图中出现了两个12,12,实现去重3.1listagg()函数去重【方法1】使用正则表达式去重,oracle11g和oracle19c都适用selectstu_name,regexp_replace(listagg(stu_age,',')withingr
- oracle笔记
shuangmu9768
java笔记oraclelinux数据库
【1】cmd命令登录【2】创建表空间【3】exp导出数据【4】解决Oracle11g使用exp导出空表【5】批量增加【6】批量修改【7】MERGEINTO【8】WM_CONCAT【9】分区排序取值【10】oracle即使客户端【11】oracle性能【12】ORA-12514TNS监听程序当前无法识别连接描述符中请求服务【13】UNPIVOT操作,列转行【14】CentOS6.5安装oracle【
- Oracle To Mysql 迁移常用语句
24K老游
数据库sql数据库
--生成UNIQUE索引withtabas(selecttable_name,INDEX_NAME,wm_concat(column_name)over(partitionbytable_name,INDEX_NAMEorderbycolumn_position)r,column_position,max(column_position)over(partitionbytable_name)max
- 各数据库SQL查询结果多行数据合并成一行
hezudao25
SqlServer数据库sqloracle
一、Oracle函数多行数据合并成一行一、wm_concatwm_concat函数是是oracle中常用的函数,功能:行转列,可以将查询出的多行某列值使用逗号进行隔开拼接,成为一条数据。示例,现在有一张风险表,每个风险项(risk_id)对应有多条规则(risk_rule),现在我要按照风险项把对应的规则都查询出来。selectrisk_id,wm_concat(risk_rule)fromris
- wm_concat和listagg
zz_ll9023
oracle
wm_concat和listagg是两个不同的函数,具体区别如下:功能:wm_concat和listagg都可以实现对(单个或组合)列的合并,也可以看成是对某一列的“SUM”。然而,wm_concat在12c版本中被取消,而listagg是在11.2的版本中才首次出现的。排序:listagg函数行转列后,会按照原有查询结果顺序排列。而wm_concat函数行转列后,不会按照原有查询结果排序。总的来
- 在Sqlserver中用for xml path替代 Oracle中 wm_concat函数
高明
sqlserver数据库sql
SELECTID,Names=(stuff((SELECT','+NameFROMTableawherea.ID=b.IDFORXMLpath('')),1,1,''))FROMTablebgroupbyId
- Oracle查询wm_concat返回[oracle.sql.CLOB@72f4a250]第一坑
简陌刀丶阿吉
Oracle行合并,wm_concat在linux查询异常。字符串类型变为clob类型查询查询到的数据类型如图,红色圈住的是clob类型,但是我需要的是String,所以在查询的时候,to_char一下解决方案
- 03-012 oracle中xmlagg和listagg
csdn_immortal
databaselistaggxmlaggwm_contact
oracle列转换行有如下方法一、wm_concatWMSYS.WM_CONCAT:依赖WMSYS用户,不同oracle环境时可能用不了,返回类型为CLOB,可用substr截取长度后to_char转化为字符类型1、语法wm_concat()实例如下selectwm_concat(distinctvendor)fromams_asset_info二、XMLAGG函数效果和wm_concat一样,但
- oracle listagg 排序,oracle 行转列 listagg与wm_concat
深夜利行
oraclelistagg排序
wm_concat和listagg函数都可以实现对(单个或组合)列的合并,也可以看成是对某一列的“SUM”,这俩个函数功能相同,listagg是在11.2的版本中才首次出现的,wm_concat在12c版本中被取消。常见用法selectt.job,listagg(t.ename,',')withingroup(orderbyhiredateasc)fromscott.emptgroupbyt.jo
- Oracle列转行函数listagg和wm_concat
微微笑再加油
数据库sql数据库
listagg函数其函数在Oracle11g版本中推出,对分组后的数据按照一定的排序进行字符串连接。//用法如下分隔符号可以自定义listagg(字段,',')WITHINGROUP(ORDERBY字段)现在要把查询出的两列转为一行selectlistagg(B,',')WITHINGROUP(ORDERBYB)fromAWHEREA='1'结果如下wm_concat函数其函数在Oracle10g
- oracle列转行函数listagg和vm_concat
Javaxiaobaismc
随手记oracle数据库sql
wm_concat和listagg函数都可以实现对(单个或组合)列的合并,也可以看成是对某一列的“SUM”,这俩个函数功能相同,listagg是在11.2的版本中才首次出现的,wm_concat在12c版本中被取消。常见用法selectt.job,listagg(t.ename,’,’)withingroup(orderbyhiredateasc)fromscott.emptgroupbyt.jo
- Oracle的wm_concat函数对应postgresql的什么函数?
liuhuapeng0304
sqlpostgresqloracle
//oracle的函数wm_concat(name)//pg的函数string_agg(name,',')
- SQL装13的一些写法
hzp666
SQLSERVER数据库MySQLsqlserver函数group_concatoracleSQL数据库
一些当你离职后,让老板狂拍大腿的代码Oracle:1.EXCEPTEXCEPT是指在第一个集合中存在,但是不存在于第二个集合中的数据。(selectA)EXCEPT(selectB)INTERSECT返回两个结果集的交集(即两个查询都返回的所有非重复值)2.wm_contactselectid,wm_concat(name)namefromtablegroupbyid;转换前:idname1李白1
- odps函数
静听山水
Odpssql
1、wm_concat聚合函数,可以实现对分组后的列数据拼接成一行。参数:第一个参数为分隔符,第二个参数为要聚合的列;selectprov_code,wm_concat('-',city_name)fromcode_china_areagroupbyprov_code;2、datediff日期函数,求两个日期的时间差selectdatediff(getdate(),'2023-06-3000:00
- Oracle (wm_concat,listagg ,xmlagg)的使用
Hzcc
1.wm_concat返回类型string--此函数慎用,在Oracle12G中不支持此函数,如果遇到项目的数据库版本升级,会报出标识符无效的错。/*SELECTwm_concat(t.name)INTOv_wm_concat_strFROMnbw.czh_testtGROUPBYt.id1HAVINGt.id1<3;dbms_output.put_line(v_wm_concat_str);*/
- ORA-00932: inconsistent datatypes: expected - got CLOB
徐如是
gotclob不知道还有没有其他情况今天做数据分析,用了wm_concat然后再groupby就出现这个问题了。这个我在公司开发环境没问题,上了生产就有问题,而后定位在wm_concat后或者是字符太长的原因,我觉得是wm_concat的原因。总之对他来一个to_cahr即可。
- Oracle 数据库将多行数据根据条件转换成一行
JasonLanDH
解决方案oraclesql
/****过滤条件COLOR1、YELLOW或者TOMATO则显示TOMATO2、全WHITE则显示WHITE3、只要有一个LAWNGREEN则显示LAWNGREEN4、全LAWNGREEN则显示LAWNGREEN****/以下是解决方案SQL1、使用wm_concat()函数将多行数据按单号分组合并成一行。2、再使用case语法进行条件过滤,instr()函数判断字符串中是否包含某个字符结果大于
- oracle中wm_concat函数去重,oracle-常用函数-wm_contact
Ezreal JI
oraclewm_concat(column)函数使我们经常会使用到的,下面就教您如何使用oraclewm_concat(column)函数实现字段合并如:shopping:-----------------------------------------u_idgoodsnum------------------------------------------1苹果22梨子51西瓜43葡萄13香
- Oracle wm_concat函数失效问题
firehand01
oracle数据库
今天在使用Oraclewm_concat函数时,使用selectwm_concat(字段1)from表名,查询出结果为空,其实数据库表里是有数据的。为什么查询结果为空呢??后来发现,字段1的类型为NVARCHAR2类型的,把该字段1的类型修改为VARCHAR2,再查询,数据就出来了。不知道是不是wm_concat函数,listagg函数对NVARCHAR2类型的数据都无效吗?暂未考证。
- Oracle中to_char(wm_concat())函数使用
明天会更好fjy
笔记javasqlmysql
需求:通过id查询某条任务,返回多条数据,将这一列转成行进行展示。伪代码进行测试:selectto_char(wm_concat(h.xl_mc))ascddbmcfromstudentwhwhereh.id='1111'
- MaxCompute 与 AnalyticDB MySQL 数据处理与转换
梦幻通灵
数据处理大数据mysqlodps数据库
AnalyticDBMySQL(简称ads)与MaxCompute(简称odps)进行数据转换时,个别语法有差别,记录下来,方便备查。1、行转列函数odps中行转列函数wm_concat,将列信息转成行显示,可指定分隔符。语法格式wm_concat(separator,string),其中separator为分隔符,支持字符串去重,即distinct.selectwm_concat('|',sku
- oracle 多行数据合并成一行数据
相思子~
数据库oracle数据库database
前言划水的时候看到有人问了这个问题,顺手写个sql记录一下。原sql数据(多行)selectnullasv1_name,1asv1,'名称2'asv2_name,2asv2fromdualunionallselect'名称3'asv1_name,3asv1,'名称4'asv2_name,4asv2fromdual合并后select(wm_concat(a.v1_name))asv1_name,(w
- 1.1初识分组查询
寒枝旧廊
在说分组查询之前我们先了解一下什么是分组函数。概念时间到,咚沙卡拉卡。分组函数作用于一组数据,并对一组数据返回一个值。例如求出员工表中的工资最大值。说完了没用的概念我们来说点有用的东西,来讲一下分组函数的使用吧。我们常用的分组函数有:AVG(平均值)、SUM(求和)、MIN(最小值)、MAX(最大值)、COUNT(求个数)以及WM_CONCAT(行转列)举个栗子介绍下AVG函数和SUM函数【求员工
- Oracle——字符串聚合
jc_hook
数据库数据库oraclesql
一直以来对于聚合还是停留在数字上的聚合,遇到了在Oracle数据库中实现字符串聚合的问题,记录一下。在不写自定义函数的情况下,使用**wm_concat(字段名)**这个方法便可以实现字符串的聚合。该函数是Oracle的内置函数,会使用’,'将拼接字段内容隔开在11g版本使用时需要用to_char方法对结果进行类型转换,否则结果为变成为clob类型的数据示例:idnameclass1tom1班2j
- Oracle多行数据合并为一行数据,并将列数据转为字段名
herozhi0821
oracle数据库
Oracle多行数据合并为一行数据实现查询效果原数据方式一:MAX()数据效果SQL方式二:LISTAGG()数据效果方式三:WM_CONCAT()数据效果实现查询效果原数据FZPROJECTVALUE1电脑$16001手机$121导管$12电脑$22手机$22方式一:MAX()数据效果电脑电脑手机导管1$1600$12$12$2$22SQL根据FZ字段筛选并分组,MAX支持字符内容,SUN()同
- wm_concat的源代码
ok060
oracle数据库
CREATEORREPLACETYPEwm_concat_implAUTHIDCURRENT_USERASOBJECT(curr_strVARCHAR2(32767),STATICFUNCTIONodciaggregateinitialize(sctxINOUTwm_concat_impl)RETURNNUMBER,MEMBERFUNCTIONodciaggregateiterate(SELFIN
- Oracle函数之LISTAGG
践行见远
oraclewm_concatlistagg列转行
原文链接:https://www.cnblogs.com/ivictor/p/4654267.html前面刚说了wm_concat函数,没过几天用的时候,就报这个函数找不到了。于是有找到了新的替代函数,listagg,而且用起来更好用了。下面我们来看看其具体用法。用法:对其作用,官方文档的解释如下:Foraspecifiedmeasure,LISTAGGordersdatawithineachgr
- 解决Oracle高版本 ORA-00904: “WM_CONCAT“: 标识符无效
二叉平衡木
oracle数据库dba
原因:缺少WM_CONCAT函数解决方案:创接一个使用sqlplus/assysdba登录数据库--创建wm_concat函数--首先使用dba账号登录oracle数据库--解锁wmsys用户alteruserwmsysaccountunlock;--并为wmsys用户授权,可根据需要授权,不建议授权所有权限grantallprivilegestowmsys;--如果不知道wmsys用户的密码,可
- windows下源码安装golang
616050468
golang安装golang环境windows
系统: 64位win7, 开发环境:sublime text 2, go版本: 1.4.1
1. 安装前准备(gcc, gdb, git)
golang在64位系
- redis批量删除带空格的key
bylijinnan
redis
redis批量删除的通常做法:
redis-cli keys "blacklist*" | xargs redis-cli del
上面的命令在key的前后没有空格时是可以的,但有空格就不行了:
$redis-cli keys "blacklist*"
1) "blacklist:12:
[email protected]
- oracle正则表达式的用法
0624chenhong
oracle正则表达式
方括号表达示
方括号表达式
描述
[[:alnum:]]
字母和数字混合的字符
[[:alpha:]]
字母字符
[[:cntrl:]]
控制字符
[[:digit:]]
数字字符
[[:graph:]]
图像字符
[[:lower:]]
小写字母字符
[[:print:]]
打印字符
[[:punct:]]
标点符号字符
[[:space:]]
- 2048源码(核心算法有,缺少几个anctionbar,以后补上)
不懂事的小屁孩
2048
2048游戏基本上有四部分组成,
1:主activity,包含游戏块的16个方格,上面统计分数的模块
2:底下的gridview,监听上下左右的滑动,进行事件处理,
3:每一个卡片,里面的内容很简单,只有一个text,记录显示的数字
4:Actionbar,是游戏用重新开始,设置等功能(这个在底下可以下载的代码里面还没有实现)
写代码的流程
1:设计游戏的布局,基本是两块,上面是分
- jquery内部链式调用机理
换个号韩国红果果
JavaScriptjquery
只需要在调用该对象合适(比如下列的setStyles)的方法后让该方法返回该对象(通过this 因为一旦一个函数称为一个对象方法的话那么在这个方法内部this(结合下面的setStyles)指向这个对象)
function create(type){
var element=document.createElement(type);
//this=element;
- 你订酒店时的每一次点击 背后都是NoSQL和云计算
蓝儿唯美
NoSQL
全球最大的在线旅游公司Expedia旗下的酒店预订公司,它运营着89个网站,跨越68个国家,三年前开始实验公有云,以求让客户在预订网站上查询假期酒店时得到更快的信息获取体验。
云端本身是用于驱动网站的部分小功能的,如搜索框的自动推荐功能,还能保证处理Hotels.com服务的季节性需求高峰整体储能。
Hotels.com的首席技术官Thierry Bedos上个月在伦敦参加“2015 Clou
- java笔记1
a-john
java
1,面向对象程序设计(Object-oriented Propramming,OOP):java就是一种面向对象程序设计。
2,对象:我们将问题空间中的元素及其在解空间中的表示称为“对象”。简单来说,对象是某个类型的实例。比如狗是一个类型,哈士奇可以是狗的一个实例,也就是对象。
3,面向对象程序设计方式的特性:
3.1 万物皆为对象。
- C语言 sizeof和strlen之间的那些事 C/C++软件开发求职面试题 必备考点(一)
aijuans
C/C++求职面试必备考点
找工作在即,以后决定每天至少写一个知识点,主要是记录,逼迫自己动手、总结加深印象。当然如果能有一言半语让他人收益,后学幸运之至也。如有错误,还希望大家帮忙指出来。感激不尽。
后学保证每个写出来的结果都是自己在电脑上亲自跑过的,咱人笨,以前学的也半吊子。很多时候只能靠运行出来的结果再反过来
- 程序员写代码时就不要管需求了吗?
asia007
程序员不能一味跟需求走
编程也有2年了,刚开始不懂的什么都跟需求走,需求是怎样就用代码实现就行,也不管这个需求是否合理,是否为较好的用户体验。当然刚开始编程都会这样,但是如果有了2年以上的工作经验的程序员只知道一味写代码,而不在写的过程中思考一下这个需求是否合理,那么,我想这个程序员就只能一辈写敲敲代码了。
我的技术不是很好,但是就不代
- Activity的四种启动模式
百合不是茶
android栈模式启动Activity的标准模式启动栈顶模式启动单例模式启动
android界面的操作就是很多个activity之间的切换,启动模式决定启动的activity的生命周期 ;
启动模式xml中配置
<activity android:name=".MainActivity" android:launchMode="standard&quo
- Spring中@Autowired标签与@Resource标签的区别
bijian1013
javaspring@Resource@Autowired@Qualifier
Spring不但支持自己定义的@Autowired注解,还支持由JSR-250规范定义的几个注解,如:@Resource、 @PostConstruct及@PreDestroy。
1. @Autowired @Autowired是Spring 提供的,需导入 Package:org.springframewo
- Changes Between SOAP 1.1 and SOAP 1.2
sunjing
ChangesEnableSOAP 1.1SOAP 1.2
JAX-WS
SOAP Version 1.2 Part 0: Primer (Second Edition)
SOAP Version 1.2 Part 1: Messaging Framework (Second Edition)
SOAP Version 1.2 Part 2: Adjuncts (Second Edition)
Which style of WSDL
- 【Hadoop二】Hadoop常用命令
bit1129
hadoop
以Hadoop运行Hadoop自带的wordcount为例,
hadoop脚本位于/home/hadoop/hadoop-2.5.2/bin/hadoop,需要说明的是,这些命令的使用必须在Hadoop已经运行的情况下才能执行
Hadoop HDFS相关命令
hadoop fs -ls
列出HDFS文件系统的第一级文件和第一级
- java异常处理(初级)
白糖_
javaDAOspring虚拟机Ajax
从学习到现在从事java开发一年多了,个人觉得对java只了解皮毛,很多东西都是用到再去慢慢学习,编程真的是一项艺术,要完成一段好的代码,需要懂得很多。
最近项目经理让我负责一个组件开发,框架都由自己搭建,最让我头疼的是异常处理,我看了一些网上的源码,发现他们对异常的处理不是很重视,研究了很久都没有找到很好的解决方案。后来有幸看到一个200W美元的项目部分源码,通过他们对异常处理的解决方案,我终
- 记录整理-工作问题
braveCS
工作
1)那位同学还是CSV文件默认Excel打开看不到全部结果。以为是没写进去。同学甲说文件应该不分大小。后来log一下原来是有写进去。只是Excel有行数限制。那位同学进步好快啊。
2)今天同学说写文件的时候提示jvm的内存溢出。我马上反应说那就改一下jvm的内存大小。同学说改用分批处理了。果然想问题还是有局限性。改jvm内存大小只能暂时地解决问题,以后要是写更大的文件还是得改内存。想问题要长远啊
- org.apache.tools.zip实现文件的压缩和解压,支持中文
bylijinnan
apache
刚开始用java.util.Zip,发现不支持中文(网上有修改的方法,但比较麻烦)
后改用org.apache.tools.zip
org.apache.tools.zip的使用网上有更简单的例子
下面的程序根据实际需求,实现了压缩指定目录下指定文件的方法
import java.io.BufferedReader;
import java.io.BufferedWrit
- 读书笔记-4
chengxuyuancsdn
读书笔记
1、JSTL 核心标签库标签
2、避免SQL注入
3、字符串逆转方法
4、字符串比较compareTo
5、字符串替换replace
6、分拆字符串
1、JSTL 核心标签库标签共有13个,
学习资料:http://www.cnblogs.com/lihuiyy/archive/2012/02/24/2366806.html
功能上分为4类:
(1)表达式控制标签:out
- [物理与电子]半导体教材的一个小问题
comsci
问题
各种模拟电子和数字电子教材中都有这个词汇-空穴
书中对这个词汇的解释是; 当电子脱离共价键的束缚成为自由电子之后,共价键中就留下一个空位,这个空位叫做空穴
我现在回过头翻大学时候的教材,觉得这个
- Flashback Database --闪回数据库
daizj
oracle闪回数据库
Flashback 技术是以Undo segment中的内容为基础的, 因此受限于UNDO_RETENTON参数。要使用flashback 的特性,必须启用自动撤销管理表空间。
在Oracle 10g中, Flash back家族分为以下成员: Flashback Database, Flashback Drop,Flashback Query(分Flashback Query,Flashbac
- 简单排序:插入排序
dieslrae
插入排序
public void insertSort(int[] array){
int temp;
for(int i=1;i<array.length;i++){
temp = array[i];
for(int k=i-1;k>=0;k--)
- C语言学习六指针小示例、一维数组名含义,定义一个函数输出数组的内容
dcj3sjt126com
c
# include <stdio.h>
int main(void)
{
int * p; //等价于 int *p 也等价于 int* p;
int i = 5;
char ch = 'A';
//p = 5; //error
//p = &ch; //error
//p = ch; //error
p = &i; //
- centos下php redis扩展的安装配置3种方法
dcj3sjt126com
redis
方法一
1.下载php redis扩展包 代码如下 复制代码
#wget http://redis.googlecode.com/files/redis-2.4.4.tar.gz
2 tar -zxvf 解压压缩包,cd /扩展包 (进入扩展包然后 运行phpize 一下是我环境中phpize的目录,/usr/local/php/bin/phpize (一定要
- 线程池(Executors)
shuizhaosi888
线程池
在java类库中,任务执行的主要抽象不是Thread,而是Executor,将任务的提交过程和执行过程解耦
public interface Executor {
void execute(Runnable command);
}
public class RunMain implements Executor{
@Override
pub
- openstack 快速安装笔记
haoningabc
openstack
前提是要配置好yum源
版本icehouse,操作系统redhat6.5
最简化安装,不要cinder和swift
三个节点
172 control节点keystone glance horizon
173 compute节点nova
173 network节点neutron
control
/etc/sysctl.conf
net.ipv4.ip_forward =
- 从c面向对象的实现理解c++的对象(二)
jimmee
C++面向对象虚函数
1. 类就可以看作一个struct,类的方法,可以理解为通过函数指针的方式实现的,类对象分配内存时,只分配成员变量的,函数指针并不需要分配额外的内存保存地址。
2. c++中类的构造函数,就是进行内存分配(malloc),调用构造函数
3. c++中类的析构函数,就时回收内存(free)
4. c++是基于栈和全局数据分配内存的,如果是一个方法内创建的对象,就直接在栈上分配内存了。
专门在
- 如何让那个一个div可以拖动
lingfeng520240
html
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml
- 第10章 高级事件(中)
onestopweb
事件
index.html
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/
- 计算两个经纬度之间的距离
roadrunners
计算纬度LBS经度距离
要解决这个问题的时候,到网上查了很多方案,最后计算出来的都与百度计算出来的有出入。下面这个公式计算出来的距离和百度计算出来的距离是一致的。
/**
*
* @param longitudeA
* 经度A点
* @param latitudeA
* 纬度A点
* @param longitudeB
*
- 最具争议的10个Java话题
tomcat_oracle
java
1、Java8已经到来。什么!? Java8 支持lambda。哇哦,RIP Scala! 随着Java8 的发布,出现很多关于新发布的Java8是否有潜力干掉Scala的争论,最终的结论是远远没有那么简单。Java8可能已经在Scala的lambda的包围中突围,但Java并非是函数式编程王位的真正觊觎者。
2、Java 9 即将到来
Oracle早在8月份就发布
- zoj 3826 Hierarchical Notation(模拟)
阿尔萨斯
rar
题目链接:zoj 3826 Hierarchical Notation
题目大意:给定一些结构体,结构体有value值和key值,Q次询问,输出每个key值对应的value值。
解题思路:思路很简单,写个类词法的递归函数,每次将key值映射成一个hash值,用map映射每个key的value起始终止位置,预处理完了查询就很简单了。 这题是最后10分钟出的,因为没有考虑value为{}的情