首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

使用外键保存对象不返回数据库中的ID

在使用外键保存对象时,有时可能会遇到数据库中的ID没有返回的情况。以下是一些基础概念和相关问题的详细解答:

基础概念

  1. 外键(Foreign Key):外键是一个字段或一组字段,其值必须匹配另一个表的主键值。外键用于建立和加强两个表之间的链接。
  2. 主键(Primary Key):主键是唯一标识表中每一行的字段,通常是一个自增的整数。

可能的原因

  1. 事务未提交:如果在保存对象时使用了事务,但没有提交事务,数据库中的ID可能不会返回。
  2. ORM框架配置问题:某些ORM(对象关系映射)框架可能需要特定的配置才能正确返回生成的ID。
  3. 数据库驱动问题:使用的数据库驱动可能存在bug或不兼容问题,导致ID无法正确返回。
  4. 代码逻辑问题:在保存对象后,可能没有正确地获取或返回生成的ID。

解决方法

以下是一些常见的解决方法,假设使用的是Python和SQLAlchemy作为ORM框架:

1. 确保事务提交

代码语言:txt
复制
from sqlalchemy import create_engine, Column, Integer, ForeignKey
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import sessionmaker, relationship

Base = declarative_base()

class Parent(Base):
    __tablename__ = 'parent'
    id = Column(Integer, primary_key=True)
    children = relationship("Child")

class Child(Base):
    __tablename__ = 'child'
    id = Column(Integer, primary_key=True)
    parent_id = Column(Integer, ForeignKey('parent.id'))

engine = create_engine('sqlite:///example.db')
Base.metadata.create_all(engine)
Session = sessionmaker(bind=engine)
session = Session()

# 创建并保存对象
new_child = Child()
session.add(new_child)
session.commit()  # 确保提交事务

print(new_child.id)  # 应该打印出生成的ID

2. 检查ORM框架配置

确保ORM框架的配置正确,例如SQLAlchemy的sessionmakerrelationship配置。

3. 更新数据库驱动

如果怀疑是数据库驱动的问题,尝试更新到最新版本。

4. 检查代码逻辑

确保在保存对象后,正确地获取并返回生成的ID。

应用场景

  • 多表关联:在需要维护多个表之间关系的应用中,外键是必不可少的。
  • 数据完整性:通过外键约束,可以确保数据的完整性和一致性。

优势

  • 数据一致性:外键确保了引用表中的数据必须存在于被引用表中,从而保持数据的一致性。
  • 简化查询:通过外键关系,可以方便地进行跨表查询和关联操作。

类型

  • 单列外键:一个字段作为外键。
  • 复合外键:多个字段组合成一个外键。

通过以上方法和建议,应该能够解决在使用外键保存对象时不返回数据库中ID的问题。如果问题依然存在,建议检查具体的数据库日志或ORM框架的文档,以获取更多详细信息。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

为什么不推荐数据库使用外键?

我的经验告诉我,很多数据库(大多数我曾经使用的)不包含外键时并不总是一件坏事。在这篇文章中,我想把重点放在为什么的原因上。 为什么这是一个问题?...2.表格关系不清晰 数据库中缺少外键的另一个不太明显的负面影响是,不了解该模式的人很难找到正确的表并找出表关系。这可能会导致严重的数据库查询和报告问题。 为什么数据库可以没有外键?...让我们来看看数据库可以没有外键的原因。首先一个简短的免责声明(因为文章引发了一些关于LinkedIn群体的争议):下面的理由绝不鼓励不要在数据库中使用外键约束。...ORM(对象关系映射)框架或Ruby on Rails框架就是这种情况。 这些工具负责参照完整性,并与RDBMS一起创建更高级别的数据库引擎。这些框架可以自己创建数据库表,而不总是创建外键。...使用这些工具的开发人员很少会干扰自动生成的模式,并且不需要外键。

1.8K20

数据库不推荐使用外键的9个理由

来源:www.jdon.com/49188 我的经验告诉我,很多数据库(大多数我曾经使用的)不包含外键时并不总是一件坏事。在这篇文章中,我想把重点放在为什么的原因上。 为什么这是一个问题?...2.表格关系不清晰 数据库中缺少外键的另一个不太明显的负面影响是,不了解该模式的人很难找到正确的表并找出表关系。这可能会导致严重的数据库查询和报告问题。 为什么数据库可以没有外键?...让我们来看看数据库可以没有外键的原因。首先一个简短的免责声明(因为文章引发了一些关于LinkedIn群体的争议): 下面的理由绝不鼓励不要在数据库中使用外键约束。...ORM(对象关系映射)框架或Ruby on Rails框架就是这种情况。这些工具负责参照完整性,并与RDBMS一起创建更高级别的数据库引擎。这些框架可以自己创建数据库表,而不总是创建外键。...使用这些工具的开发人员很少会干扰自动生成的模式,并且不需要外键。

2.1K10
  • 数据库不推荐使用外键的 9 个理由

    2.表格关系不清晰 数据库中缺少外键的另一个不太明显的负面影响是,不了解该模式的人很难找到正确的表并找出表关系。这可能会导致严重的数据库查询和报告问题。 为什么数据库可以没有外键?...让我们来看看数据库可以没有外键的原因。首先一个简短的免责声明(因为文章引发了一些关于LinkedIn群体的争议): 下面的理由绝不鼓励不要在数据库中使用外键约束。...ORM(对象关系映射)框架或Ruby on Rails框架就是这种情况。这些工具负责参照完整性,并与RDBMS一起创建更高级别的数据库引擎。这些框架可以自己创建数据库表,而不总是创建外键。...使用这些工具的开发人员很少会干扰自动生成的模式,并且不需要外键。...SQL Server就是一个很好的例子 - 它不能在同一台服务器上的两个数据库上创建key。而且这种架构在大型系统中很常见。

    1.7K30

    一文一点 | 为什么不建议使用数据库外键

    那先复习下是什么外键,举一个最熟悉的例子: 学生表中的 student_id 是主键,那么成绩表中的 student_id 则为外键。...用外键不好么,不太好,但也注意,不是不可以,是不建议。 那么这里的不建议,其实也有两说的。 1、如果你为了追求正确性优先于性能的话,可以使用。...那么外键为什么有性能问题呢 1、数据库需要额外的维护外键自身的内部管理; 2、外键相当于把数据的一致性事务的实现,全部交给了数据库服务器来完成; 3、有了外键以后,当做一些涉及到外键字段的增,删,改操作时...,需要触发相关操作去检查,而不得不消耗资源; 4、每次更新数据,都需要额外的检查另外一张表的数据,容易造成死锁; 总结: 1、互联网行业场景中不推荐使用外键,用户量大,并发度高,如果使用外键,数据库服务器很容易产生性能瓶颈...2、传统行业可以使用,强调数据强一致性,而且用户数量有限,可控。 基于此,互联网场景中都是不建议使用外键的,外键与级联更新适用于单机低并发,不适合分布式、高并发集群。

    1.3K20

    数据库不使用外键的 9 个理由

    我的经验告诉我,很多数据库(大多数我曾经使用的)不包含外键时并不总是一件坏事。在这篇文章中,我想把重点放在为什么的原因上。 为什么这是一个问题? 1....表格关系不清晰 数据库中缺少外键的另一个不太明显的负面影响是,不了解该模式的人很难找到正确的表并找出表关系。这可能会导致严重的数据库查询和报告问题。 为什么数据库可以没有外键?...让我们来看看数据库可以没有外键的原因。首先一个简短的免责声明(因为文章引发了一些关于LinkedIn群体的争议): 下面的理由绝不鼓励不要在数据库中使用外键约束。...ORM(对象关系映射)框架或Ruby on Rails框架就是这种情况。这些工具负责参照完整性,并与RDBMS一起创建更高级别的数据库引擎。这些框架可以自己创建数据库表,而不总是创建外键。...使用这些工具的开发人员很少会干扰自动生成的模式,并且不需要外键。 5.

    1.2K10

    Mybatis使用generatedKey在插入数据时返回自增id始终为1,自增id实际返回到原对象当中的问题排查

    今天在使用数据库的时候,遇到一个场景,即在插入数据完成后需要返回此数据对应的自增主键id,但是在使用Mybatis中的generatedKey且确认各项配置均正确无误的情况下,每次插入成功后,返回的都是...终于凭借着一次Debugg发现的问题,原来在使用Mabatis中的insert或者insertSelective方式插入时,如使用int insert(TestGenKey testGenKey)时,返回值...int表示的是插入操作受影响的行数,而不是指的自增长id,那么返回的自增id到底去哪里了呢?...通过下面的Debugg我们知道自增id返回到testGenKey的原对象中去了。 举例示范配置 数据库示例表  generator的配置文件 <?...null : sex.trim(); } } 测试及Debugg 编写测试方法测试插入 插入成功后观察对应的变量对应的值 总结:调用Insert后插入操作之后,所得到自增长Id被赋值到原对象当中

    1.7K10

    删除数据库中未指定名称的外键的存储过程

    数据库中的某个表A,因为业务原因被移到别的库。麻烦的是,有几张子表(B, C, D等)建有指向它的外键,而且在创建时没有指定统一的外键名。...如此一来,在不同的环境(开发、测试、生产等)中该外键的名称不一样,必须逐个去查询外键名再进行删除,十分不便。...为此,特地编写了一个存储过程,只须指定子表名(B,C,D)和外键的列名,直接调用该存储过程即可。...Oracle的存储过程代码如下: -- 删除指定表、指定列上的外键(系统命名或未知名) CREATE OR REPLACE PROCEDURE DROP_FK(P_TABLE IN VARCHAR2,...: -- 删除指定表、指定列上的外键(系统命名或未知名) CREATE OR REPLACE FUNCTION DROP_FK(P_TABLE IN VARCHAR, P_COLUMN IN VARCHAR

    1.3K10

    .Net之使用Jquery Ajax通过FormData对象异步提交图片文件到服务端保存并返回保存的图片路径

    这篇文章中,我将要描述的是在我们.Net中如何使用Jquery Ajax通过FormData对象异步提交图片文件到后台保存,并返回保存的图片路径展示出图片,实现一个无刷新的异步图片上传的过程,当然这里我讲解的是单张图片的保存过程...FormData对象概述:   FormData对象是H5中的一个新特性,用以将数据编译成键值对,以便用XMLHttpRequest来发送数据。...其主要用于发送表单数据,但亦可用于发送带键数据(keyed data),而独立于表单使用。...Jquery Ajax通过FormData对象异步提交图片文件: HTML中选中图片的按钮: 头像 id="headPortrait...//返回完整的图片保存地址 92 result="/"+basePath + "/" + saveDir + "/" + saveName; 93 } 94 catch (Exception)

    2.3K20

    如何使用 Python 和 SQLAlchemy 结合外键映射来获取其他表中的数据

    在使用 Python 和 SQLAlchemy 时,结合外键映射可以让你在查询时轻松地获取其他表中的数据。...SQLAlchemy 提供了丰富的 ORM(对象关系映射)功能,可以让你通过定义外键关系来查询并获取关联的数据。下面我会演示如何设置外键关系,并通过 SQLAlchemy 查询获取其他表中的数据。...1、问题背景在使用 SQLAlchemy 进行对象关系映射时,我们可能需要获取其他表中的数据。...2.3 添加另一个外键如果我们需要在 Order 表中添加另一个外键,例如 product_id 字段,并且希望获取该订单所属产品的信息,那么我们可以在 Order 类中定义一个新的关系属性,使用 relationship...总结结合外键映射,你可以通过 SQLAlchemy 轻松地获取不同表之间关联的数据。你可以使用:relationship:设置表之间的关系(如外键),并通过 ORM 获取关联的数据。

    14310

    Java面试手册:数据库 ②

    使用数据库的必要性 无论是集合、对象、程序一旦重启所有数据全部消失,无法做到持久化保存 xml 是可以保存数据的 另外还可以通过IO流将数据保存到本地磁盘,但是数据缺乏结构化,无法描述复杂的业务逻辑...java 里面双引号表示String 类型,单引号表示char类型,而数据库中是char(长度不尅变)和varchar(长度可变) 关于数据库 一个项是数据库先行(表结构的设计、关系到项目的成败),每一个项目都有自己的数据库...数据库的组成:一个数据库是由多张表组成的,数据库中的数据保存在数据表中,数据白由两部分组成 表结构:列信息--->字段 表数据:行信息--->值 SQL入门 ?...数据库的设计是项目成功的最主要环节,(项目的重要)数据库中实现相关关系,主键 和外键不是必须有的,但是为了安全尽量使用。...java和数据库的对应关系)给表中的一个字段添加一个外键属性(从表),让它由相应的主键约束(主表),与其他表的主键构成关联关系,主键约束外键。

    1.3K20

    Django中ORM操作

    中的settings.py文件中设置 连接 MySQL数据库(Django默认使用的是sqllite数据库) DATABASES = { 'default': { 'ENGINE':...1、无需连表查询性能低,省硬盘空间(选项不固定时用外键) 2、在modle文件里不能动态增加(选项一成不变用Django的choice) 其他字段 db_index = True 表示设置索引 unique...width_field=None, 上传图片的高度保存的数据库字段名(字符串) height_field=None 上传图片的宽度保存的数据库字段名...,外键__外键列,反向是小写的表名 UserInfo.objects.values_list('nid','ug_id','ug__title') 反向连表: 反向操作无非2种方式: 1、通过对象的形式反向跨表...().first() result = obj.userinfo_set.all() [userinfo对象,userinfo对象,] 小写的表名 得到有外键关系的列 #因为使用values取值取得是字典的不是对象

    4.8K10

    SQL Server 数据库学习「建议收藏」

    大家好,又见面了,我是你们的朋友全栈君。 一、认识数据库 1、数据库的基本概念 2、数据库常用对象 3、数据库的组成 数据库主要由文件和文件组组成。数据库中所有的数据和对象都被存储在文件中。...(5)创建检查约束,检查约束可以把输入的数据限制在指定范围。 设计——选择一列——右击 check约束 (6)创建外键:外键是建立两个表数据之间连接的一列或多列。...通过将保存表中主键值的一列或多列添加到另一个表中,可以创建两个表之间的连接。这个列为第二个表的外键。...(1)简单基本连接 (2)内连接 内联接使用比较运算符根据每个表共有的列的值匹配两个表中的行。 如: (3)外连接 外连不但返回符合连接和查询条件的数据行,还返回不符合条件的一些行。...左外链接: 右外连接: 完全连接:返回两个表中所有匹配行和不匹配行 3.3.2 insert 插入语句 3.3.3 update语句修改指定的数据 3.3.4 delete 语句删除指定数据

    1.6K10

    python技术面试题(九)

    我们在项目开发过程中尽量少的使用外键,因为外键约束会影响插入和删除性能;使用缓存,减少对数据库的访问;需要多次连接数据库的一个页面,将需要的数据一次性的取出,减少对数据库的查询次数。...在Redis中,键总是一个字符串对象,而值可以是字符串、列表、集合等对象,所以我们通常说的键为字符串键,表示的是这个键对应的值为字符串对象,我们说一个键为集合键时,表示的是这个键对应的值为集合对象。...intset 编码的集合对象使用整数集合作为底层实现,集合对象包含的所有元素都被保存在整数集合中。...其中InnoDB支持事务,支持外键约束,它还支持行锁(比如select…for update语句,会触发行锁,但是锁定的是索引不是记录)。MyISAM不支持事务,不支持外键,它是数据库默认的引擎。...答:缓存穿透指的是缓存和数据库中该数据没有,但是用户不断的发起请求(如发起id为-1或者id特别大不存在该数据的请求),从而使得数据库压力过大。这样就要考虑是不是受到了攻击。

    91040

    Hibernate @OneToMany 及 @Cascade级联操作

    属性(级联)只设置“一”的一方即可,外键由“多”的一方进行维护。...@ManyToOne和@OneToMany 注解 ManyToOne(多对一)单向:不产生中间表,但可以用@Joincolumn(name=" ")来指定生成外键的名字,外键在多的一方表中产生。...OneToMany(一对多)单向:会产生中间表,此时可以用@onetoMany @Joincolumn(name=" ")避免产生中间表,并且指定了外键的名字(别看@joincolumn在一中写着,但它存在在多的那个表中...cascade属性:指定级联操作的行为(可多选) CascadeType.PERSIST:级联新增(又称级联保存):对A对象保存时也会对B对象进行保存。并且,只有A类新增时,会级联B对象新增。...image.png ★员工已经级联保存,但是员工表中的boss_id却是空,可见级联是直接将set中的对象持久化到数据库,而并没有对关系进行维护(需要手动去维护)。

    6.1K21

    Python自动化开发学习12-Mari

    主键: 主键是唯一的。一个数据表中只能包含一个主键。你可以使用主键来查询数据。 外键: 外键用于关联两个表。 复合键: 复合键(组合键)将多个列作为一个索引键,一般用于复合索引。...考勤表中的 student_id 要和学生信息表这的 id 建立外键关联。...FULL JOIN : 没有这句命令,不直接支持,但是可以实现 ? ? ? 多表联查的2张表不需要有外键关联。...由于上面建立的2张表建立了外键关联,record表中的student_id一定是在student表中的,所以上面 JOIN 语句使用 LEFT 是不会有更多记录的。...这个类型就是无符号的数字类型。数据类型一致后成功创建了包含外键关联的新表。 只是创建还不够,我们还要使用。上面的Exam类中少写了一行代码。

    2.7K10

    Hibernate【inverse和cascade属性】知识要点

    级联保存、更新、删除 级联保存 级联保存有什么用呢???我们来看个例子: 如果在保存对象的时候,没有把相关的对象也一并保存进数据库,会出现错误。...因为它会发现dept是有外键的,而外键又是一个对象来保存着,这个对象在数据库表中并没有存在,因此会抛出异常 //创建对象 Dept dept = new Dept();...这里写图片描述 如果我们在dept中设置了级联保存,那么Hibernate就会知道:保存dept的数据时,发现dept了外键,也把dept外键的对象保存在数据库之中 数据库中肯定是不能维护关联关系的【这里我们已经测试了】 但是呢,现在也设置了级联保存,级联保存是否可以让该对象相关的关联关系一并保存在数据库中的。...多对多关系的时候也是一样的,只不过多对多的关联关系是在中间表中 cascade属性 cascade有这么几个值: none 不级联操作, 默认值 save-update 级联保存或更新

    1.2K40

    MySQL(笔记)

    清除已有语句:\c 数据管理 外键(了解即可) 外键概念 如果公共关键字在一个关系中是主关键字,那么这个公共关键字被称为另一个关系的外键。由此可见,外键表示了两个关系之间的相关联系。...以另一个关系的外键作主关键字的表被称为主表,具有此外键的表被称为主表的从表。 在实际操作中,将一个表的值放入第二个表来表示关联,所使用的值是第一个表的主键值(在必要时可包括复合主键值)。...此时,第二个表中保存这些值的属性称为外键(foreign key)。 外键作用 保持数据一致性,完整性,主要目的是控制存储在外键表中的数据,约束。...使两张表形成关联,外键只能引用外表中的列的值或使用空值。...DROP INDEX FK_gradeid; 以上操作都是物理外键,数据库级别的外键,我们不建议使用!

    1.5K10
    领券