- 以内存为核心的开源分布式存储系统
这次靠你了
大数据Tachyonhdfs大数据
是一个以内存为核心的开源分布式存储系统,也是目前发展最迅速的开源大数据项目之一。Tachyon为不同的大数据计算框架(如ApacheSpark,HadoopMapReduce,ApacheFlink等)提供可靠的内存级的数据共享服务。此外,Tachyon还能够整合众多现有的存储系统(如AmazonS3,ApacheHDFS,RedHatGlusterFS,OpenStackSwift等),为用
- VMD渲染高清图片
薛定谔的青蛙
前端
使用snapshot直接渲染的图片分辨率太低了,放大后糊成一团:改用tachyon渲染可以解决这个问题:渲染完成后会生成一个.dat的文本文件,之后使用vmd自带的tachyon_WIN32.exe将dat文件渲染为高清图片。注意某些beta版本的vmd可以可能没有tachyon_WIN32.exe。之后在tachyon_WIN32.exe目录下新建一个.bat文本,写入以下内容:tachyon_
- Alluxio中国行(一)开源分布式存储系统Alluxio的历史、现状和未来
言则yanze
开源Alluxio分布式存储系统
七月底八月初在南京、上海和北京三地,Alluxio项目创立者李浩源以及部分核心开发者举办了一系列Meetup活动。活动现场介绍了Alluxio项目的新增功能,Alluxio生态系统展望,以及探讨了Alluxio在未来的发展路线。同时还分享了Alluxio在百度、去哪儿网的实践案例,与广大开发者及用户积极交流,碰撞思想。Alluxio,前称Tachyon,源自UCBerkeleyAMPLab,是一个
- Spark OFF_HEAP
尼小摩
OFF_HEAPSpark中RDD提供了几种存储级别,不同的存储级别可以带来不同的容错性能,例如MEMORY_ONLY,MEMORY_ONLY_SER_2...其中,有一种特别的是OFF_HEAPoff_heap的优势在于,在内存有限的条件下,减少不必要的内存消耗,以及频繁的GC问题,提升程序性能。Spark2.0以前,默认的off_heap是Tachyon,当然,你可以通过继承ExternalB
- 超详Chip-seq分析流程
想要学好生信的小白
一、Chip-seq分析流程二、数据、参考基因组、所需软件下载1、参考基因组下载:以二穗短柄草为例:https://genome.jgi.doe.gov/portal/pages/dynamicOrganismDownload.jsf?organism=Bdistachyonhttps://genome.jgi.doe.gov/portal/pages/dynamicOrganismDownloa
- 好用的样式动画库集合(css、js)
失眠时间
网站收集cssjavascript前端
文章目录前言一、Animate.css二、Anime.js三、CSShake四、Hover.css五、AniJS六、Animista七、Tachyons-animate八、Sequence.js九、Infinite十、OBNOXIOUS.CSS十一、MOTIONUI十二、Keyframes.app十三、AnimXYZ十四、Whirl十五、Hamburgers十六、Vivify十七、MagicAni
- 解锁前端Vue3宝藏级资料 第四章 VUE常用 UI 库 1 ( element-plus,Ant ,naiveui,ArcoDesign)
Zht_bs
vue前端vue.jsui
现在常用的前台UI分别是以下几种,我们将从中间选择介绍几个主流的UI的用于后台的系统搭建与开发。AntDesignVueelement-plusnaiveuiArcoDesignBootstrapVueBuefyChakraUIFramevuerkOrugaTachyonsTailwindCSSNutUIVantVuetify.js第一章Vue3项目创建1VueCLI创建vue项目第一章Vue
- 使用vmd渲染并保存指定分辨率的图片
药研猿
MD相关VMDMD
准备TCL脚本文件#设置渲染分辨率为1920x1080,600dpirenderTachyonInternalout.tgawidth1920height1080dpi600#启用抗锯齿选项displayantialiason运行TCL输入:sourcerender.tcl使用Photoshop打开输出的out.tga文件并保存常用图片格式
- Spark大数据处理技术
weixin_33935777
人工智能大数据ui
全球首部全面介绍Spark及Spark生态圈相关技术的技术书籍俯览未来大局,不失精细剖析,呈现一个现代大数据框架的架构原理和实现细节透彻讲解Spark原理和架构,以及部署模式、调度框架、存储管理及应用监控等重要模块Spark生态圈深度检阅:SQL处理Shark和SparkSQL、流式处理SparkStreaming、图计算Graphx及内存文件系统Tachyon内容简介书籍计算机书籍《Spark大
- Alluxio原理和应用场景随笔
青色的海牛
大数据示说网大数据分享专栏alluxio七牛云sparkachyonhdfs
上周末有幸参加了Alluxio(之前也叫Tachyon),七牛云和示说网举办的Alluxio上海Meetup,之前我并没有在真实应用场景中使用过Alluxio,对其适用的应用场景一直报怀疑态度。自信聆听其创始人的演讲之后,感觉这个项目还挺有意思,对Alluxio简单总结一下:DAL(数据访问层)AlluxioDALAlluxio提供了各种文件访问API,包括兼容HDFS的API,Alluxio特有
- Spark系列之Spark体系架构
落叶飘雪2014
Spark数据计算Spark大数据
title:Spark系列第四章Spark体系架构4.1Spark核心功能Alluxio原来叫tachyon分布式内存文件系统SparkCore提供Spark最基础的最核心的功能,主要包括:1、SparkContext通常而言,DriverApplication的执行与输出都是通过SparkContext来完成的,在正式提交Application之前,首先需要初始化SparkContext。Spa
- 【Iceberg+Alluxio】助力加速数据通道(上篇)
Alluxio是2014年在伯克利AMPLab孵化的一个项目,那时候名叫Tachyon,是跟Spark同一期孵化的分布式存储项目。截止到今天为止,我们这个社区里已经有超过1000名的contributor参与搭建了社区代码和各种活动,在Slackcommittee里面已经有5000以上的member进行互动,大家也把技术广泛应用在各种开源场景里面。在去年的时候,我们也被谷歌评选为最具影响力的十大J
- 推酷《编程狂人》第一一六期
推酷
推酷诚意满满的技术周刊《编程狂人》,下面是内容列表,干货多多,也可以移步到官网进一步阅读。业界新闻Tachyon已支持阿里云OSS,正式改名AlluxioJDK9最终将包含Jigsaw模块系统微软狠挖甲骨文墙脚:从Oracle迁移到SQLServer免费Eclipse基金会发布下一代IDE,EclipseChe4.0JEP286提议在Java局部变量中引入类型推断前端开发2016年JavaScri
- 分布式内存文件系统:Tachyon
zdy0_2004
分布式大数据Tachyon
Tachyonhttp://www.open-open.com/lib/view/open1409754088791.htmlTachyon是一个分布式内存文件系统,可以在集群里以访问内存的速度来访问存在tachyon里的文件。把Tachyon是架构在最底层的分布式文件存储和上层的各种计算框架之间的一种中间件。主要职责是将那些不需要落地到DFS里的文件,落地到分布式内存文件系统中,来达到共享内存,
- Tachyon在Spark中的作用(Tachyon: Reliable, Memory Speed Storage for Cluster Computing Frameworks 论文阅读翻译)...
weixin_34194087
摘要:Tachyon是一种分布式文件系统,能够借助集群计算框架使得数据以内存的速度进行共享。当今的缓存技术优化了read过程,可是,write过程由于须要容错机制,就须要通过网络或者是磁盘进行复制操作。Tachyon通过将“血统”技术引入到存储层进而消除了这个瓶颈。创建一个长期的以“血统机制”为基础的存储系统的关键挑战是失败情况发生的时候及时地进行数据恢复。Tachyon通过引入一种检查点的算法来
- Tachyon的安装、配置和使用
gurongwalker
Tachyon技术专栏
发布人:南京大学PASA大数据实验室董乾豪0.前言在上一篇博文《Tachyon简介》中,我们简要地介绍了Tachyon,一个以内存为中心的分布式文件系统,及其一些基本工作原理。这一次,我们重点介绍如何在你自己的单机或集群环境下去安装、配置和使用Tachyon。具体地,会从怎样编译源码开始,到各项配置、命令的说明,再加上API的使用举例,让大家能够一步步地把Tachyon用起来。版本选择Tachyo
- Tachyon
孝林
Tachyon是一个分布式文件系统,提供了一种可靠的方式,可以以访问内存的速度在不同的分布式计算框架之间共享数据。Tachyon使用lineage技术实现容错,并通过一种检查点(checkpoint)算法来确保恢复以及资源开销在一定范围之内。据作者测试,Tachyon的写性能超过in-memoryhbase110倍,能为实际端到端工作流提高4倍性能。Tachyon目前已经开源并且在多个不同的企业、
- FileSplit简单使用
走丢的小木头
hadoop的FileSplit简单使用FileSplit类继承关系:FileSplit类中的属性和方法:作业输入:[java]viewplaincopyprint?hadoop@hadoop:/home/hadoop/blb$hdfsdfs-text/user/hadoop/libin/input/inputpath1.txthadoopasparkahiveahbaseatachyonas
- Alluxio介绍与作用
twj0823
一、介绍AlluxioTachyon正式改名为alluxio,并发布v1.0.0版本,alluxio是内存高速虚拟分布式存储系统。Alluxio是一个以内存为中心的虚拟分布式存储系统,统一数据访问和桥梁的计算框架和底层存储系统。应用程序只需要alluxio就可以把访问存储在任何底层存储系统的数据连接。此外,Alluxio以内存为中心的架构实现数据访问的数量级的速度比现有的解决方案快很多。在大数据的
- Hadoop的FileStatus简单使用
鲍礼彬
Bigdatda-Hadoop
Hadoop的FileStatus简单使用FileStatus类继承关系:FileStatus类的属性和方法:输入文件信息:blb@hadoop1:/home/blb/blb$hdfsdfs-text/user/blb/libin/input/inputpath1.txthadoopasparkahiveahbaseatachyonastormaredisablb@hadoop1:/home/bl
- hadoop的Context简单使用
鲍礼彬
Bigdatda-Hadoop
hadoop的Context简单使用作业输入:hadoop@hadoop:/home/hadoop/blb$hdfsdfs-text/user/hadoop/libin/input/inputpath1.txthadoopasparkahiveahbaseatachyonastormaredisahadoop@hadoop:/home/hadoop/blb$hdfsdfs-text/user/ha
- Tachyon:Spark生态系统中的分布式内存文件系统
凉秋cds
HadoopsparkTachyon内存文件系统
(转自:http://www.csdn.net/article/2015-06-25/2825056)Tachyon是Spark生态系统内快速崛起的一个新项目。本质上,Tachyon是个分布式的内存文件系统,它在减轻Spark内存压力的同时,也赋予了Spark内存快速大量数据读写的能力。Tachyon把内存存储的功能从Spark中分离出来,使Spark可以更专注计算的本身,以求通过更细的分工达到更
- ExternalBlockStore
大冰的小屋
Spark源码Spark
ExternalBlockStore作为存储Block文件的外部管理器,其实际是封装了TachyonBlockManager。这样做可以更好的解耦合,方便以后加入新的第三方的管理器。ExternalBlockStore创建TachyonBlockManager代码如下:/***StoresBlockManagerblocksonExternalBlockStore.*Wecaptureanypot
- spark有没有什么缺点。。
Bonyin
spark
spark的缺点其实就是的它的优点所带来的问题。目前Spark主要存在哪些缺点?(a)JVM的内存overhead太大,1G的数据通常需要消耗5G的内存->ProjectTungsten正试图解决这个问题;(b)不同的sparkapp之间缺乏有效的共享内存机制->ProjectTachyon在试图引入分布式的内存管理,这样不同的sparkapp可以共享缓存的数据转自http://www.about
- Alluxio环境搭建
冒冒大虾
alluxio分布式内存文件系统
Alluxio环境搭建1.简介Alluxio(之前名为Tachyon)是世界上第一个以内存为中心的虚拟的分布式存储系统。它统一了数据访问的方式,为上层计算框架和底层存储系统构建了桥梁。应用只需要连接Alluxio即可访问存储在底层任意存储系统中的数据。此外,Alluxio的以内存为中心的架构使得数据的访问速度能比现有常规方案快几个数量级。由于Alluxio的设计以内存为中心,并且是数据访问的中心,
- Spark Storage之ExternalBlockStore
Mr_JieLQ
spark-core源码sparkspark
概要前两篇介绍了Storage模块的MemoryStore和DiskStore,此外,Spark支持外部存储,即ExternalBlockStore。Tachyon(Alluxio)简介ExternalBlockStore底层使用Tachyon(现更名为Alluxio),Tachyon是一个分布式文件系统,提供内存级别的访问速度,通常作用于分布式计算框架(如spark)和底层存储之间(如HDFS)
- Tachyon 0.7.1伪分布式集群安装与测试
iteye_6622
tachyonspark分布式tachyon安装
Tachyon是一个高容错的分布式文件系统,允许文件以内存的速度在集群框架中进行可靠的共享,就像Spark和MapReduce那样。通过利用信息继承,内存侵入,Tachyon获得了高性能。Tachyon工作集文件缓存在内存中,并且让不同的Jobs/Queries以及框架都能内存的速度来访问缓存文件。因此,Tachyon可以减少那些需要经常使用的数据集通过访问磁盘来获得的次数。源码下载源码地址:ht
- tachyon与hdfs,以及spark整合
iteye_6622
tachyonspark
Tachyon0.7.1伪分布式集群安装与测试:http://blog.csdn.net/stark_summer/article/details/48321605从官方文档得知,Spark1.4.x和Tachyon0.6.4版本兼容,而最新版的Tachyon0.7.1和Spark1.5.x兼容,目前所用的Spark为1.4.1,tachyon为0.7.1tachyon与hdfs整合修改tachy
- 专访范斌,谈开源三年后的Alluxio
csdn郭芮
在Alluxio(前Tachyon)项目开源三年后的今天,全世界已经有超过300名贡献者参与到项目当中,其中包括Intel,百度,去哪儿等100多家公司。仅仅在去年,它的代码贡献人数就比以往翻了三倍。Alluxio项目已经成为大数据领域内历史上成长最快的项目之一。本期被访嘉宾——范斌(@apc2):Alluxio公司软件工程师,也是Alluxio开源项目的管理委员会(PMC)成员。曾在Micros
- Spark生态之Alluxio学习25--spark从HDFS和Alluxio读取时间比较
KeepLearningBigData
alluxio
更多代码请见:https://github.com/xubo245/SparkLearningSpark生态之Alluxio学习版本:alluxio-1.3.0(tachyon),spark-1.5.2,hadoop-2.6.01.解释想要分析alluxio加速效果,发现alluxio会出现长尾效应,导致有些task特别耗时,相对于HDFS,并没有明显优势。2.代码:#~/cloud/alluxi
- PHP,安卓,UI,java,linux视频教程合集
cocos2d-x小菜
javaUIPHPandroidlinux
╔-----------------------------------╗┆
- 各表中的列名必须唯一。在表 'dbo.XXX' 中多次指定了列名 'XXX'。
bozch
.net.net mvc
在.net mvc5中,在执行某一操作的时候,出现了如下错误:
各表中的列名必须唯一。在表 'dbo.XXX' 中多次指定了列名 'XXX'。
经查询当前的操作与错误内容无关,经过对错误信息的排查发现,事故出现在数据库迁移上。
回想过去: 在迁移之前已经对数据库进行了添加字段操作,再次进行迁移插入XXX字段的时候,就会提示如上错误。
&
- Java 对象大小的计算
e200702084
java
Java对象的大小
如何计算一个对象的大小呢?
 
- Mybatis Spring
171815164
mybatis
ApplicationContext ac = new ClassPathXmlApplicationContext("applicationContext.xml");
CustomerService userService = (CustomerService) ac.getBean("customerService");
Customer cust
- JVM 不稳定参数
g21121
jvm
-XX 参数被称为不稳定参数,之所以这么叫是因为此类参数的设置很容易引起JVM 性能上的差异,使JVM 存在极大的不稳定性。当然这是在非合理设置的前提下,如果此类参数设置合理讲大大提高JVM 的性能及稳定性。 可以说“不稳定参数”
- 用户自动登录网站
永夜-极光
用户
1.目标:实现用户登录后,再次登录就自动登录,无需用户名和密码
2.思路:将用户的信息保存为cookie
每次用户访问网站,通过filter拦截所有请求,在filter中读取所有的cookie,如果找到了保存登录信息的cookie,那么在cookie中读取登录信息,然后直接
- centos7 安装后失去win7的引导记录
程序员是怎么炼成的
操作系统
1.使用root身份(必须)打开 /boot/grub2/grub.cfg 2.找到 ### BEGIN /etc/grub.d/30_os-prober ### 在后面添加 menuentry "Windows 7 (loader) (on /dev/sda1)" { 
- Oracle 10g 官方中文安装帮助文档以及Oracle官方中文教程文档下载
aijuans
oracle
Oracle 10g 官方中文安装帮助文档下载:http://download.csdn.net/tag/Oracle%E4%B8%AD%E6%96%87API%EF%BC%8COracle%E4%B8%AD%E6%96%87%E6%96%87%E6%A1%A3%EF%BC%8Coracle%E5%AD%A6%E4%B9%A0%E6%96%87%E6%A1%A3 Oracle 10g 官方中文教程
- JavaEE开源快速开发平台G4Studio_V3.2发布了
無為子
AOPoraclemysqljavaeeG4Studio
我非常高兴地宣布,今天我们最新的JavaEE开源快速开发平台G4Studio_V3.2版本已经正式发布。大家可以通过如下地址下载。
访问G4Studio网站
http://www.g4it.org
G4Studio_V3.2版本变更日志
功能新增
(1).新增了系统右下角滑出提示窗口功能。
(2).新增了文件资源的Zip压缩和解压缩
- Oracle常用的单行函数应用技巧总结
百合不是茶
日期函数转换函数(核心)数字函数通用函数(核心)字符函数
单行函数; 字符函数,数字函数,日期函数,转换函数(核心),通用函数(核心)
一:字符函数:
.UPPER(字符串) 将字符串转为大写
.LOWER (字符串) 将字符串转为小写
.INITCAP(字符串) 将首字母大写
.LENGTH (字符串) 字符串的长度
.REPLACE(字符串,'A','_') 将字符串字符A转换成_
- Mockito异常测试实例
bijian1013
java单元测试mockito
Mockito异常测试实例:
package com.bijian.study;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.when;
import org.junit.Assert;
import org.junit.Test;
import org.mockito.
- GA与量子恒道统计
Bill_chen
JavaScript浏览器百度Google防火墙
前一阵子,统计**网址时,Google Analytics(GA) 和量子恒道统计(也称量子统计),数据有较大的偏差,仔细找相关资料研究了下,总结如下:
为何GA和量子网站统计(量子统计前身为雅虎统计)结果不同?
首先:没有一种网站统计工具能保证百分之百的准确出现该问题可能有以下几个原因:(1)不同的统计分析系统的算法机制不同;(2)统计代码放置的位置和前后
- 【Linux命令三】Top命令
bit1129
linux命令
Linux的Top命令类似于Windows的任务管理器,可以查看当前系统的运行情况,包括CPU、内存的使用情况等。如下是一个Top命令的执行结果:
top - 21:22:04 up 1 day, 23:49, 1 user, load average: 1.10, 1.66, 1.99
Tasks: 202 total, 4 running, 198 sl
- spring四种依赖注入方式
白糖_
spring
平常的java开发中,程序员在某个类中需要依赖其它类的方法,则通常是new一个依赖类再调用类实例的方法,这种开发存在的问题是new的类实例不好统一管理,spring提出了依赖注入的思想,即依赖类不由程序员实例化,而是通过spring容器帮我们new指定实例并且将实例注入到需要该对象的类中。依赖注入的另一种说法是“控制反转”,通俗的理解是:平常我们new一个实例,这个实例的控制权是我
- angular.injector
boyitech
AngularJSAngularJS API
angular.injector
描述: 创建一个injector对象, 调用injector对象的方法可以获得angular的service, 或者用来做依赖注入. 使用方法: angular.injector(modules, [strictDi]) 参数详解: Param Type Details mod
- java-同步访问一个数组Integer[10],生产者不断地往数组放入整数1000,数组满时等待;消费者不断地将数组里面的数置零,数组空时等待
bylijinnan
Integer
public class PC {
/**
* 题目:生产者-消费者。
* 同步访问一个数组Integer[10],生产者不断地往数组放入整数1000,数组满时等待;消费者不断地将数组里面的数置零,数组空时等待。
*/
private static final Integer[] val=new Integer[10];
private static
- 使用Struts2.2.1配置
Chen.H
apachespringWebxmlstruts
Struts2.2.1 需要如下 jar包: commons-fileupload-1.2.1.jar commons-io-1.3.2.jar commons-logging-1.0.4.jar freemarker-2.3.16.jar javassist-3.7.ga.jar ognl-3.0.jar spring.jar
struts2-core-2.2.1.jar struts2-sp
- [职业与教育]青春之歌
comsci
教育
每个人都有自己的青春之歌............但是我要说的却不是青春...
大家如果在自己的职业生涯没有给自己以后创业留一点点机会,仅仅凭学历和人脉关系,是难以在竞争激烈的市场中生存下去的....
&nbs
- oracle连接(join)中使用using关键字
daizj
JOINoraclesqlusing
在oracle连接(join)中使用using关键字
34. View the Exhibit and examine the structure of the ORDERS and ORDER_ITEMS tables.
Evaluate the following SQL statement:
SELECT oi.order_id, product_id, order_date
FRO
- NIO示例
daysinsun
nio
NIO服务端代码:
public class NIOServer {
private Selector selector;
public void startServer(int port) throws IOException {
ServerSocketChannel serverChannel = ServerSocketChannel.open(
- C语言学习homework1
dcj3sjt126com
chomework
0、 课堂练习做完
1、使用sizeof计算出你所知道的所有的类型占用的空间。
int x;
sizeof(x);
sizeof(int);
# include <stdio.h>
int main(void)
{
int x1;
char x2;
double x3;
float x4;
printf(&quo
- select in order by , mysql排序
dcj3sjt126com
mysql
If i select like this:
SELECT id FROM users WHERE id IN(3,4,8,1);
This by default will select users in this order
1,3,4,8,
I would like to select them in the same order that i put IN() values so:
- 页面校验-新建项目
fanxiaolong
页面校验
$(document).ready(
function() {
var flag = true;
$('#changeform').submit(function() {
var projectScValNull = true;
var s ="";
var parent_id = $("#parent_id").v
- Ehcache(02)——ehcache.xml简介
234390216
ehcacheehcache.xml简介
ehcache.xml简介
ehcache.xml文件是用来定义Ehcache的配置信息的,更准确的来说它是定义CacheManager的配置信息的。根据之前我们在《Ehcache简介》一文中对CacheManager的介绍我们知道一切Ehcache的应用都是从CacheManager开始的。在不指定配置信
- junit 4.11中三个新功能
jackyrong
java
junit 4.11中两个新增的功能,首先是注解中可以参数化,比如
import static org.junit.Assert.assertEquals;
import java.util.Arrays;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.junit.runn
- 国外程序员爱用苹果Mac电脑的10大理由
php教程分享
windowsPHPunixMicrosoftperl
Mac 在国外很受欢迎,尤其是在 设计/web开发/IT 人员圈子里。普通用户喜欢 Mac 可以理解,毕竟 Mac 设计美观,简单好用,没有病毒。那么为什么专业人士也对 Mac 情有独钟呢?从个人使用经验来看我想有下面几个原因:
1、Mac OS X 是基于 Unix 的
这一点太重要了,尤其是对开发人员,至少对于我来说很重要,这意味着Unix 下一堆好用的工具都可以随手捡到。如果你是个 wi
- 位运算、异或的实际应用
wenjinglian
位运算
一. 位操作基础,用一张表描述位操作符的应用规则并详细解释。
二. 常用位操作小技巧,有判断奇偶、交换两数、变换符号、求绝对值。
三. 位操作与空间压缩,针对筛素数进行空间压缩。
&n
- weblogic部署项目出现的一些问题(持续补充中……)
Everyday都不同
weblogic部署失败
好吧,weblogic的问题确实……
问题一:
org.springframework.beans.factory.BeanDefinitionStoreException: Failed to read candidate component class: URL [zip:E:/weblogic/user_projects/domains/base_domain/serve
- tomcat7性能调优(01)
toknowme
tomcat7
Tomcat优化: 1、最大连接数最大线程等设置
<Connector port="8082" protocol="HTTP/1.1"
useBodyEncodingForURI="t
- PO VO DAO DTO BO TO概念与区别
xp9802
javaDAO设计模式bean领域模型
O/R Mapping 是 Object Relational Mapping(对象关系映射)的缩写。通俗点讲,就是将对象与关系数据库绑定,用对象来表示关系数据。在O/R Mapping的世界里,有两个基本的也是重要的东东需要了解,即VO,PO。
它们的关系应该是相互独立的,一个VO可以只是PO的部分,也可以是多个PO构成,同样也可以等同于一个PO(指的是他们的属性)。这样,PO独立出来,数据持