Entity实体设计

Entity实体设计

💡用来和数据库中的表对应,解决的是数据格式在Java和数据库间的转换。

(一)设计思想

数据库 Java
对象
字段(列) 属性

(二)实体Entity编程

编码规范

💡Java中将所有数据库的数据,使用Java对象进行表示。

  • ① 通常一张表对应一个实体,命名规范:表名t_person,实体类名Person

  • ② 实体类必须实现Serializable

  • ③ 表中的一个字段,对应实体的一个属性。实体属性必须使用包装类型。封装并提供set和get方法。

  • ④ 必须手动提供无参构造方法(必须),如果需要也可以提供有参构造方法(非必要)

  • ⑤ 代码要放在entity包下

示例1:

  • MySQL库表

    create table t_person(
    person_id int primary key auto_increment,
    person_name varchar(20) not null,
    age tinyint,
    sex varchar(6),
    mobile varchar(20),
    address varchar(50)
    );

  • 实体类

    package com.xx.entity;
    //1. 实体类,实现序列化
    public class Person implements Serializable{
    // 2. 属性
    private Integer personId;
    private String personName;
    private Integer age;
    private String sex;
    private String mobile;
    private String address;
    // 3. 无参构造方法+有参构造方法(可选)
    public Person(){}
    // 4. get和set方法
    public Integer getPersonId(){return personId;}
    public void setPersonId(Integer personId){this.personId = personId;}
    public String getPersonName(){return personName;}
    public void setPersonName(String personName){this.personName = personName;}
    public Integer getAge(){return age;}
    public void setAge(Integer age){this.age = age;}
    public String getSex(){return sex;}
    public void setSex(String sex){this.sex = sex;}
    public String getMobile(){return mobile;}
    public void setMobile(String mobile){this.mobile = mobile;}
    public String getAddress(){return address;}
    public void setAddress(String address){this.address = address;}
    }

补充:

事实上JdbcTemplate的RowMapper的结果集映射对象,就是ORM思想的应用。

示例2:

  • MySQL库表

    复制代码
    create table t_account(
        account_id int primary key auto_increment,
        account_name varchar(20) not null unique,
        account_password varchar(20) not null,
        balance decimal(10,1)
    )
  • 实体类

    复制代码
相关推荐
liweiweili12611 分钟前
解决 MySQL 错误 1356 (HY000)
数据库·mysql
杨凯凡23 分钟前
MySQL函数触发:函数处理与触发器自动化应用
数据库·mysql
TDengine (老段)23 分钟前
TDengine 在新能源领域的价值
java·大数据·数据库·人工智能·时序数据库·tdengine·涛思数据
镜舟科技1 小时前
时序数据库、实时数据库与实时数仓:如何为实时数据场景选择最佳解决方案?
数据库·物联网·数据分析·时序数据库·olap·实时数仓·实时数据库
麻雀无能为力1 小时前
CAU数据库class2 SQL语言
数据库·sql·oracle
夜松云2 小时前
Qt框架核心组件完全指南:从按钮交互到定时器实现
数据库·qt·交互·信号与槽·ui组件·容器类·定时器机制
Elastic 中国社区官方博客2 小时前
JavaScript 中使用 Elasticsearch 的正确方式,第一部分
大数据·开发语言·javascript·数据库·elasticsearch·搜索引擎·全文检索
vvilkim2 小时前
深度解析:Redis 性能优化全方位指南
数据库·redis·性能优化
小光学长3 小时前
基于vue框架的东莞市二手相机交易管理系统5yz0u(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库
Freedom℡3 小时前
Spark,SparkSQL操作Mysql, 创建数据库和表
数据库·spark