JavaBean实体类处理外键过程解析

数据库中的表在映射为JavaBean的实体类时,实体类的字段名应与数据库表中的字段名一致。那么外键要怎么处理?

1. JavaBean中实体类中不应该出现外键字段,弊端如下 :

如果出现外键对应的字段,那么将会出现一个对象与另一个对象的属性相对应,这将不是面向对象中的对象与对象对应。

单个外键只能存储一个字符串,用处不大

2.外键处理方式 :数据库表中的外键字段应当转换成外键对应的表的对象,也就是JavaBean的实体类不声明外键的字段,而是声明外键对应数据表类的类型。举个例子,如下 :

数据库建表如下 :

-- 1.1 创建用户表
CREATE TABLE `user` (
 `uid` varchar(32) NOT NULL, #用户编号
 `username` varchar(20) DEFAULT NULL,   #用户名
 `password` varchar(20) DEFAULT NULL,   #密码
 `name` varchar(20) DEFAULT NULL,     #昵称
 `email` varchar(30) DEFAULT NULL,     #电子邮箱
 `telephone` varchar(20) DEFAULT NULL,   #电话
 `birthday` date DEFAULT NULL,       #生日
 `sex` varchar(10) DEFAULT NULL,      #性别
 `state` int(11) DEFAULT 0,        #状态:0=未激活,1=已激活
 `code` varchar(64) DEFAULT NULL,     #激活码
 PRIMARY KEY (`uid`)
) ENGINE=InnoDB ;

-- 2.1 创建分类表
CREATE TABLE `category` (
 `cid` varchar(32) NOT NULL,
 `cname` varchar(20) DEFAULT NULL, #分类名称
 PRIMARY KEY (`cid`)
) ENGINE=InnoDB ;

-- 3.1 创建商品表
CREATE TABLE `product` (
 `pid` varchar(32) NOT NULL,
 `pname` varchar(50) DEFAULT NULL,   #商品名称
 `market_price` double DEFAULT NULL,  #市场价
 `shop_price` double DEFAULT NULL,   #商城价
 `pimage` varchar(200) DEFAULT NULL,  #商品图片路径
 `pdate` date DEFAULT NULL,      #上架时间
 `is_hot` int(11) DEFAULT NULL,    #是否热门:0=不热门,1=热门
 `pdesc` varchar(255) DEFAULT NULL,  #商品描述
 `pflag` int(11) DEFAULT 0,      #商品标记:0=未下架(默认值),1=已经下架
 `cid` varchar(32) DEFAULT NULL,    #分类id
 PRIMARY KEY (`pid`),
 KEY `product_fk_0001` (`cid`),
 CONSTRAINT `product_fk_0001` FOREIGN KEY (`cid`) REFERENCES `category` (`cid`)
) ENGINE=InnoDB ;

-- 4 创建订单表
CREATE TABLE `order` (
 `oid` varchar(32) NOT NULL,
 `ordertime` datetime DEFAULT NULL,    #下单时间
 `total` double DEFAULT NULL,       #总价
 `state` int(11) DEFAULT NULL,       #订单状态:1=未付款;2=已付款,未发货;3=已发货,没收货;4=收货,订单结束
 `address` varchar(30) DEFAULT NULL,    #收获地址
 `name` varchar(20) DEFAULT NULL,     #收获人
 `telephone` varchar(20) DEFAULT NULL,   #收货人电话
 `uid` varchar(32) DEFAULT NULL,
 PRIMARY KEY (`oid`),
 KEY `order_fk_0001` (`uid`),
 CONSTRAINT `order_fk_0001` FOREIGN KEY (`uid`) REFERENCES `user` (`uid`)
) ENGINE=InnoDB ;

-- 5 创建订单项表
CREATE TABLE `orderitem` (
 `itemid` varchar(32) NOT NULL,
 `quantity` int(11) DEFAULT NULL,     #购买数量
 `total` double DEFAULT NULL,     #小计
 `pid` varchar(32) DEFAULT NULL,    #购买商品的id
 `oid` varchar(32) DEFAULT NULL,    #订单项所在订单id
 PRIMARY KEY (`itemid`),
 KEY `order_item_fk_0001` (`pid`),
 KEY `order_item_fk_0002` (`oid`),
 CONSTRAINT `order_item_fk_0001` FOREIGN KEY (`pid`) REFERENCES `product` (`pid`),
 CONSTRAINT `order_item_fk_0002` FOREIGN KEY (`oid`) REFERENCES `order` (`oid`)
) ENGINE=InnoDB ;

其中订单与订单项的JavaBean的实体类如下 :

/**
 * 订单项
 */
public class OrderItem {

  private String itemid ;   // 订单项编号
  private Integer quantity;    // 购买数量
  private Double total;  // 小计

  private Product product ;  // 商品对象
  private Order order ;    // 订单项所在订单对象
  ......
}

/**
 * 订单实体类
 */
public class Order {

  private String oid ;    // 订单编号
  private Date ordertime; // 下单时间
  private Double total ;   // 总价
  private Integer state ;   // 订单状态 : 1 : 未付款 2 : 已付款,未发货  3 :已发货,未收货  4: 已收货,订单结束
  private String address ;  // 收货地址
  private String name ;    // 收件人姓名 : 收件人不一定是购买人
  private String telephone ; // 收件人电话

  private User user ;     // 订单所属的用户

  private List<OrderItem> list = new ArrayList<>() ; // 订单项集合
  ......
}

这样做的优点如下 :

  • 程序对象和对象产生关系,而不是对象(Order的对象)和对象的属性(User对象的uid)产生关系
  • 设计Order的目的 : 让order携带订单上的数据向service层,dao层传递,user对象是可以携带更多的数据的
  • 程序中体现订单对象和订单项对象之间的关系,项目中的部分功能中有类似的需求 : 查询订单的同时,还要获取订单下所有的订单项

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Java工具类BeanUtils库介绍及实例详解

    BeanUtils工具由Apache软件基金组织编写,提供给我们使用,主要解决的问题是:把对象的属性数据封装到对象中. 在整个J2EE的编程过程中,我们经常会从各种配置文件中读取相应的数据,需要明白的一点是从配置文件中读取到的数据都是String,但是很显然我们的应用程序中不仅仅有String一种数据类型,比如:基本数据类型(int.double.char.float等),还有自定义数据类型(引用数据类型), 那么我们必须面临的一个问题就是讲字符串类型转换为各种具体的数据类型,该怎么办呢? 有两

  • 浅谈java分页三个类 PageBean ResponseUtil StringUtil

    如下所示: package ssmy.page; /** * 分页类 * @author Jesse * */ public class PageBean { private int page;//第几页 private int pageSize;//每页显示的记录数 private int start ;//起始记录数 public int getPage() { return page; } public void setPage(int page) { this.page = page;

  • JavaWeb BeanUtils信息类原理详解

    这篇文章主要介绍了JavaWeb BeanUtils信息类原理详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 一.BeanInfo 1.BeanInfo是JavaBean类的信息类,一个javaBean的信息封装在对应beanInfo对象中 2.要获取到beanInfo,一般通过一个内省类Introspector的一个方法getBeanInfo(Class<T> beanClass),给个javaBean的类型就会返回对应的beanInf

  • Java类获取Spring中bean的5种方式

    获取Spring中的bean有很多种方式,再次总结一下: 第一种:在初始化时保存ApplicationContext对象 ApplicationContext ac = new FileSystemXmlApplicationContext("applicationContext.xml"); ac.getBean("beanId"); 说明:这种方式适用于采用Spring框架的独立应用程序,需要程序通过配置文件手工初始化Spring. 第二种:通过Spring提供

  • 基于Java反射的map自动装配JavaBean工具类设计示例代码

    前言 JavaBean是一个特殊的java类,本文将给大家详细介绍关于基于Java反射的map自动装配JavaBean工具类设计的相关内容,下面话不多说了,来一起看看详细的介绍吧 方法如下 我们平时在用Myabtis时不是常常需要用map来传递参数,大体是如下的步骤: public List<Role> findRoles(Map<String,Object> param); <select id="dindRoles" parameterType=&qu

  • JavaBean和Map转换封装类的方法

    实例如下: package com.ljq.util; import java.beans.BeanInfo; import java.beans.Introspector; import java.beans.PropertyDescriptor; import java.lang.reflect.Method; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.ut

  • java中用ObjectMapper类实现Json与bean的转换示例

    前言 ObjectMapper是jackson中的方法,本文主要给大家介绍了关于java中用ObjectMapper类实现Json与bean转换的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧. 一.将json字符串转为bean public class JsonToJavaBean { public static void main(String[] args) { String str="{\"student\":[{\"name\&q

  • Java类库BeanUtils组件使用方法及实例详解

    BeanUtils BeanUtils是Apache commens组件里面的成员,由Apache提供的一套开源api,用于简化对javaBean的操作,能够对基本类型自动转换. JavaBean BeanUtils组件是用于简化javaBean的操作,那么什么是javaBean呢?简单来说,javaBean实质就是java类,只不过是遵循了某种规范的java类. javaBean的特点: 必须具有一个无参的构造方法 属性必须私有化 私有化的属性必须通过public类型的方法来暴露,也就是说要出

  • JavaBean实体类处理外键过程解析

    数据库中的表在映射为JavaBean的实体类时,实体类的字段名应与数据库表中的字段名一致.那么外键要怎么处理? 1. JavaBean中实体类中不应该出现外键字段,弊端如下 : 如果出现外键对应的字段,那么将会出现一个对象与另一个对象的属性相对应,这将不是面向对象中的对象与对象对应. 单个外键只能存储一个字符串,用处不大 2.外键处理方式 :数据库表中的外键字段应当转换成外键对应的表的对象,也就是JavaBean的实体类不声明外键的字段,而是声明外键对应数据表类的类型.举个例子,如下 : 数据库

  • Mybatis实现插入数据后返回主键过程解析

    添加记录后获取主键ID,这是一个很常见的需求,特别是在一次前端调用中需要插入多个表的场景. 除了添加单条记录时获取主键值,有时候可能需要获取批量添加记录时各记录的主键值,MyBatis从3.3.1版本开始支持批量添加记录并返回各记录主键字段值. 一.获取新添加记录主键字段值 注意: 在MyBatis中添加操作返回的是记录数并非记录主键id. 如果需要获取新添加记录的主键值,需要在执行添加操作之后,直接读取Java对象的主键属性. Integer rows = sqlSession.getMapp

  • django在开发中取消外键约束的实现

    我就废话不多说了,大家还是直接看代码吧! # 在setting设置外键 'OPTIONS': { "init_command": "SET foreign_key_checks = 0;", } 补充知识:django-给外键关系传值,删除外键关系 反查: 在表关系里 related_name = '反查name',自己不设置,django也会默认设置为class的小写名字+_set , ex: book_set. 一对一关系赋值: class ModelStudy

  • Mybatis-Plus实体类注解方法与mapper层和service层的CRUD方法

    目录 1 注解 1.1 @TableName 1.2 @TableId 1.3 @TableField 1.4 @TableLogic 2 mapper层的CRUD方法 2.1 增(insert) 2.2 删(delete) 2.3 改(update) 2.4 查(select) 3 service层的CRUD方法 3.1 批量添加或者更新 3.2 查询表中总记录数 1 注解 1.1 @TableName   之前在入门案例中我们分析过:使用mp底层方法生成的SQL语句中,表名为mapper或者

  • 解析ABP框架领域层中的实体类与仓储类

    领域层 实体是DDD(领域驱动设计)的核心概念之一.Eric Evans是这样描述的"很多对象不是通过它们的属性定义的,而是通过一连串的连续性事件和标识定义的"(引用领域驱动设计一书). 译者注:对象不是通过它们的属性来下根本性的定义,而应该是通过它的线性连续性和标识性定义的..所以,实体是具有唯一标识的ID且存储在数据库中.实体通常被映射成数据库中的一个表. 实体类(Entity classes) 在ABP中,实体继承自Entity类,请看下面示例: public class Per

  • 如何理解Java中基类子对象的构建过程从"基类向外"进行扩散的?

    <Java编程思想>复用类一章,提出基类的子对象的构建过程是从基类"向外"进行扩散的. 下面通过实例进行讲解,首先看下面的代码: import static net.mindview.util.Print.*; //<java编程思想>提供的类库 /** * @author Administrator * */ public class Cat extends Animal { public Cat() { // TODO Auto-generated cons

  • 调用其他python脚本文件里面的类和方法过程解析

    这篇文章主要介绍了调用其他python脚本文件里面的类和方法过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 问题描述: 自己编写了若干个Python脚本. 在testC.py里面需要调用testA.py和testB.py里面的若干类和方法.要怎么办? 需要都打包.安装,再去调用吗? 其实不必那么麻烦. 这里有个前提,testA.py, testB.py, testC.py在同级目录下. 如果不在同级目录,后面会补充介绍如何把路径包含过来

  • Java实体类实现链式操作实例解析

    这篇文章主要介绍了Java实体类实现链式操作实例解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 原来是这么写bean的,单纯的使用get.set方法,再加一个toString package Model; /** * @author: Davion * @date: 2019/12/11 * @description: */ public class User { private Integer id; private String nam

  • mybatis-plus实体类主键策略有3种(小结)

    mybatis plus 实体类主键策略有3种( 注解 > 全局 > 默认 ) 当IdType的类型为ID_WORKER.ID_WORKER_STR或者UUID时,主键由MyBatis Plus的IdWorker类生成,idWorker中调用了分布式唯一 ID 生成器 - Sequence 1.注解方式 @TableId(type = IdType.AUTO)在实体类增加注解即可 @TableName("t_article") public class TArticle e

  • Java cglib为实体类(javabean)动态添加属性方式

    1.应用场景 之前对接三方平台遇到一个参数名称是变化的,然后我就想到了动态javabean怎么生成,其实是我想多了,用个map就轻易解决了,但还是记录下动态属性添加的实现吧. 2.引入依赖 <!--使用cglib 为javabean动态添加属性--> <dependency> <groupId>commons-beanutils</groupId> <artifactId>commons-beanutils</artifactId>

随机推荐