主键 外键

主键 外键

在这里插入图片描述

在关系型数据库中,主键(Primary Key)和外键(Foreign Key)是用于维护数据完整性和建立表之间关系的重要概念。

主键(Primary Key)

  • 定义: 主键是一个或多个列的组合,其值能够唯一标识表中的每一行。
  • 特性:
    • 唯一性: 主键的值必须是唯一的,不能重复。
    • 非空性: 主键列不能包含 NULL 值。
    • 单一性: 每个表只能有一个主键。
  • 用途: 主键用于确保每一行数据的唯一性,并作为其他表引用的基础。
示例

假设有一个 users 表:

CREATE TABLE users (
    user_id INT PRIMARY KEY,
    username VARCHAR(50),
    email VARCHAR(100)
);

在这个例子中,user_id 是主键,它唯一标识每个用户。

外键(Foreign Key)

  • 定义: 外键是一个或多个列的组合,其值引用另一个表中的主键。
  • 特性:
    • 引用完整性: 外键值必须在被引用的表中存在(或为 NULL)。
    • 多对一关系: 外键通常用于建立表之间的多对一关系。
  • 用途: 外键用于维护表之间的关系和引用完整性。
示例

假设有一个 orders 表,其中 user_id 是外键,引用 users 表的主键:

CREATE TABLE orders (
    order_id INT PRIMARY KEY,
    order_date DATE,
    user_id INT,
    FOREIGN KEY (user_id) REFERENCES users(user_id)
);

在这个例子中,user_id 是外键,它引用 users 表中的 user_id 主键。这确保了每个订单都与一个有效的用户相关联。

主键和外键的关系

  • 主键: 定义在一个表中,用于唯一标识该表中的记录。
  • 外键: 定义在一个表中,用于引用另一个表的主键,从而建立两个表之间的关系。

维护数据完整性

  • 级联操作: 可以设置外键约束的级联操作,如 ON DELETE CASCADE,以便在删除或更新主表记录时自动更新或删除相关的外键记录。
  • 约束检查: 数据库在插入或更新数据时会检查外键约束,以确保引用完整性。( 此时, 不使用 ON DELETE CASCADE 亦同 )

通过使用主键和外键,你可以确保数据库中的数据完整性,并建立表之间的关系,从而更好地组织和管理数据。

主键 外键 mybatis

在使用 MyBatis 进行数据库操作时,主键和外键的概念依然适用,因为它们是数据库层面的约束和关系。MyBatis 是一个持久层框架,它通过 XML 或注解的方式将 SQL 语句与 Java 对象进行映射。以下是如何在 MyBatis 中处理主键和外键的基本方法:

主键处理

  1. 自动生成主键

    在数据库中,主键通常是自动生成的(例如,自增 ID)。在 MyBatis 中,可以使用 useGeneratedKeyskeyProperty 来获取自动生成的主键值。

    <insert id="insertUser" parameterType="User" useGeneratedKeys="true" keyProperty="userId">
        INSERT INTO users (username, email) VALUES (#{username}, #{email})
    </insert>
    
    • useGeneratedKeys="true": 告诉 MyBatis 使用数据库生成的主键。
    • keyProperty="userId": 指定实体类中用于存储生成主键的属性。
  2. 手动设置主键

    如果主键不是自动生成的,你需要在插入数据时手动设置主键值。

    <insert id="insertUser" parameterType="User">
        INSERT INTO users (user_id, username, email) VALUES (#{userId}, #{username}, #{email})
    </insert>
    

外键处理

外键关系通常在数据库设计时定义。在 MyBatis 中,处理外键关系主要涉及到如何查询和映射相关联的数据。

  1. 一对多关系

    假设一个用户可以有多个订单,你可以在 MyBatis 中定义一个查询来获取用户及其订单列表。

    <select id="selectUserWithOrders" resultMap="UserOrderMap">
        SELECT u.user_id, u.username, o.order_id, o.order_date
        FROM users u
        LEFT JOIN orders o ON u.user_id = o.user_id
        WHERE u.user_id = #{userId}
    </select>
    
    <resultMap id="UserOrderMap" type="User">
        <id property="userId" column="user_id"/>
        <result property="username" column="username"/>
        <collection property="orders" ofType="Order">
            <id property="orderId" column="order_id"/>
            <result property="orderDate" column="order_date"/>
        </collection>
    </resultMap>
    
    • resultMap: 定义如何将查询结果映射到 Java 对象。
    • collection: 用于映射一对多关系,将多个订单映射到一个用户对象的 orders 属性。
  2. 多对一关系

    如果一个订单属于一个用户,你可以在订单查询中包含用户信息。

    <select id="selectOrderWithUser" resultMap="OrderUserMap">
        SELECT o.order_id, o.order_date, u.user_id, u.username
        FROM orders o
        JOIN users u ON o.user_id = u.user_id
        WHERE o.order_id = #{orderId}
    </select>
    
    <resultMap id="OrderUserMap" type="Order">
        <id property="orderId" column="order_id"/>
        <result property="orderDate" column="order_date"/>
        <association property="user" javaType="User">
            <id property="userId" column="user_id"/>
            <result property="username" column="username"/>
        </association>
    </resultMap>
    
    • association: 用于映射多对一关系,将用户信息映射到订单对象的 user 属性。

总结

  • 主键: 在 MyBatis 中,可以通过 useGeneratedKeyskeyProperty 来处理自动生成的主键。
  • 外键: 通过 resultMapcollectionassociation 来处理表之间的关系和数据映射。

通过这些配置,你可以在 MyBatis 中有效地处理主键和外键关系,确保数据的完整性和一致性。

主键 外键 hibernate

在 Hibernate 中,主键和外键的概念同样适用,因为它们是关系型数据库的基本组成部分。Hibernate 是一个对象关系映射(ORM)框架,它将 Java 对象映射到数据库表中。以下是如何在 Hibernate 中处理主键和外键的基本方法:

主键处理

  1. 简单主键

    在 Hibernate 中,简单主键通常使用 @Id 注解来标识。可以结合 @GeneratedValue 注解来自动生成主键值。

    import javax.persistence.Entity;
    import javax.persistence.GeneratedValue;
    import javax.persistence.GenerationType;
    import javax.persistence.Id;
    
    @Entity
    public class User {
        @Id
        @GeneratedValue(strategy = GenerationType.IDENTITY)
        private Long userId;
    
        private String username;
        private String email;
    
        // Getters and setters
    }
    
    • @Id: 标识主键字段。
    • @GeneratedValue: 指定主键生成策略。GenerationType.IDENTITY 通常用于自增主键。
  2. 复合主键

    对于复合主键,可以使用 @EmbeddedId@IdClass 注解。

    import javax.persistence.Embeddable;
    import java.io.Serializable;
    
    @Embeddable
    public class OrderId implements Serializable {
        private Long orderId;
        private Long userId;
    
        // Getters, setters, equals, and hashCode
    }
    
    import javax.persistence.EmbeddedId;
    import javax.persistence.Entity;
    
    @Entity
    public class Order {
        @EmbeddedId
        private OrderId id;
    
        private String orderDate;
    
        // Getters and setters
    }
    
    • @Embeddable: 用于定义复合主键类。
    • @EmbeddedId: 用于在实体中嵌入复合主键。

外键处理

外键用于定义实体之间的关系。在 Hibernate 中,使用 @ManyToOne, @OneToMany, @OneToOne, 和 @ManyToMany 注解来定义这些关系。

  1. 多对一关系

    在订单和用户之间的多对一关系中,订单表中的 userId 是外键。

    import javax.persistence.Entity;
    import javax.persistence.GeneratedValue;
    import javax.persistence.GenerationType;
    import javax.persistence.Id;
    import javax.persistence.ManyToOne;
    
    @Entity
    public class Order {
        @Id
        @GeneratedValue(strategy = GenerationType.IDENTITY)
        private Long orderId;
    
        private String orderDate;
    
        @ManyToOne
        private User user;
    
        // Getters and setters
    }
    
    • @ManyToOne: 定义多对一关系,通常在外键字段上使用。
  2. 一对多关系

    在用户和订单之间的一对多关系中,用户表中的 userId 是主键,订单表中的 userId 是外键。

    import javax.persistence.Entity;
    import javax.persistence.GeneratedValue;
    import javax.persistence.GenerationType;
    import javax.persistence.Id;
    import javax.persistence.OneToMany;
    import java.util.List;
    
    @Entity
    public class User {
        @Id
        @GeneratedValue(strategy = GenerationType.IDENTITY)
        private Long userId;
    
        private String username;
        private String email;
    
        @OneToMany(mappedBy = "user")
        private List<Order> orders;
    
        // Getters and setters
    }
    
    • @OneToMany: 定义一对多关系,mappedBy 属性指定关系的拥有方。
  3. 一对一关系

    使用 @OneToOne 注解来定义一对一关系。

    import javax.persistence.Entity;
    import javax.persistence.GeneratedValue;
    import javax.persistence.GenerationType;
    import javax.persistence.Id;
    import javax.persistence.OneToOne;
    
    @Entity
    public class UserProfile {
        @Id
        @GeneratedValue(strategy = GenerationType.IDENTITY)
        private Long profileId;
    
        private String address;
    
        @OneToOne
        private User user;
    
        // Getters and setters
    }
    
    • @OneToOne: 定义一对一关系。

总结

  • 主键: 使用 @Id@GeneratedValue 来定义和生成主键。
  • 外键: 使用关系注解(如 @ManyToOne, @OneToMany)来定义实体之间的关系。

通过这些注解和配置,你可以在 Hibernate 中有效地处理主键和外键关系,确保数据的完整性和一致性。

主键 外键 mybatis plus

MyBatis-Plus 是 MyBatis 的增强版,提供了许多便捷的功能来简化开发过程。在 MyBatis-Plus 中,主键和外键的处理与 MyBatis 类似,但它提供了一些额外的工具和注解来简化这些操作。

主键处理

  1. 自动生成主键

    MyBatis-Plus 支持自动生成主键,通常通过数据库的自增字段实现。你可以使用 @TableId 注解来指定主键字段,并设置主键生成策略。

    import com.baomidou.mybatisplus.annotation.IdType;
    import com.baomidou.mybatisplus.annotation.TableId;
    import com.baomidou.mybatisplus.annotation.TableName;
    
    @TableName("users")
    public class User {
        @TableId(value = "user_id", type = IdType.AUTO)
        private Long userId;
    
        private String username;
        private String email;
    
        // Getters and setters
    }
    
    • @TableId: 用于标识主键字段。
    • IdType.AUTO: 指定主键生成策略为自增。
  2. 手动设置主键

    如果主键不是自动生成的,你可以在插入数据时手动设置主键值。

    @TableId(value = "user_id", type = IdType.INPUT)
    private Long userId;
    
    • IdType.INPUT: 指定主键由用户输入。

外键处理

外键关系通常在数据库设计时定义。在 MyBatis-Plus 中,处理外键关系主要涉及到如何查询和映射相关联的数据。MyBatis-Plus 本身不直接处理外键关系,但你可以通过编写 SQL 查询和使用关联查询来实现。

  1. 一对多关系

    假设一个用户可以有多个订单,你可以在 MyBatis-Plus 中定义一个查询来获取用户及其订单列表。

    @TableName("orders")
    public class Order {
        @TableId(value = "order_id", type = IdType.AUTO)
        private Long orderId;
    
        private String orderDate;
        private Long userId;
    
        // Getters and setters
    }
    

    你可以使用自定义 SQL 查询来获取用户及其订单:

    @Select("SELECT u.user_id, u.username, o.order_id, o.order_date FROM users u LEFT JOIN orders o ON u.user_id = o.user_id WHERE u.user_id = #{userId}")
    List<UserWithOrders> selectUserWithOrders(@Param("userId") Long userId);
    
  2. 多对一关系

    如果一个订单属于一个用户,你可以在订单查询中包含用户信息。

    @Select("SELECT o.order_id, o.order_date, u.user_id, u.username FROM orders o JOIN users u ON o.user_id = u.user_id WHERE o.order_id = #{orderId}")
    OrderWithUser selectOrderWithUser(@Param("orderId") Long orderId);
    

总结

  • 主键: 使用 @TableId 注解来定义主键字段,并指定主键生成策略。
  • 外键: 通过自定义 SQL 查询和关联查询来处理表之间的关系。

MyBatis-Plus 提供了许多便捷的功能来简化数据库操作,但对于复杂的外键关系,仍然需要通过 SQL 查询来实现。通过这些配置和查询,你可以在 MyBatis-Plus 中有效地处理主键和外键关系,确保数据的完整性和一致性。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

初始Python篇(4)—— 元组、字典

找往期文章包括但不限于本期文章中不懂的知识点&#xff1a; 个人主页&#xff1a;我要学编程(ಥ_ಥ)-CSDN博客 所属专栏&#xff1a; Python 目录 元组 相关概念 元组的创建与删除 元组的遍历 元组生成式 字典 相关概念 字典的创建与删除 字典的遍历与访问 字典…

Maple :一款强大的计算软件,广泛应用于数学、工程、物理和其他科学领域

Maple 是一款强大的计算软件&#xff0c;广泛应用于数学、工程、物理和其他科学领域。它以其符号计算、数值计算和图形可视化能力而闻名&#xff0c;适用于从基础到高级的数学问题。以下是对 Maple 的详细介绍&#xff1a; 1. 基本功能 符号计算 &#xff1a;Maple 能够处理复…

RBAC 模型

系统权限控制最常采用的访问控制模型就是 RBAC 模型 。 什么是 RBAC 呢&#xff1f; RBAC 即基于角色的权限访问控制&#xff08;Role-Based Access Control&#xff09;。这是一种通过角色关联权限&#xff0c;角色同时又关联用户的授权的方式。 简单地说&#xff1a;一个用…

鸿蒙网络编程系列7-TLS安全数据传输单向认证示例

1.TLS简介 TLS&#xff08;Transport Layer Security&#xff09;协议的前身是SSL&#xff08;Secure Socket Layer&#xff09;安全套接层协议&#xff0c;由Netscape公司于1994年提出&#xff0c;是一套网络通信安全协议。IETF&#xff08;The Internet Engineering Task Fo…

ORACLE 19C安装 RAC报错

1. 问题描述 在Oracle 19C RAC的安装过程中&#xff0c;使用克隆方式在两个节点上部署集群。当第一个节点配置好基础服务后&#xff0c;关机并克隆节点。当尝试在第二个节点上通过页面进行RAC安装时&#xff0c;出现以下错误&#xff1a; [INS-32070] Could not remove the n…

Maven--简略

简介 Apache旗下的一款开源项目&#xff0c;用来进行项目构建&#xff0c;帮助开发者管理项目中的jar及jar包之间的依赖&#xff0c;还拥有项目编译、测试、打包的功能。 管理方式 统一建立一个jar仓库&#xff0c;把jar上传至统一的仓库&#xff0c;使用时&#xff0c;配置…

ArcGIS无插件加载(无偏移)在线天地图高清影像与街道地图指南

在地理信息系统&#xff08;GIS&#xff09;的应用中&#xff0c;加载高清影像与街道地图对于地图制图、影像查阅、空间数据分析等工作至关重要。天地图作为官方出品的地图服务&#xff0c;以其标准的数据、较快的影像更新速度等特点受到广泛欢迎。以下是如何在ArcGIS中无插件加…

【论文速读】Prompt Tuning:The Power of Scale for Parameter-Effificient Prompt Tuning

arxiv&#xff1a;2104.08691v2 摘要 在这项工作中&#xff0c;我们探索了“prompt tuning&#xff08;提示调优&#xff09;”&#xff0c;这是一种简单而有效的机制&#xff0c;用于学习“soft prompts&#xff08;软提示&#xff09;”&#xff0c;以条件下冻结的语言模型…

MATLAB智能算法 - AntColonyOptimization蚁群算法

AntColonyOptimization蚁群算法 智能算法是路线规划、深度学习等等一系列领域所使用的优化算法&#xff0c;是算法进阶之路的必备之路。 前言&#xff1a;本文主要围绕解决TSP旅行商问题展开&#xff0c;对于机器人的路线规划以及非线性方程求解的问题等解决方案 对于一些其他优…

leetcode289:生命游戏

根据 百度百科 &#xff0c; 生命游戏 &#xff0c;简称为 生命 &#xff0c;是英国数学家约翰何顿康威在 1970 年发明的细胞自动机。 给定一个包含 m n 个格子的面板&#xff0c;每一个格子都可以看成是一个细胞。每个细胞都具有一个初始状态&#xff1a; 1 即为 活细胞 &am…

Nest.js 实战 (十四):如何获取客户端真实 IP

问题解析 在 Nest.js 应用中&#xff0c;当你试图通过 request.ip 获取客户端的 IP 地址时&#xff0c;如果总是返回 ::1 或者 ::ffff:127.0.0.1&#xff0c;这通常意味着请求来自本地主机。 因为在前后端分离应用中&#xff0c;前端请求后端服务一般的做法都是通过代理&…

springboot051医院管理系统(论文+源码)_kaic

医院管理系统 摘要 随着信息互联网信息的飞速发展&#xff0c;医院也在创建着属于自己的管理系统。本文介绍了医院管理系统的开发全过程。通过分析企业对于医院管理系统的需求&#xff0c;创建了一个计算机管理医院管理系统的方案。文章介绍了医院管理系统的系统分析部分&#…

R语言机器学习遥感数据处理与模型空间预测技术及实际项目案例分析

随机森林作为一种集成学习方法&#xff0c;在处理复杂数据分析任务中特别是遥感数据分析中表现出色。通过构建大量的决策树并引入随机性&#xff0c;随机森林在降低模型方差和过拟合风险方面具有显著优势。在训练过程中&#xff0c;使用Bootstrap抽样生成不同的训练集&#xff…

2024大模型应用实践报告|附35页PDF文件下载

前言 今天分享的是大模型专题系列深度研究报告&#xff1a;《大模型专题&#xff1a;2024大模型应用实践报告&#xff1a;战略一致性&#xff0c;企业成功落地大模型的隐藏秘钥》 &#xff08;报告出品方&#xff1a;爱分析&#xff09; 报告共计&#xff1a;35页 1.报告综述…

某MDM主数据管理系统与微软Dynamic CRM系统(国内节点)集成案例

一、需求分析 需要完成的核心场景&#xff1a; 客户主数据&#xff1a;通过SAP PO集成中间件平台&#xff0c;某MDM主数据实时推送客户主数据信息至微软CRM系统&#xff0c;方便微软CRM系统进行客户方面的管理&#xff0c;并供微软CRM查询员工信息&#xff0c;修改员工&…

大数据-180 Elasticsearch - 原理剖析 索引写入与近实时搜索

点一下关注吧&#xff01;&#xff01;&#xff01;非常感谢&#xff01;&#xff01;持续更新&#xff01;&#xff01;&#xff01; 目前已经更新到了&#xff1a; Hadoop&#xff08;已更完&#xff09;HDFS&#xff08;已更完&#xff09;MapReduce&#xff08;已更完&am…

【Eclipse系列】解决Eclipse中xxx.properties文件中文乱码问题

问题描述&#xff1a;由于eclipse对Properties资源文件的编码的默认设置是ISO-8859-1&#xff0c;所以在打开.properties文件时&#xff0c;会发现中文乱码了&#xff0c;如图&#xff1a; 解决方法&#xff1a; 1、一次生效法 右击该properties文件–>properties–>Re…

暖水毯/取暖毯语音识别控制芯片IC方案

暖水毯、取暖毯作为现代家居生活的温暖伴侣&#xff0c;其智能化升级已是大势所趋。在暖水毯与取暖毯中融入语音识别控制芯片IC方案&#xff0c;为用户的冬日取暖体验带来了革命性的变革。 一、暖水毯/取暖毯增加语音识别控制芯片方案&#xff0c;让产品能通过对话来调节&…

5种边界填充

目录 边界填充需要知道的两个东西什么算边界边界的范围是多少举例 复制填充反射法反射101法外包装法数值填充法原图代码最终效果 边界填充需要知道的两个东西 什么算边界 顾名思义&#xff1a;就是图片的最外边 边界的范围是多少 根据你自己的需要而设置 举例 这里我选择…