有以下Hive表的定义:
create table topic_recommend_score (
category_id int,
topic_id bigint,
score double,
rank int
);
这张表是我们业务里话题推荐分值表的简化版本。category_id代表分类ID,topic_id是话题ID,score是评分值。rank代表每个分类下话题分值的排名,用开窗函数计算出来的: row_number() over(partition by t.category_id order by t.score desc)
在对外提供推荐结果时,我们会将每个小组下排名前1000的话题ID取出,拼成一个逗号分隔的字符串,处理之后送入HBase供调用方查询。拼合的SQL语句如下:
select category_id,
concat_ws(',',collect_list(cast(topic_id as string)))
from topic_recommend_score
where rank >= 1 and rank <= 1000
group by category_id;
看起来没什么问题?但实际上是错误的。输出结果中总会有一些category_id对应的列表顺序异常,比如本来排名正数与排名倒数的两批ID调换了位置,即rank变成了n-3, n-2, n-1, n, 5, 6, 7, ..., n-4, 1, 2, 3, 4
。
产生这个问题的根本原因自然在MapReduce,如果启动了多于一个mapper/reducer来处理数据,select出来的数据顺序就几乎肯定与原始顺序不同了。考虑把mapper数固定成1比较麻烦(见我之前写的那篇Hive调优文章),也不现实,所以要迂回地解决问题:把rank加进来再进行一次排序,拼接完之后把rank去掉。如下:
select category_id,
regexp_replace(
concat_ws(',',
sort_array(
collect_list(
concat_ws(':',lpad(cast(rank as string),5,'0'),cast(topic_id as string))
)
)
),
'\\d+\:','')
from topic_recommend_score
where rank >= 1 and rank <= 1000
group by category_id;
这里将rank放在了topic_id之前,用冒号分隔,然后用sort_array函数对collect_list之后的结果进行排序(只支持升序)。特别注意,rank必须要在高位补足够的0对齐,因为排序的是字符串而不是数字,如果不补0的话,按字典序排序就会变成1, 10, 11, 12, 13, 2, 3, 4...
,又不对了。 将排序的结果拼起来之后,用regexp_replace函数替换掉冒号及其前面的数字,大功告成。
顺便看一下Hive源码中collect_list和collect_set函数对应的逻辑吧。
public class GenericUDAFMkCollectionEvaluator extends GenericUDAFEvaluator
implements Serializable {
private static final long serialVersionUID = 1l;
enum BufferType { SET, LIST }
// For PARTIAL1 and COMPLETE: ObjectInspectors for original data
private transient PrimitiveObjectInspector inputOI;
// For PARTIAL2 and FINAL: ObjectInspectors for partial aggregations (list
// of objs)
private transient StandardListObjectInspector loi;
private transient ListObjectInspector internalMergeOI;
private BufferType bufferType;
//needed by kyro
public GenericUDAFMkCollectionEvaluator() {
}
public GenericUDAFMkCollectionEvaluator(BufferType bufferType){
this.bufferType = bufferType;
}
@Override
public ObjectInspector init(Mode m, ObjectInspector[] parameters)
throws HiveException {
super.init(m, parameters);
// init output object inspectors
// The output of a partial aggregation is a list
if (m == Mode.PARTIAL1) {
inputOI = (PrimitiveObjectInspector) parameters[0];
return ObjectInspectorFactory
.getStandardListObjectInspector((PrimitiveObjectInspector) ObjectInspectorUtils
.getStandardObjectInspector(inputOI));
} else {
if (!(parameters[0] instanceof ListObjectInspector)) {
//no map aggregation.
inputOI = (PrimitiveObjectInspector) ObjectInspectorUtils
.getStandardObjectInspector(parameters[0]);
return (StandardListObjectInspector) ObjectInspectorFactory
.getStandardListObjectInspector(inputOI);
} else {
internalMergeOI = (ListObjectInspector) parameters[0];
inputOI = (PrimitiveObjectInspector) internalMergeOI.getListElementObjectInspector();
loi = (StandardListObjectInspector) ObjectInspectorUtils.getStandardObjectInspector(internalMergeOI);
return loi;
}
}
}
class MkArrayAggregationBuffer extends AbstractAggregationBuffer {
private Collection container;
public MkArrayAggregationBuffer() {
if (bufferType == BufferType.LIST){
container = new ArrayList();
} else if(bufferType == BufferType.SET){
container = new LinkedHashSet();
} else {
throw new RuntimeException("Buffer type unknown");
}
}
}
@Override
public void reset(AggregationBuffer agg) throws HiveException {
((MkArrayAggregationBuffer) agg).container.clear();
}
@Override
public AggregationBuffer getNewAggregationBuffer() throws HiveException {
MkArrayAggregationBuffer ret = new MkArrayAggregationBuffer();
return ret;
}
//mapside
@Override
public void iterate(AggregationBuffer agg, Object[] parameters)
throws HiveException {
assert (parameters.length == 1);
Object p = parameters[0];
if (p != null) {
MkArrayAggregationBuffer myagg = (MkArrayAggregationBuffer) agg;
putIntoCollection(p, myagg);
}
}
//mapside
@Override
public Object terminatePartial(AggregationBuffer agg) throws HiveException {
MkArrayAggregationBuffer myagg = (MkArrayAggregationBuffer) agg;
List ret = new ArrayList(myagg.container.size());
ret.addAll(myagg.container);
return ret;
}
@Override
public void merge(AggregationBuffer agg, Object partial)
throws HiveException {
MkArrayAggregationBuffer myagg = (MkArrayAggregationBuffer) agg;
List partialResult = (ArrayList) internalMergeOI.getList(partial);
if (partialResult != null) {
for(Object i : partialResult) {
putIntoCollection(i, myagg);
}
}
}
@Override
public Object terminate(AggregationBuffer agg) throws HiveException {
MkArrayAggregationBuffer myagg = (MkArrayAggregationBuffer) agg;
List ret = new ArrayList(myagg.container.size());
ret.addAll(myagg.container);
return ret;
}
private void putIntoCollection(Object p, MkArrayAggregationBuffer myagg) {
Object pCopy = ObjectInspectorUtils.copyToStandardObject(p, this.inputOI);
myagg.container.add(pCopy);
}
public BufferType getBufferType() {
return bufferType;
}
public void setBufferType(BufferType bufferType) {
this.bufferType = bufferType;
}
}
你可能感兴趣的:(HiveQL collect_list保持顺序小记)
小鹏汽车申请注册“P7 Ultra”商标 或为P7车型升级版铺路
大湾区经济门户网
汽车 媒体 人工智能 大数据
大湾区经济网品牌工程频道报道,据企查查APP显示,广东小鹏汽车科技有限公司近日提交“P7Ultra”商标注册申请,国际分类为运输工具,当前状态为“注册申请中”。业内推测,此举或为小鹏P7车型高端版本量产上市做准备。作为小鹏汽车主力车型,P7系列自2020年上市以来累计交付量已突破14万辆,2024年前4个月仍保持月均超2000辆销量。此次申请“Ultra”后缀商标,或延续其产品线升级策略——此前小
相似度计算
Panesle
python 人工智能 算法
1.余弦相似度计算(不区分向量方向,互换顺序也相同)sen_vec1=sbert.get_sentence_emb(context15)#向量化sen_vec1=sen_vec1*(1.0/(np.linalg.norm(sen_vec1)+0.00001))#normal化sen_vec2=sbert.get_sentence_emb(context14)#向量化sen_vec2=sen_vec
AdaBoost算法
Mr终游
机器学习 算法 决策树
目录一、核心原理:二、算法步骤三、关键优势:四.局限与解决五、代码示例(鸢尾花数据集)AdaBoost(AdaptiveBoosting)是一种经典的集成学习算法,通过组合多个弱分类器(如决策树)来构建强分类器。其核心思想是通过迭代优化残差(错误)和动态调整样本权重,逐步提升模型性能。以下是对AdaBoost的简明总结和关键要点:一、核心原理:提升法:通过顺序训练多个弱分类器,每轮专注修正前一个模
DeepSeek安装部署笔记(二)
山哥ol
笔记 运维 python
Bat批处理文件的编写第五步启动openWebUI的批处理编写1、下面的代码,复制到文本文件,再改扩展名2、这样,在桌面直接双击此文件运行第五步启动openWebUI的批处理编写1、下面的代码,复制到文本文件,再改扩展名@echooffREM关闭回显使界面更简洁setCONDA_ROOT=D:\condasetENV_NAME=openwebuiREM使用’/K’参数保持CMD窗口不关闭,并执行后
JAVA排序
荔枝吃吃
java 排序算法 算法
1.冒泡排序/***使用冒泡排序算法对整数数组进行排序*冒泡排序是一种简单的排序算法,它重复地遍历要排序的数列,*一次比较两个元素,如果它们的顺序错误就把它们交换过来*遍历数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成*这个算法的名字由来是因为越小(或越大)的元素会经过交换慢慢“浮”到数列的顶端**@paramarr待排序的整数数组*/publicstaticvoidbubb
Leetcode 刷题笔记1 动态规划part05
平乐君
leetcode 笔记 动态规划
开始完全背包不同于01背包,完全背包的特色在于元素可以重复拿取,因此在递归公式和遍历顺序上都有些许不同。leetcode518零钱兑换||在组合方式中所用到的递推公式是dp[j]=dp[j-coins[i]]+dp[j]对于coins[i]>j的情况,forjinrange(coin[i],amount+1)不会执行,即实现dp[i][j]=dp[i-1][j]classSolution:defc
动画 + 大白话讲清楚React渲染原理
梅花十三儿
react.js 前端 javascript
前言相信很多人跟我之前一样,看到源码两个字觉得触不可及,觉得离自己还很遥远,是需要非常多年的工作经验的大佬才能触及到的领域。就在去年我改变了这个想法,当时被react的几个生命周期执行顺序弄的睡不着觉,为什么有些时候生命周期的执行事与愿违?又为什么数组中必须要加上key属性?为啥在render中不能写setState等等问题…在一系列的问题中,我终于还是打开了那份久违的源码,并且Ctrl+F慢慢探
【无标题】四色定理拓扑证明的数学强化与物理深化框架
2301_81062744
拓扑学
###**四色定理拓扑证明的数学强化与物理深化框架**---####**一、拓扑收缩的数学严谨性补全**#####**1.1零点插入的平面性保持证明**-**Kuratowski定理应用**:验证插入零点后的图\(G'\)不含\(K_5\)或\(K_{3,3}\)子图。-**引理**:每次插入零点仅增加2度顶点,不改变图的平面类。-**证明**:设原图\(G\)为平面图,插入零点\(p\)将边\(
Go入门指南- 7.1数组声明和初始化
白小白的学习笔记
Go入门指南 golang 算法 数据结构
7.1.1概念数组是具有相同唯一类型的一组以编号且长度固定的数据项序列(这是一种同构的数据结构);这种类型可以是任意的原始类型例如整型、字符串或者自定义类型。数组长度必须是一个常量表达式,并且必须是一个非负整数。数组长度也是数组类型的一部分,所以[5]int和[10]int是属于不同类型的。数组的编译时值初始化是按照数组顺序完成的(如下)。注意事项如果我们想让数组元素类型为任意类型的话可以使用空接
数据机构 C语言实现队列(含代码详解 易懂)
码上好玩
/*数学模型参照《大话数据结构》队列部分!!!取余运算实现队列循环!!!*/#include#include#include#include#defineOK1#defineERROR0#defineTURE1#defineFALSE0#defineMAXSIZE20/*队列最大的成员个数即数组的长度*/typedefintStatus;typedefintQElemType;/*循环队列的顺序存
RabbitMQ如何保证消息的幂等性、可靠性、顺序性
zw791029369
消息队列MQ rabbitmq
如何保证消息的幂等性所谓的幂等性其实就是保证同一条消息不会重复或者重复消费了也不会对系统数据造成异常。出现消息重复消费的情况拿RabbitMQ来说的话,消费者在消费完成一条消息之后会向MQ回复一个ACK(可以配置自动ACK或者手动ACK)来告诉MQ这条消息已经消费了。假如当消费者消费完数据后,准备回执ACK时,系统挂掉了,MQ是不知道该条消息已经被消费了。所以重启之后MQ会再次发送该条消息,导致消
RabbitMQ 可靠性、重复消费、顺序性、消息积压解决方案
一堆土豆33
java-rabbitmq rabbitmq java
前言为什么引入消息队列?引入MQ给我们解决了一些问题,但同时又引入了一些复杂的问题,这些问题是大型项目中必须解决的重点,更重要的是,面试也经常问。实际上消息队列可以说是没法百分之百保证可靠性的!RabbitMQ提供的相关机制也只是在于缩小消息丢失的概率,或者说提供了消息丢失后的我们可以记录日志的功能。在解决这些问题时有必要明白一点,其实小公司业务量不大,并发量不高的情况下这些问题是几乎不会发生的.
力扣简单题系列:两个数组的交集(LeetCode 349)
Yohen-
力扣简单题 leetcode 算法 职场和发展
力扣简单题系列:两个数组的交集(LeetCode349)题目描述:给定两个数组nums1和nums2,返回它们的交集。输出结果中的每个元素是唯一的,且可以不考虑输出结果的顺序。示例:输入:nums1=[1,2,2,1],nums2=[2,2]输出:[2]输入:nums1=[4,9,5],nums2=[9,4,9,8,4]输出:[9,4]解题思路:这道题的核心是找到两个数组中共同出现的元素,并且结果
03.05 随手记
喜刷刷1999
javascript
1.什么是事件流?页面触发一个事件时,会按照一定的顺序来响应事件,事件的响应过程为事件流2.什么是作用域?规定变量和函数的可使用范围称作作用域每个函数都有一个作用域链,查找变量或者函数时,需要从局部作用域到全局作用域依次查找,这些作用域的集合称作作用域链。3.什么是执行栈,什么是执行上下文?执行上下文分为:全局执行上下文创建一个全局的window对象,并规定this指向window,执行js的时候
PTA拼题A2023跨年挑战赛
0白露
C c语言
防疫打卡为了鼓励大家做好个人防护,某群开启了“防疫打卡”活动,群里最后一个被新冠病毒感染的群员将获得群主赠送的红包一个。具体规则如下:每天所有群员均需打卡,如有人未打卡视为退出活动(无获奖资格);打卡为今日体温,体温≥37.5°C的失去获得红包的资格;当打卡剩余最后一人时,无论该人状态如何都将自动获得红包,同一日打卡按给定的消息顺序计算,不打卡的排在最后。保证不会出现打卡人全部失去资格,且超过一人
C/C++ 面试大纲
八月的雨季997
C++ / C++11 c++
文章目录C程序运行数组指针字符串内存模型内存对齐内存泄露内存拷贝链表文件排序快排选择冒泡折半C++封装继承多态类型转化:默认构造继承方式构造顺序虚继承多态:虚析构函数虚构造C++11lambdafunctor移动构造智能指针:多线程STLvectorlistsetmultiset哈希表unorderd_setmapmultimapunorderd_map仿函数算法设计模式设计原则:单例模式单例模式
学习c语言的第十天
流川飞
学习 c语言
今天学习的是一维数组和二维数组,我对二维数组的理解是:在进行使用时理解为矩阵,在进行储存时和一维数组一样按顺序依次存放,所以要注意的是,定义二维数组时不能缺少列数的定义,因为列数可以区分出哪些数组为一行。今日学习时长:2h
Azkaban其一,介绍、体系架构和安装
出发行进
# Azkaban Azkaban linux
目录一、简介二、Azkaban的体系结构三、Azkaban的安装步骤1、上传,解压2、生成mysql的元数据3、配置web-server4、配置exec-server5、修改所有的.sh的执行权限一、简介遇到了什么问题才会使用Azkaban?比如:想启动hadoop集群先启动zk集群,再启动hdfs,再启动yarn,再启动日志系统工作过程中总会遇到多个脚本执行的时候有顺序。任务可以有一个编排的工具
开源模型应用落地-qwen2-7b-instruct-LoRA微调-LLaMA-Factory-单机多卡-RTX 4090双卡(五)
开源技术探险家
开源模型-实际应用落地 # 开源模型-微调实战密码 自然语言处理 深度学习 语言模型
一、前言本篇文章将使用LLaMA-Factory去高效微调QWen2系列模型,通过阅读本文,您将能够更好地掌握这些关键技术,理解其中的关键技术要点,并应用于自己的项目中。二、术语介绍2.1.LoRA微调LoRA(Low-RankAdaptation)用于微调大型语言模型(LLM)。是一种有效的自适应策略,它不会引入额外的推理延迟,并在保持模型质量的同时显着减少下游任务的可训练参数数量。2.2.参数
每日一题——缺失的第一个正数
tt555555555555
面经 算法题 C语言 算法 数据结构 leetcode
缺失的第一个正数问题描述示例输入与输出解题思路代码实现代码解析1.**原地交换逻辑**2.**查找缺失的正整数**3.**特殊情况**示例分析示例1示例2示例3注意事项错误的交换顺序正确的交换顺序核心区别总结问题描述给定一个未排序的整数数组nums,请你找出其中没有出现的最小正整数。要求实现时间复杂度为O(n),并且只使用常数级别的额外空间。示例输入:nums=[1,2,0]输出:3解释:范围[1
初识Redis
我不是少爷.
Redis redis 数据库 缓存
目录导航Redis核心架构解析多平台环境搭建指南可视化工具生态集群架构设计与实现虚拟化环境构建方案版本演进与6.0特性1.Redis核心架构解析1.1数据模型革命基础类型二进制安全字段存储嵌套结构顺序存储阻塞操作去重集合集合运算排序集合String计数器图片缓存Hash用户画像商品详情List消息队列任务调度Set标签系统好友推荐ZSet实时排行榜1.2持久化双引擎对比特性RDB快照AOF日志持久
数据结构笔记——第一章:数据结构基础
米布偷吃小饼干
数据结构笔记 数据结构 c语言
1.数据结构基础1.1什么是数据结构1.1.1关于数据组织—例:图书摆放例1:如何在书架上摆放图书?分类二分查找解决问题方法的效率,跟数据的组织方式有关。1.1.2关于空间使用—例:PrintN函数实现例2:写程序实现一个函数PrintN,使传入一个正整数为N的参数后,能顺序打印从1到N的全部正整数。/*循环实现*/voidPrintN(intN){inti;for(i=1;ivoidPrintN
大白话Webpack 配置与使用的详细步骤和插件应用
IT木昜
大白话前端高频面试题 webpack 前端 node.js
大白话Webpack配置与使用的详细步骤和插件应用啥是WebpackWebpack就像是一个超级管家,在我们开发网页的时候,会有各种各样的文件,像JavaScript文件、CSS文件、图片等等。这些文件就像是家里的各种物品,分散在不同的地方,而且有的物品还得按照特定顺序摆放、处理之后才能正常使用。Webpack这个管家就负责把这些分散的文件收集起来,按照我们的要求进行打包、处理,最后变成一个或几个
c语言中的主要知识点
C7211BA
c语言 开发语言
一、基础语法与结构程序结构包含顺序结构、选择结构(if/switch)、循环结构(for/while/do-while)。程序必须包含且仅有一个main函数作为入口。数据类型与变量基本类型:整型(int、long)、浮点型(float、double)、字符型(char)。构造类型:数组(需注意初始化规则)、结构体、共用体。常量与变量:常量需通过const或#define定义;变量需先定义后使用,区
SpringBoot集成Flink-CDC
whiteBrocade
spring flink mysql java-activemq kafka elasticsearch
FlinkCDCCDC相关介绍CDC是什么?CDC是ChangeDataCapture(变更数据获取)的简称。核心思想是,监测并捕获数据库的变动(包括数据或数据表的插入、更新以及删除等),将这些变更按发生的顺序完整记录下来,写入到MQ以供其他服务进行订阅及消费CDC分类CDC主要分为基于查询和基于Binlog基于查询基于Binlog开源产品Sqoop、DataXCanal、Maxwell、Debe
ClickHouse单机安装与一些安装时可能出现的问题解决方法
遇安.YuAn
ClickHouse 大数据平台组件搭建 clickhouse 服务器 linux 环境搭建
博主这里的ClickHouse版本为21.9.4.351、将四个安装包上传并解压(解压顺序建议按照博主的解压顺序):1.1、tar-zxvfclickhouse-common-static-21.9.4.35.tgz进入:cdclickhouse-common-static-21.9.4.35cdinstall启动脚本:./doinst.sh启动时如果报错:cp:无法创建普通文件“/usr/bin
(动态规划)2915. 和为目标值的最长子序列的长度
蹉跎x
力扣 数据结构 leetcode 算法
给你一个下标从0开始的整数数组nums和一个整数target。返回和为target的nums子序列中,子序列长度的最大值。如果不存在和为target的子序列,返回-1。子序列指的是从原数组中删除一些或者不删除任何元素后,剩余元素保持原来的顺序构成的数组。示例1:输入:nums=[1,2,3,4,5],target=9输出:3解释:总共有3个子序列的和为9:[4,5],[1,3,5]和[2,3,4]
力扣的第34题 在排序数组中查找元素的第一个和最后一个位置
Wdc_12
leetcode 算法 数据结构
1.题目给你一个按照非递减顺序排列的整数数组nums,和一个目标值target。请你找出给定目标值在数组中的开始位置和结束位置。如果数组中不存在目标值target,返回[-1,-1]。你必须设计并实现时间复杂度为O(logn)的算法解决此问题。1.1示例输入:nums=[5,7,7,8,8,10],target=8输出:[3,4]输入:nums=[5,7,7,8,8,10],target=6输出:
Linux文件类型和根目录结构
m0_74536424
Linux学习笔记 linux 运维 服务器
Linux文件类型和根目录结构1.文件类型字符文件类型说明~普通文件类似于Windows的记事本d目录文件类似于windows文件夹c字符设备文件串行端口设备,顺序读写,键盘b块设备文件可供存储的接口设备,随机读写,硬盘p管道文件用于进程间的通信s套接字文件通常用于网络上的通信。可以启动一个程序来监听客户端的要求,客户端可以通过套接字来进行数据通信l符号链接又叫软链接,和原来文件不是同一个文件例如
【Linux】【网络】UDP打洞-->不同子网下的客户端和服务器通信(成功版)
钟离墨笺
Linux 网络 服务器 linux
【Linux】【网络】UDP打洞–>不同子网下的客户端和服务器通信(成功版)根据上个文章的分析问题可能出现在代码逻辑上面我这里重新查找资料怀疑:1NAT映射可能需要多次数据包的发送才能建立。2NAT映射保存时间太短,并且NAT可能会在短时间内改变这些映射,需要一直保持映射。有些NAT设备会因为短时间内没有数据而回收端口映射,导致服务器提供的IP:Port失效。保活机制:双方定期发送保活包以防NAT
scala的option和some
矮蛋蛋
编程 scala
原文地址:
http://blog.sina.com.cn/s/blog_68af3f090100qkt8.html
对于学习 Scala 的 Java™ 开发人员来说,对象是一个比较自然、简单的入口点。在 本系列 前几期文章中,我介绍了 Scala 中一些面向对象的编程方法,这些方法实际上与 Java 编程的区别不是很大。我还向您展示了 Scala 如何重新应用传统的面向对象概念,找到其缺点
NullPointerException
Cb123456
android BaseAdapter
java.lang.NullPointerException: Attempt to invoke virtual method 'int android.view.View.getImportantForAccessibility()' on a null object reference
出现以上异常.然后就在baidu上
PHP使用文件和目录
天子之骄
php文件和目录 读取和写入 php验证文件 php锁定文件
PHP使用文件和目录
1.使用include()包含文件
(1):使用include()从一个被包含文档返回一个值
(2):在控制结构中使用include()
include_once()函数需要一个包含文件的路径,此外,第一次调用它的情况和include()一样,如果在脚本执行中再次对同一个文件调用,那么这个文件不会再次包含。
在php.ini文件中设置
SQL SELECT DISTINCT 语句
何必如此
sql
SELECT DISTINCT 语句用于返回唯一不同的值。
SQL SELECT DISTINCT 语句
在表中,一个列可能会包含多个重复值,有时您也许希望仅仅列出不同(distinct)的值。
DISTINCT 关键词用于返回唯一不同的值。
SQL SELECT DISTINCT 语法
SELECT DISTINCT column_name,column_name
F
java冒泡排序
3213213333332132
java 冒泡排序
package com.algorithm;
/**
* @Description 冒泡
* @author FuJianyong
* 2015-1-22上午09:58:39
*/
public class MaoPao {
public static void main(String[] args) {
int[] mao = {17,50,26,18,9,10
struts2.18 +json,struts2-json-plugin-2.1.8.1.jar配置及问题!
7454103
DAO spring Ajax json qq
struts2.18 出来有段时间了! (貌似是 稳定版)
闲时研究下下! 貌似 sruts2 搭配 json 做 ajax 很吃香!
实践了下下! 不当之处请绕过! 呵呵
网上一大堆 struts2+json 不过大多的json 插件 都是 jsonplugin.34.jar
strut
struts2 数据标签说明
darkranger
jsp bean struts servlet Scheme
数据标签主要用于提供各种数据访问相关的功能,包括显示一个Action里的属性,以及生成国际化输出等功能
数据标签主要包括:
action :该标签用于在JSP页面中直接调用一个Action,通过指定executeResult参数,还可将该Action的处理结果包含到本页面来。
bean :该标签用于创建一个javabean实例。如果指定了id属性,则可以将创建的javabean实例放入Sta
链表.简单的链表节点构建
aijuans
编程技巧
/*编程环境WIN-TC*/ #include "stdio.h" #include "conio.h"
#define NODE(name, key_word, help) \ Node name[1]={{NULL, NULL, NULL, key_word, help}}
typedef struct node { &nbs
tomcat下jndi的三种配置方式
avords
tomcat
jndi(Java Naming and Directory Interface,Java命名和目录接口)是一组在Java应用中访问命名和目录服务的API。命名服务将名称和对象联系起来,使得我们可以用名称
访问对象。目录服务是一种命名服务,在这种服务里,对象不但有名称,还有属性。
tomcat配置
关于敏捷的一些想法
houxinyou
敏捷
从网上看到这样一句话:“敏捷开发的最重要目标就是:满足用户多变的需求,说白了就是最大程度的让客户满意。”
感觉表达的不太清楚。
感觉容易被人误解的地方主要在“用户多变的需求”上。
第一种多变,实际上就是没有从根本上了解了用户的需求。用户的需求实际是稳定的,只是比较多,也比较混乱,用户一般只能了解自己的那一小部分,所以没有用户能清楚的表达出整体需求。而由于各种条件的,用户表达自己那一部分时也有
富养还是穷养,决定孩子的一生
bijian1013
教育 人生
是什么决定孩子未来物质能否丰盛?为什么说寒门很难出贵子,三代才能出贵族?真的是父母必须有钱,才能大概率保证孩子未来富有吗?-----作者:@李雪爱与自由
事实并非由物质决定,而是由心灵决定。一朋友富有而且修养气质很好,兄弟姐妹也都如此。她的童年时代,物质上大家都很贫乏,但妈妈总是保持生活中的美感,时不时给孩子们带回一些美好小玩意,从来不对孩子传递生活艰辛、金钱来之不易、要懂得珍惜
oracle 日期时间格式转化
征客丶
oracle
oracle 系统时间有 SYSDATE 与 SYSTIMESTAMP;
SYSDATE:不支持毫秒,取的是系统时间;
SYSTIMESTAMP:支持毫秒,日期,时间是给时区转换的,秒和毫秒是取的系统的。
日期转字符窜:
一、不取毫秒:
TO_CHAR(SYSDATE, 'YYYY-MM-DD HH24:MI:SS')
简要说明,
YYYY 年
MM 月
【Scala六】分析Spark源代码总结的Scala语法四
bit1129
scala
1. apply语法
FileShuffleBlockManager中定义的类ShuffleFileGroup,定义:
private class ShuffleFileGroup(val shuffleId: Int, val fileId: Int, val files: Array[File]) {
...
def apply(bucketId
Erlang中有意思的bug
bookjovi
erlang
代码中常有一些很搞笑的bug,如下面的一行代码被调用两次(Erlang beam)
commit f667e4a47b07b07ed035073b94d699ff5fe0ba9b
Author: Jovi Zhang <bookjovi@gmail.com>
Date: Fri Dec 2 16:19:22 2011 +0100
erts:
移位打印10进制数转16进制-2008-08-18
ljy325
java 基础
/**
* Description 移位打印10进制的16进制形式
* Creation Date 15-08-2008 9:00
* @author 卢俊宇
* @version 1.0
*
*/
public class PrintHex {
// 备选字符
static final char di
读《研磨设计模式》-代码笔记-组合模式
bylijinnan
java 设计模式
声明: 本文只为方便我个人查阅和理解,详细的分析以及源代码请移步 原作者的博客http://chjavach.iteye.com/
import java.util.ArrayList;
import java.util.List;
abstract class Component {
public abstract void printStruct(Str
利用cmd命令将.class文件打包成jar
chenyu19891124
cmd jar
cmd命令打jar是如下实现:
在运行里输入cmd,利用cmd命令进入到本地的工作盘符。(如我的是D盘下的文件有此路径 D:\workspace\prpall\WEB-INF\classes)
现在是想把D:\workspace\prpall\WEB-INF\classes路径下所有的文件打包成prpall.jar。然后继续如下操作:
cd D: 回车
cd workspace/prpal
[原创]JWFD v0.96 工作流系统二次开发包 for Eclipse 简要说明
comsci
eclipse 设计模式 算法 工作 swing
JWFD v0.96 工作流系统二次开发包 for Eclipse 简要说明
&nb
SecureCRT右键粘贴的设置
daizj
secureCRT 右键 粘贴
一般都习惯鼠标右键自动粘贴的功能,对于SecureCRT6.7.5 ,这个功能也已经是默认配置了。
老版本的SecureCRT其实也有这个功能,只是不是默认设置,很多人不知道罢了。
菜单:
Options->Global Options ...->Terminal
右边有个Mouse的选项块。
Copy on Select
Paste on Right/Middle
Linux 软链接和硬链接
dongwei_6688
linux
1.Linux链接概念Linux链接分两种,一种被称为硬链接(Hard Link),另一种被称为符号链接(Symbolic Link)。默认情况下,ln命令产生硬链接。
【硬连接】硬连接指通过索引节点来进行连接。在Linux的文件系统中,保存在磁盘分区中的文件不管是什么类型都给它分配一个编号,称为索引节点号(Inode Index)。在Linux中,多个文件名指向同一索引节点是存在的。一般这种连
DIV底部自适应
dcj3sjt126com
JavaScript
<!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&q
Centos6.5使用yum安装mysql——快速上手必备
dcj3sjt126com
mysql
第1步、yum安装mysql
[root@stonex ~]# yum -y install mysql-server
安装结果:
Installed:
mysql-server.x86_64 0:5.1.73-3.el6_5 &nb
如何调试JDK源码
frank1234
jdk
相信各位小伙伴们跟我一样,想通过JDK源码来学习Java,比如collections包,java.util.concurrent包。
可惜的是sun提供的jdk并不能查看运行中的局部变量,需要重新编译一下rt.jar。
下面是编译jdk的具体步骤:
1.把C:\java\jdk1.6.0_26\sr
Maximal Rectangle
hcx2013
max
Given a 2D binary matrix filled with 0's and 1's, find the largest rectangle containing all ones and return its area.
public class Solution {
public int maximalRectangle(char[][] matrix)
Spring MVC测试框架详解——服务端测试
jinnianshilongnian
spring mvc test
随着RESTful Web Service的流行,测试对外的Service是否满足期望也变的必要的。从Spring 3.2开始Spring了Spring Web测试框架,如果版本低于3.2,请使用spring-test-mvc项目(合并到spring3.2中了)。
Spring MVC测试框架提供了对服务器端和客户端(基于RestTemplate的客户端)提供了支持。
&nbs
Linux64位操作系统(CentOS6.6)上如何编译hadoop2.4.0
liyong0802
hadoop
一、准备编译软件
1.在官网下载jdk1.7、maven3.2.1、ant1.9.4,解压设置好环境变量就可以用。
环境变量设置如下:
(1)执行vim /etc/profile
(2)在文件尾部加入:
export JAVA_HOME=/home/spark/jdk1.7
export MAVEN_HOME=/ho
StatusBar 字体白色
pangyulei
status
[[UIApplication sharedApplication] setStatusBarStyle:UIStatusBarStyleLightContent];
/*you'll also need to set UIViewControllerBasedStatusBarAppearance to NO in the plist file if you use this method
如何分析Java虚拟机死锁
sesame
java thread oracle 虚拟机 jdbc
英文资料:
Thread Dump and Concurrency Locks
Thread dumps are very useful for diagnosing synchronization related problems such as deadlocks on object monitors. Ctrl-\ on Solaris/Linux or Ctrl-B
位运算简介及实用技巧(一):基础篇
tw_wangzhengquan
位运算
http://www.matrix67.com/blog/archives/263
去年年底写的关于位运算的日志是这个Blog里少数大受欢迎的文章之一,很多人都希望我能不断完善那篇文章。后来我看到了不少其它的资料,学习到了更多关于位运算的知识,有了重新整理位运算技巧的想法。从今天起我就开始写这一系列位运算讲解文章,与其说是原来那篇文章的follow-up,不如说是一个r
jsearch的索引文件结构
yangshangchuan
搜索引擎 jsearch 全文检索 信息检索 word分词
jsearch是一个高性能的全文检索工具包,基于倒排索引,基于java8,类似于lucene,但更轻量级。
jsearch的索引文件结构定义如下:
1、一个词的索引由=分割的三部分组成: 第一部分是词 第二部分是这个词在多少