程序中数据库的操作历史和对数据库操作的实体类注意事项

Posted l-x-x-y-d-j

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了程序中数据库的操作历史和对数据库操作的实体类注意事项相关的知识,希望对你有一定的参考价值。

稍微了解一下程序中数据库操作历史吧!

1.首先是JDBC连接

2.c3p0

3.JPA

JPA是Java Persistence API的简称,中文名Java持久层API,是JDK 5.0注解或XML描述对象-关系表的映射关系,并将运行期的实体对象持久化到数据库中.

4.hibernate

     实现了全自动的ORM(对象关系映射)

  1. 数据持久化:用户只需要操作对象即可,内部将对象最终转化为sql.
  2. 结果集映射:将sql执行后的结果自动的映射为对象 

 缺点:

  1. 耗费内存
  2. 会形成冗余的sql,执行的效率较低
  3. 如果是关联查询,则需要冗余的配置,同时需要学习hsql

5.Mybatis

   以半自动的ORM的方式操作数据库

  1. sql语句需要自己手写
  2. 能够实现结果集映射.

6.通用Mapper等

    特点:基于Mybatis的,实现类单表的orm自动映射.

  以面向对象的方式操作单表.

  我们重点了解一下通用mapper,假设你们都会Mybatis

  通用Mapper底层原理

  1. 1.  定义公共的接口方法

    包含了单表操作的全部方法.CRUD等操作

  1. 将接口方法最终转为Sql语句

    例子:以新增为例

    Sql:  insert into 表名(字段名称) values(值….)

  1. 3.  将对象与表一一映射

对   象名称{对象的属性} >>>>> 表名(字段….)

  1. 最终形成sql

    Sql:insert into 表名(字段…) values(对象的属性值…….)

  使用通用Mapper对数据库进行操作,要对实体类进行一些操作:

  1.要在实体类 名上加上@Table注解,并加上表名,还要定义主键,以及自增@GeneratedValue(Strategy=GenerationType.IDENTITY)

  如果表不自增的话,就不要加@GeneratedValue(Strategy=GenerationType.IDENTITY)了

  技术分享图片

  2.定义操作数据库的Dao层,继承SysMapper<Item>,这里要引入通用mapper的.jar依赖。只能进行普通的增删改查

  复杂的话,还是自己写sql语句吧!

  技术分享图片

  

<!-- 通用Mapper -->

      <dependency>

          <groupId>com.github.abel533</groupId>

          <artifactId>mapper</artifactId>

          <version>${mapper.version}</version>

      </dependency>

  

以上是关于程序中数据库的操作历史和对数据库操作的实体类注意事项的主要内容,如果未能解决你的问题,请参考以下文章

qt对sqlite数据库多线程的操作

SpringBoot中Redis的setmaplistvalue实体类等基本操作介绍

qt对sqlite数据库多线程的操作

Entity Framework 的小实例:在项目中添加一个实体类,并做插入操作

实体类数据访问类

实体类数据访问类