- 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用户的密码,可
- Java开发中,spring mvc 的线程怎么调用?
小麦麦子
springmvc
今天逛知乎,看到最近很多人都在问spring mvc 的线程http://www.maiziedu.com/course/java/ 的启动问题,觉得挺有意思的,那哥们儿问的也听仔细,下面的回答也很详尽,分享出来,希望遇对遇到类似问题的Java开发程序猿有所帮助。
问题:
在用spring mvc架构的网站上,设一线程在虚拟机启动时运行,线程里有一全局
- maven依赖范围
bitcarter
maven
1.test 测试的时候才会依赖,编译和打包不依赖,如junit不被打包
2.compile 只有编译和打包时才会依赖
3.provided 编译和测试的时候依赖,打包不依赖,如:tomcat的一些公用jar包
4.runtime 运行时依赖,编译不依赖
5.默认compile
依赖范围compile是支持传递的,test不支持传递
1.传递的意思是项目A,引用
- Jaxb org.xml.sax.saxparseexception : premature end of file
darrenzhu
xmlprematureJAXB
如果在使用JAXB把xml文件unmarshal成vo(XSD自动生成的vo)时碰到如下错误:
org.xml.sax.saxparseexception : premature end of file
很有可能时你直接读取文件为inputstream,然后将inputstream作为构建unmarshal需要的source参数。InputSource inputSource = new In
- CSS Specificity
周凡杨
html权重Specificitycss
有时候对于页面元素设置了样式,可为什么页面的显示没有匹配上呢? because specificity
CSS 的选择符是有权重的,当不同的选择符的样式设置有冲突时,浏览器会采用权重高的选择符设置的样式。
规则:
HTML标签的权重是1
Class 的权重是10
Id 的权重是100
- java与servlet
g21121
servlet
servlet 搞java web开发的人一定不会陌生,而且大家还会时常用到它。
下面是java官方网站上对servlet的介绍: java官网对于servlet的解释 写道
Java Servlet Technology Overview Servlets are the Java platform technology of choice for extending and enha
- eclipse中安装maven插件
510888780
eclipsemaven
1.首先去官网下载 Maven:
http://www.apache.org/dyn/closer.cgi/maven/binaries/apache-maven-3.2.3-bin.tar.gz
下载完成之后将其解压,
我将解压后的文件夹:apache-maven-3.2.3,
并将它放在 D:\tools目录下,
即 maven 最终的路径是:D:\tools\apache-mave
- jpa@OneToOne关联关系
布衣凌宇
jpa
Nruser里的pruserid关联到Pruser的主键id,实现对一个表的增删改,另一个表的数据随之增删改。
Nruser实体类
//*****************************************************************
@Entity
@Table(name="nruser")
@DynamicInsert @Dynam
- 我的spring学习笔记11-Spring中关于声明式事务的配置
aijuans
spring事务配置
这两天学到事务管理这一块,结合到之前的terasoluna框架,觉得书本上讲的还是简单阿。我就把我从书本上学到的再结合实际的项目以及网上看到的一些内容,对声明式事务管理做个整理吧。我看得Spring in Action第二版中只提到了用TransactionProxyFactoryBean和<tx:advice/>,定义注释驱动这三种,我承认后两种的内容很好,很强大。但是实际的项目当中
- java 动态代理简单实现
antlove
javahandlerproxydynamicservice
dynamicproxy.service.HelloService
package dynamicproxy.service;
public interface HelloService {
public void sayHello();
}
dynamicproxy.service.impl.HelloServiceImpl
package dynamicp
- JDBC连接数据库
百合不是茶
JDBC编程JAVA操作oracle数据库
如果我们要想连接oracle公司的数据库,就要首先下载oralce公司的驱动程序,将这个驱动程序的jar包导入到我们工程中;
JDBC链接数据库的代码和固定写法;
1,加载oracle数据库的驱动;
&nb
- 单例模式中的多线程分析
bijian1013
javathread多线程java多线程
谈到单例模式,我们立马会想到饿汉式和懒汉式加载,所谓饿汉式就是在创建类时就创建好了实例,懒汉式在获取实例时才去创建实例,即延迟加载。
饿汉式:
package com.bijian.study;
public class Singleton {
private Singleton() {
}
// 注意这是private 只供内部调用
private static
- javascript读取和修改原型特别需要注意原型的读写不具有对等性
bijian1013
JavaScriptprototype
对于从原型对象继承而来的成员,其读和写具有内在的不对等性。比如有一个对象A,假设它的原型对象是B,B的原型对象是null。如果我们需要读取A对象的name属性值,那么JS会优先在A中查找,如果找到了name属性那么就返回;如果A中没有name属性,那么就到原型B中查找name,如果找到了就返回;如果原型B中也没有
- 【持久化框架MyBatis3六】MyBatis3集成第三方DataSource
bit1129
dataSource
MyBatis内置了数据源的支持,如:
<environments default="development">
<environment id="development">
<transactionManager type="JDBC" />
<data
- 我程序中用到的urldecode和base64decode,MD5
bitcarter
cMD5base64decodeurldecode
这里是base64decode和urldecode,Md5在附件中。因为我是在后台所以需要解码:
string Base64Decode(const char* Data,int DataByte,int& OutByte)
{
//解码表
const char DecodeTable[] =
{
0, 0, 0, 0, 0, 0
- 腾讯资深运维专家周小军:QQ与微信架构的惊天秘密
ronin47
社交领域一直是互联网创业的大热门,从PC到移动端,从OICQ、MSN到QQ。到了移动互联网时代,社交领域应用开始彻底爆发,直奔黄金期。腾讯在过去几年里,社交平台更是火到爆,QQ和微信坐拥几亿的粉丝,QQ空间和朋友圈各种刷屏,写心得,晒照片,秀视频,那么谁来为企鹅保驾护航呢?支撑QQ和微信海量数据背后的架构又有哪些惊天内幕呢?本期大讲堂的内容来自今年2月份ChinaUnix对腾讯社交网络运营服务中心
- java-69-旋转数组的最小元素。把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。输入一个排好序的数组的一个旋转,输出旋转数组的最小元素
bylijinnan
java
public class MinOfShiftedArray {
/**
* Q69 旋转数组的最小元素
* 把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。输入一个排好序的数组的一个旋转,输出旋转数组的最小元素。
* 例如数组{3, 4, 5, 1, 2}为{1, 2, 3, 4, 5}的一个旋转,该数组的最小值为1。
*/
publ
- 看博客,应该是有方向的
Cb123456
反省看博客
看博客,应该是有方向的:
我现在就复习以前的,在补补以前不会的,现在还不会的,同时完善完善项目,也看看别人的博客.
我刚突然想到的:
1.应该看计算机组成原理,数据结构,一些算法,还有关于android,java的。
2.对于我,也快大四了,看一些职业规划的,以及一些学习的经验,看看别人的工作总结的.
为什么要写
- [开源与商业]做开源项目的人生活上一定要朴素,尽量减少对官方和商业体系的依赖
comsci
开源项目
为什么这样说呢? 因为科学和技术的发展有时候需要一个平缓和长期的积累过程,但是行政和商业体系本身充满各种不稳定性和不确定性,如果你希望长期从事某个科研项目,但是却又必须依赖于某种行政和商业体系,那其中的过程必定充满各种风险。。。
所以,为避免这种不确定性风险,我
- 一个 sql优化 ([精华] 一个查询优化的分析调整全过程!很值得一看 )
cwqcwqmax9
sql
见 http://www.itpub.net/forum.php?mod=viewthread&tid=239011
Web翻页优化实例
提交时间: 2004-6-18 15:37:49 回复 发消息
环境:
Linux ve
- Hibernat and Ibatis
dashuaifu
Hibernateibatis
Hibernate VS iBATIS 简介 Hibernate 是当前最流行的O/R mapping框架,当前版本是3.05。它出身于sf.net,现在已经成为Jboss的一部分了 iBATIS 是另外一种优秀的O/R mapping框架,当前版本是2.0。目前属于apache的一个子项目了。 相对Hibernate“O/R”而言,iBATIS 是一种“Sql Mappi
- 备份MYSQL脚本
dcj3sjt126com
mysql
#!/bin/sh
# this shell to backup mysql
#
[email protected] (QQ:1413161683 DuChengJiu)
_dbDir=/var/lib/mysql/
_today=`date +%w`
_bakDir=/usr/backup/$_today
[ ! -d $_bakDir ] && mkdir -p
- iOS第三方开源库的吐槽和备忘
dcj3sjt126com
ios
转自
ibireme的博客 做iOS开发总会接触到一些第三方库,这里整理一下,做一些吐槽。 目前比较活跃的社区仍旧是Github,除此以外也有一些不错的库散落在Google Code、SourceForge等地方。由于Github社区太过主流,这里主要介绍一下Github里面流行的iOS库。 首先整理了一份
Github上排名靠
- html wlwmanifest.xml
eoems
htmlxml
所谓优化wp_head()就是把从wp_head中移除不需要元素,同时也可以加快速度。
步骤:
加入到function.php
remove_action('wp_head', 'wp_generator');
//wp-generator移除wordpress的版本号,本身blog的版本号没什么意义,但是如果让恶意玩家看到,可能会用官网公布的漏洞攻击blog
remov
- 浅谈Java定时器发展
hacksin
java并发timer定时器
java在jdk1.3中推出了定时器类Timer,而后在jdk1.5后由Dou Lea从新开发出了支持多线程的ScheduleThreadPoolExecutor,从后者的表现来看,可以考虑完全替代Timer了。
Timer与ScheduleThreadPoolExecutor对比:
1.
Timer始于jdk1.3,其原理是利用一个TimerTask数组当作队列
- 移动端页面侧边导航滑入效果
ini
jqueryWebhtml5cssjavascirpt
效果体验:http://hovertree.com/texiao/mobile/2.htm可以使用移动设备浏览器查看效果。效果使用到jquery-2.1.4.min.js,该版本的jQuery库是用于支持HTML5的浏览器上,不再兼容IE8以前的浏览器,现在移动端浏览器一般都支持HTML5,所以使用该jQuery没问题。HTML文件代码:
<!DOCTYPE html>
<h
- AspectJ+Javasist记录日志
kane_xie
aspectjjavasist
在项目中碰到这样一个需求,对一个服务类的每一个方法,在方法开始和结束的时候分别记录一条日志,内容包括方法名,参数名+参数值以及方法执行的时间。
@Override
public String get(String key) {
// long start = System.currentTimeMillis();
// System.out.println("Be
- redis学习笔记
MJC410621
redisNoSQL
1)nosql数据库主要由以下特点:非关系型的、分布式的、开源的、水平可扩展的。
1,处理超大量的数据
2,运行在便宜的PC服务器集群上,
3,击碎了性能瓶颈。
1)对数据高并发读写。
2)对海量数据的高效率存储和访问。
3)对数据的高扩展性和高可用性。
redis支持的类型:
Sring 类型
set name lijie
get name lijie
set na
- 使用redis实现分布式锁
qifeifei
在多节点的系统中,如何实现分布式锁机制,其中用redis来实现是很好的方法之一,我们先来看一下jedis包中,有个类名BinaryJedis,它有个方法如下:
public Long setnx(final byte[] key, final byte[] value) {
checkIsInMulti();
client.setnx(key, value);
ret
- BI并非万能,中层业务管理报表要另辟蹊径
张老师的菜
大数据BI商业智能信息化
BI是商业智能的缩写,是可以帮助企业做出明智的业务经营决策的工具,其数据来源于各个业务系统,如ERP、CRM、SCM、进销存、HER、OA等。
BI系统不同于传统的管理信息系统,他号称是一个整体应用的解决方案,是融入管理思想的强大系统:有着系统整体的设计思想,支持对所有
- 安装rvm后出现rvm not a function 或者ruby -v后提示没安装ruby的问题
wudixiaotie
function
1.在~/.bashrc最后加入
[[ -s "$HOME/.rvm/scripts/rvm" ]] && source "$HOME/.rvm/scripts/rvm"
2.重新启动terminal输入:
rvm use ruby-2.2.1 --default
把当前安装的ruby版本设为默