orm java_Java 8 Friday:不再需要ORM

orm java

在Data Geekery ,我们喜欢Java。 而且,由于我们真的很喜欢jOOQ的流畅的API和查询DSL ,我们对Java 8将为我们的生态系统带来什么感到非常兴奋。

Java 8星期五

每个星期五,我们都会向您展示一些不错的教程风格的Java 8新功能,这些功能利用了lambda表达式,扩展方法和其他出色的功能。 您可以在GitHub上找到源代码 。

不再需要ORM

在过去的十年中,关于ORM(对象关系映射)的有用性的争论一直在进行。 尽管许多人都同意Hibernate和JPA很好地解决了许多问题(大多数情况是复杂对象图的持久性),但其他人可能会认为, 映射复杂性对于以数据为中心的应用程序来说过于矫kill过正 。

JPA通过在接收目标类型上使用硬连线的注释建立标准化的声明性映射规则来解决映射问题。 我们声称,许多以数据为中心的问题不应仅受这些注释的狭窄范围的限制,而应以更具功能性的方式解决。 Java 8和新的Streams API最终使我们能够以非常简洁的方式执行此操作!

让我们从一个简单的示例开始,在该示例中,我们使用H2的INFORMATION_SCHEMA收集所有表及其列。 我们将要生成一个Map<String, List<String>>类型的临时数据结构来包含此信息。 为了简化SQL交互,我们将使用jOOQ (与往常一样,此博客上的内容令人震惊)。 这是我们准备的方法:

public static void main(String[] args)
throws Exception {Class.forName("org.h2.Driver");try (Connection c = getConnection("jdbc:h2:~/sql-goodies-with-mapping", "sa", "")) {// This SQL statement produces all table// names and column names in the H2 schemaString sql ="select table_name, column_name " +"from information_schema.columns " +"order by " +"table_catalog, " +"table_schema, " +"table_name, " +"ordinal_position";// This is jOOQ's way of executing the above// statement. Result implements List, which// makes subsequent steps much easierResult<Record> result =DSL.using(c).fetch(sql)}
}

现在我们已经设置了该查询,让我们看看如何从jOOQ Result中生成Map<String, List<String>>

DSL.using(c).fetch(sql).stream().collect(groupingBy(r -> r.getValue("TABLE_NAME"),mapping(r -> r.getValue("COLUMN_NAME"),toList()))).forEach((table, columns) -> System.out.println(table + ": " + columns));

上面的示例产生以下输出:

FUNCTION_COLUMNS: [ALIAS_CATALOG, ALIAS_SCHEMA, ...]
CONSTANTS: [CONSTANT_CATALOG, CONSTANT_SCHEMA, ...]
SEQUENCES: [SEQUENCE_CATALOG, SEQUENCE_SCHEMA, ...]

它是如何工作的? 让我们逐步进行

DSL.using(c).fetch(sql)// Here, we transform a List into a Stream.stream()// We're collecting Stream elements into a new
// collection type.collect(// The Collector is a grouping operation, producing
// a MapgroupingBy(// The grouping operation's group key is defined by
// the jOOQ Record's TABLE_NAME valuer -> r.getValue("TABLE_NAME"),// The grouping operation's group value is generated
// by this mapping expression...mapping(// ... which is essentially mapping each grouped
// jOOQ Record to the Record's COLUMN_NAME valuer -> r.getValue("COLUMN_NAME"),// ... and then collecting all those values into a
// java.util.List. WhewtoList())))// Once we have this List<String, List<String>> we
// can simply consume it with the following Consumer
// lambda expression.forEach((table, columns) -> System.out.println(table + ": " + columns));

得到它了? 第一次玩这些东西时,肯定有些棘手。 起初,新类​​型,泛型泛型,lambda表达式的组合可能有点令人困惑。 最好的办法是简单地练习这些东西,直到您掌握了它。 毕竟,与以前的Java Collections API相比,整个Streams API确实是一场革命。

好消息是:此API是最终的,并将保留。 练习每一分钟都是对自己未来的投资。

请注意,以上程序使用了以下静态导入:

import static java.util.stream.Collectors.*;

还要注意,不再像数据库中那样对输出进行排序。 这是因为groupingBy收集器返回java.util.HashMap 。 在我们的例子中,我们可能更喜欢将东西收集到java.util.LinkedHashMap ,该对象保留插入/收集的顺序:

DSL.using(c).fetch(sql).stream().collect(groupingBy(r -> r.getValue("TABLE_NAME"),// Add this Supplier to the groupingBy// method callLinkedHashMap::new,mapping(r -> r.getValue("COLUMN_NAME"),toList()))).forEach(...);

我们可以继续使用其他转换结果的方法。 想象一下,我们想根据上述模式生成简单的DDL。 非常简单 首先,我们需要选择列的数据类型。 我们只需将其添加到我们SQL查询中:

String sql ="select " +"table_name, " +"column_name, " +"type_name " + // Add the column type"from information_schema.columns " +"order by " +"table_catalog, " +"table_schema, " +"table_name, " +"ordinal_position";

我还为示例引入了一个新的本地类,以包装名称和类型属性:

class Column {final String name;final String type;Column(String name, String type) {this.name = name;this.type = type;}
}

现在,让我们看看如何更改Streams API方法调用:

result.stream().collect(groupingBy(r -> r.getValue("TABLE_NAME"),LinkedHashMap::new,mapping(// We now collect this new wrapper type// instead of just the COLUMN_NAMEr -> new Column(r.getValue("COLUMN_NAME", String.class),r.getValue("TYPE_NAME", String.class)),toList()))).forEach((table, columns) -> {// Just emit a CREATE TABLE statementSystem.out.println("CREATE TABLE " + table + " (");// Map each "Column" type into a String// containing the column specification,// and join them using comma and// newline. Done!System.out.println(columns.stream().map(col -> "  " + col.name +" " + col.type).collect(Collectors.joining(",\n")));System.out.println(");");});

输出再好不过了!

CREATE TABLE CATALOGS(CATALOG_NAME VARCHAR
);
CREATE TABLE COLLATIONS(NAME VARCHAR,KEY VARCHAR
);
CREATE TABLE COLUMNS(TABLE_CATALOG VARCHAR,TABLE_SCHEMA VARCHAR,TABLE_NAME VARCHAR,COLUMN_NAME VARCHAR,ORDINAL_POSITION INTEGER,COLUMN_DEFAULT VARCHAR,IS_NULLABLE VARCHAR,DATA_TYPE INTEGER,CHARACTER_MAXIMUM_LENGTH INTEGER,CHARACTER_OCTET_LENGTH INTEGER,NUMERIC_PRECISION INTEGER,NUMERIC_PRECISION_RADIX INTEGER,NUMERIC_SCALE INTEGER,CHARACTER_SET_NAME VARCHAR,COLLATION_NAME VARCHAR,TYPE_NAME VARCHAR,NULLABLE INTEGER,IS_COMPUTED BOOLEAN,SELECTIVITY INTEGER,CHECK_CONSTRAINT VARCHAR,SEQUENCE_NAME VARCHAR,REMARKS VARCHAR,SOURCE_DATA_TYPE SMALLINT
);

ORM时代可能刚刚结束

这是一个强有力的声明。 ORM时代可能已经结束。 为什么? 因为使用函数表达式转换数据集是软件工程中最强大的概念之一。 函数式编程非常有表现力,而且用途广泛。 它是数据和数据流处理的核心。 我们的Java开发人员已经知道现有的功能语言。 例如,每个人以前都使用过SQL。 想一想。 使用SQL,您可以声明表源,将它们投影/转换为新的元组流,并将它们作为派生表提供给其他更高级别SQL语句或Java程序。

如果您使用的是XML,则可以使用XSLT声明XML转换,并使用XProc pipelining将结果提供给其他XML处理实体,例如另一个XSL样式表。

Java 8的Streams没什么。 使用SQL和Streams API是最强大的数据处理概念之一。 如果将jOOQ添加到堆栈,则可以从对数据库记录和查询API的类型安全访问中受益。 想象一下使用jOOQ的流畅API而不是使用SQL字符串编写上一条语句。

jooq-在Java中编写SQL的最佳方法

整个方法链可以是一个单一的流利数据转换链,如下所示:

DSL.using(c).select(COLUMNS.TABLE_NAME,COLUMNS.COLUMN_NAME,COLUMNS.TYPE_NAME).from(COLUMNS).orderBy(COLUMNS.TABLE_CATALOG,COLUMNS.TABLE_SCHEMA,COLUMNS.TABLE_NAME,COLUMNS.ORDINAL_POSITION).fetch()  // jOOQ ends here.stream() // Streams start here.collect(groupingBy(r -> r.getValue(COLUMNS.TABLE_NAME),LinkedHashMap::new,mapping(r -> new Column(r.getValue(COLUMNS.COLUMN_NAME),r.getValue(COLUMNS.TYPE_NAME)),toList()))).forEach((table, columns) -> {// Just emit a CREATE TABLE statementSystem.out.println("CREATE TABLE " + table + " (");// Map each "Column" type into a String// containing the column specification,// and join them using comma and// newline. Done!System.out.println(columns.stream().map(col -> "  " + col.name +" " + col.type).collect(Collectors.joining(",\n")));System.out.println(");");});

Java 8是未来,借助jOOQ,Java 8和Streams API,您可以编写功能强大的数据转换API。 希望我们像您一样兴奋! 请继续关注此博客上更多精彩的Java 8内容。

翻译自: https://www.javacodegeeks.com/2014/04/java-8-friday-no-more-need-for-orms.html

orm java

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/343278.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

工业交换机的端口号结构特征

假如按工业交换机的端口号构造来分&#xff0c;工业交换机大概可分成&#xff1a;固定不动端口号工业交换机和模块化设计工业交换机二种不一样的构造。实际上也有一种是二者兼具&#xff0c;那便是在出示基础固定不动端口号的基本以上再配置一定的拓展扩展槽或控制模块。今天&a…

python3 ftp.mlsd,python3中的ftp目录

我在Python3.3中有以下代码&#xff1a;ftpHost"myhost"linkftplib.FTP(ftpHost)link.login(user"me",passwd"alsome")tlink.nlst()link.quit()print(t)我得到的输出是^{pr2}$在python3文档中&#xff0c;写到FTP.nlst文件“自3.3版起已弃用&…

lora技术和zigbee技术那个好,两者有啥优势

ZigBee是基于IEEE802.15.4标准的低功耗局域网协议&#xff0c;LoRa是LPWAN通信技术中的一种&#xff0c;那么lora技术和ZigBee技术哪个好呢?今天我们就来看看具体的介绍。 LoRa是LPWAN通信技术中的一种&#xff0c;是美国Semtech公司采用和推广的一种基于扩频技术的超远距离无…

【渝粤教育】国家开放大学2018年春季 0062-22T港台文学专题讲座 参考试题

试卷编号&#xff1a;0062 座位号 2017——2018学年度第二学期期末考试 中国当代文学专题 试题&#xff08;开&#xff09; 2018年7月 《鹿鼎记》和金庸以前的武侠小说的主要差别是什么&#xff1f;1&#xff0e;通过《红高粱》讲述的“我爷爷”余占鳌和“我奶奶”戴凤莲的故…

【渝粤教育】国家开放大学2018年春季 0149-22T现代汉语 参考试题

试卷编号&#xff1a;0149 座位号 2017——2018学年度第二学期期末考试 现代汉语试题 2018年7月 1&#xff0e;新词 2&#xff0e;北方方言3&#xff0e;形旁4&#xff0e;定位语素 5&#xff0e;派生义 1&#xff0e;声母z和zh的区别是________不同。 2&#xff0e;_____的…

物联网智慧城市为降低城市能源消耗做出贡献

我们居住的世界正在不断的趋于城市化 我们生活在一个不断城市化的世界里&#xff0c;世界上一半以上的人都居住在城市里。在全球范围内&#xff0c;城市化的速度正在不断的推进中&#xff1a;据推算&#xff0c;每周约有300万的人口迁入城市。按照这个速度&#xff0c;预计等到…

Java Stream:计数始终是计数吗?

它可能会出现明显的是&#xff0c;在计数的元素Stream需要较长时间的多个元素中有Stream 。 但实际上&#xff0c; Stream::count有时可以在一个操作中完成&#xff0c;无论您有多少元素。 阅读本文并了解操作方法。 计数复杂度 Stream::count终端操作对a中的元素数进行计数 …

【渝粤教育】国家开放大学2018年春季 0269-22T文学概论 参考试题

试卷代号&#xff1a;0269 2017-2018年度第二学期考试 文学概论试题 2018年7月 一、选择题&#xff08;请在下面的答题框内写上正确答案的序号&#xff09;&#xff08;每小题3分&#xff0c;共30分&#xff09; 1&#xff0e;在魏晋时期&#xff0c;南朝宋文帝建立“四学”即…

工业以太网的冗余功能有哪些?

由于工业环境对工业控制网络可靠性能的超高要求&#xff0c;工业以太网的冗余功能应运而生。从快速生成树冗余(RSTP)、环网冗余&#xff08;RapidRing&#xff09;到主干冗余&#xff08;Trunking&#xff09;&#xff0c;都有各自不同的优势和特点&#xff0c;控制工程师们可以…

支付宝回调地址index.php,支付宝支付成功回调地址怎么不改变当前页面?

手机端支付宝支付成功后 会有一个回调地址"http://pay.xxx.com/channel/alipayWap/return_url.php?is_successT&notify_idRqPnCoPT3K9%252Fvwbh3Ih20EPHd%252B9cnawdN%252Bu%252FVdQAMTpw%252FtTBJga49sLEne6jOnYt2mSr&notify_time2017-08-0814%3A41%3A49&no…

【渝粤教育】国家开放大学2018年春季 0434-22T高级英语口语 参考试题

科目编号&#xff1a;0434 2017-2018学年第二学期期末考试 高级英语口语 试题 2018年7月 (3—1) Ⅰ. Contradict the following statement. &#xff08;反驳下列论断&#xff09;。 (30 %) Whether to have many children or not is a completely private matter. Ⅱ. Make a…

input发送a.jax_JAX-RS 2.0:自定义内容处理

input发送a.jax我试图想到一个更好的标题&#xff0c;但未能拿出一个&#xff01; 请多多包涵……。 JAX-RS 2.0规范允许我们无缝地将JAXB对象编组到HTTP请求/响应主体&#xff0c;或从HTTP请求/响应主体中解组。 简而言之&#xff0c;我们可以使用域对象&#xff0c;而不必担…

php mysql ppt,7PHP访问数据库分析.ppt

7PHP访问数据库分析习题 4. 下列哪个函数可以将结果集的指针移动到指定的位置 A. mysql_fetch_rowB. mysql_fetch_assoc C. mysql_queryD. mysql_data_seek 5. PHP连接mysql数据库的连接函数mysql_connect的第三个参数是&#xff1a;() A. 主机名B. 数据库密码C. 数据库用户名 …

工业以太网交换机出现温度过高如何处理?

工业交换机由于其良好的通信性能、超强的抗磁抗干扰性被应用在工业环境下。我们都知道工业环境是很恶劣的&#xff0c;加上工业交换机要连续不间断的工作&#xff0c;很容易造成工业交换机过热的现象&#xff01;因此除了产品本身采用宽温度范围的元器件之外&#xff0c;我们更…

【渝粤教育】国家开放大学2018年春季 0556-21T广告摄影 参考试题

编号&#xff1a;0556 座位号 2017&#xff5e;2018学年度第二学期期末考试 广告摄影 试题 2018年6月 一、名词解释&#xff08;每小题5分,共15分&#xff09; 广告摄影&#xff1a; 曝光的互易律&#xff1a; 景别&#xff1a; 广告摄影试题第1页…

【渝粤教育】国家开放大学2018年春季 0675-22T中级财务会计(2) 参考试题

科目编号&#xff1a;0675 座位号 2017-2018学年度第二学期期末考试 中级财务会计&#xff08;2&#xff09; 试题 2018年 7 月 一、单选题&#xff08;本大题共10小题&#xff0c;每小题3分&#xff0c;共计30分&#xff09; &#xff08;★请考生务必将答案填入到下面对应序…

如何将Java应用程序置于Apache HTTP服务器之后

在过去 &#xff0c;将Apache HTTP服务器置于Java应用程序服务器或Java应用程序本身的前面是很常见的事情。 其背后的原因非常简单&#xff0c;可以以简单的方式添加缓存&#xff0c;还可以添加负载平衡&#xff0c;并且在此静态内容之上可以由Apache HTTP提供服务&#xff0c…

【渝粤教育】国家开放大学2018年春季 0703-22T经济学基础 参考试题

科目编号&#xff1a;0703 座位号 □□ 2017-2018学年度第二学期期末考试 经济学基础 试题 2018年7月 一、单项选择题&#xff1a;&#xff08;每题4分&#xff0c;共40分&#xff09; 一个经济体系必须回答的基本问题&#xff08; &#xff09; A&#xff0e;生产什么&#…

工业以太网交换机的概念及其主要功能介绍

随着互联网技术的快速发展&#xff0c;工业以太网在工业的通信领域也在大展身手&#xff0c;工业以太网交换机作为重要的通信设备&#xff0c;在整个工业通信行业中有着极其重要的功能&#xff01;下面&#xff0c;飞畅科技的小编就来为大家详细介绍一下什么是工业以太网交换机…

php 设置统一处理错误,统一的PHP错误处理理论

我建议去“异常”的方式。当有用户错误时抛出异常&#xff0c;您可以将php错误转换为异常&#xff0c;如下所示&#xff1a;function exception_error_handler($errno, $errstr, $errfile, $errline ) {throw new ErrorException($errstr, 0, $errno, $errfile, $errline);}set…