三年开发经验程序员可能都不懂SpringORM框架是如何访问数据库的

SpringORM框架访问数据库

Spring Boot提供了直接使用JDBC连接数据库的方式,但是使用JDBC并不是很方便,需要我们写更多的代码来完成对象和关系数据库的转换;另一种方式是将实体和实体的关系对应数据库的表和表的关系,这类工具通常是ORM工具,对实体和实体关系的操作会映射到数据库的操作。一般而言,在Spring Boot中,我们常用的ORM框架有JPA和MyBatis。Spring Data JPA默认采用Hibernate实现。

ORM的概念

对象关系映射(Object Relational Mapping,ORM)是通过使用描述对象和数据库之间映射的元数据,将面向对象语言程序中的对象自动持久化到关系数据库中。简单来说,就是将数据库表与Java实体对象做映射。

ORM的优缺点

● 优点:符合面向对象编程;技术与业务解耦,开发时不需要关注数据库的连接与释放。

● 缺点:ORM会牺牲程序的执行效率,会固定思维模式。

ORM的主流框架

包括Hibernate、JPA、MyBatis等。下面主要介绍基于JPA规范再次封装抽象实现的Spring Data JPA项目。在介绍Spring Data JPA之前,我们先简单介绍一下JPA。

什么是JPA

JPA是Java Persistence API的简称,中文名为Java持久层API,使用注解或XML描述对象与关系表的映射关系,并将运行期的实体对象持久化到数据库中。JPA包括以下3方面内容:

● 一套API标准:它在javax.persistence的包下面,用来操作实体对象,执行CRUD操作,程序在后台完成所有的事情,帮助开发者从烦琐的JDBC和SQL代码中解脱出来。

● 面 向 对 象 的 查 询 语 言 : Java PersistenceQueryLanguage(JPQL)。这是持久化操作中很重要的一个方面,通过面向对象而非面向数据库的查询语言来查询数据,避免与程序的SQL语句紧密耦合。

● Object/Relational Metadata:作为对象与表关系的映射,JPA支持XML和注解两种元数据形式,元数据描述对象和表之间的映射关系,框架据此将实体对象持久化到数据库表中。

JPA访问数据库实例

1.引入相应Maven依赖

2.添加配置文件application.yml

说明:
spring.jpa.database-platform这个参数主要用于指定默认的数据库存储引擎,在Spring Boot 2中,默认的MySQL数据库存储引擎是MyISAM,通过把取值设置为org.hibernate.dialect.MySQL5InnoDBDialect,就可以把默认的存储引擎切换为InnoDB。

3.创建Entity

4.创建OrderLog的父类BaseEntity


5.创建数据访问Repository

Repository是Spring Data的核心概念,抽象了对数据库和NoSQL的操作,提供了如下接口供开发者使用:

6.接口测试类UserController.java

Repository提供save方法来保存或者更新一个实体,默认情况下,如果Entity的主键属性为空,则认为是新的实体,保存实体;反之,如果Entity的主键属性不为空,则更新实体。

mybatis-spring-boot-starter实例

1.添加Maven依赖

2.在application.yml中添加相关配置

说明:Spring Boot会自动加载spring.datasource.*相关配置,数据源会自动注入sqlSessionFactory,sqlSessionFactory会自动注入Mapper。

3.在启动类中添加对mapper包的@MapperScan注解

4.开发Mapper实现数据操作

5.使用测试用例

通过上述几个步骤就基本完成了相关Dao层的开发,使用时当作普通的类注入就可以了。

总结一下,JPA的学习成本比MyBatis略高,MyBatis比JPA更灵活,使用MyBatis方式的同时可以使用XML的方式,进行添加User的映射文件,这里由于篇幅所限就不再赘述。上面我们主要介绍了SpringBoot通过JDBC和ORM的方式完成对关系数据库的访问,接下来我们将介绍Spring Boot如何实现对NoSQL数据存储的集成和管理。

本文给大家讲解的内容是微服务数据架构,数据分类及存储特性,SpringORM框架访问数据库

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,491评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,856评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,745评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,196评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,073评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,112评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,531评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,215评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,485评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,578评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,356评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,215评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,583评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,898评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,174评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,497评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,697评论 2 335

推荐阅读更多精彩内容