首页
学习
活动
专区
圈层
工具
发布

SqlAlchemy 2.0 中文文档(五十八)

参考:#10570 [orm] [bug] 修复了 ORM 注释声明中的错误,其中使用ClassVar,但仍然以某种方式引用 ORM 映射类名会导致无法解释为未映射的ClassVar。...参考:#9251 2.0.1 发布日期:2023 年 2 月 1 日 orm [orm] [bug] [回归] 修复了使用具有复合外键的连接表继承的 ORM 模型会在映射器内部遇到内部错误的回归...,它允许单个加载器选项自动递归到自引用关系中。...参考:#10967 [orm] [错误] 修复了在 with_expression() 实现中,如果使用的 SQL 表达式不可缓存,则会引发断言错误的问题;这是自 1.4 版以来的 2.0 版本的退化...引用:#10570 [orm] [bug] 修复了 ORM 注释声明中的错误,其中使用了一个 ClassVar,尽管以某种方式引用了 ORM 映射的类名,但未能被解释为未映射的 ClassVar

1.8K10

Rafy 领域实体框架 - 树型实体功能(自关联表)

在 Rafy 领域实体框架中,对自关联的实体结构做了特殊的处理,下面对这一功能进行讲解。 场景 在开发数据库应用程序时,往往会遇到自关联表的场景。...例如,分类信息、组织架构中的部门、文件夹信息等,都是不限制层级的。如下图中操作系统的文件夹: ? 在开发这类程序时,往往是设计一张表,表中的一个可空的外键直接引用这张表本身。对应的实体如下图: ?...而针对这样的场景,许多ORM框架都不做默认的处理,开发者往往每次都要做重复的工作:建立类似结构的表,编写关系处理代码,编写查询代码……而这种场景经常会出现,所以 Rafy 实体框架中,默认就支持了树型实体的一系列功能...功能及使用说明 在 Rafy 中的树型实体功能,只需开发者使用一行代码为指定的实体打开这个功能,框架会自动完成以下工作: 自动添加实体的自引用关系。自动生成数据库自关联表。...打开树型实体功能 开发者只需使用一行代码即可让指定的实体转变为树型实体。在指定实体的配置代码中,添加下面这行代码即可: ?

2.1K80
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    ASP.NET MVC5高级编程——(3)MVC模式的模型

    首先数据库中主外键的定义: 主键 外键 定义: 唯一标识一条记录,不能有重复的,不允许为空 表的外键是另一表的主键, 外键可以有重复的, 可以是空值 作用: 用来保证数据完整性 用来和其他表建立联系用的...这是为了给EF框架提供一个钩子,即方便模型到数据库的映射,不理解就记住,后面的项目会详细讲解。 从上面三个类的代码可以看到,红色标记的是主键,而黄色的就是外键。...5 什么是实体框架,什么是代码优先和数据上下文? 新建的ASP.NET MVC5项目会自动包含对实体框架(EF)的引用。...代码优先是指可以在不创建数据库模式、也不打开Visula Studio设计器的情况下,向SQL Server中存储或检索信息。...4.执行基架代码 4.1用实体框架创建数据库--local-DB虚拟数据空间 EF框架的代码优先方法会尽可能地使用约定而非配置(即MVC中的约定优于配置)。

    6.3K40

    Rafy 领域实体框架示例(1) - 转换传统三层应用程序

    Rafy 领域实体框架发布后,虽然有帮助文档,许多朋友还是反映学习起来比较复杂,希望能开发一个示例程序,展示如何使用 Rafy 领域实体框架所以,本文通过使用 Rafy 领域实体框架来改造一个传统的三层架构应用程序...——“服装进销存”系统,来讲解如何使用 Rafy 领域实体框架进行数据库应用程序的快速开发,以及替换为使用 Rafy 框架后带来的一些新功能。...还没有下载 Rafy 框架的同学,可以在《Rafy 框架发布》文中下载完整安装包。) 接下来,将说明如何进行代码转换,使用 Rafy 来开发一个典型的数据库应用程序。...原程序说明 考虑到要更好地演示如何使用 Rafy 框架来开发一个传统的管理系统,决定挑选一个开源系统进行改造,而这个系统应该是简单、常见的三层架构,这种系统大家都比较熟悉,这样就可以更加快速的理解框架的使用了...外键关系的转换 旧表中的外键引用关系,除了 Bill(销售单) 与 Sell(销售明细) 两个表间的关系,在设计 UML 时,都设计为实体间的引用关系。

    1.2K50

    SqlAlchemy 2.0 中文文档(十五)

    这两种用例是: 一个表包含对自身的外键,而且单个行将具有指向其自身主键的外键值。 两个表都包含对另一个表的外键引用,每个表中的一行引用另一个表中的另一行。...ON UPDATE CASCADE,没有外键支持 在使用不支持引用完整性的数据库,并且使用具有可变值的自然主键时,SQLAlchemy 提供了一个功能,允许将主键值传播到已引用的外键到有限程度,通过针对立即引用主键列的外键列发出...这两种用例是: 一张表包含一个指向自身的外键,而且一行将具有指向自己主键的外键值。 两个表分别包含一个外键引用另一个表,每个表中的一行引用另一个表。...在使用 SQLite 时,应启用引用完整性,使用 外键支持 中描述的配置。...另请参阅 邻接列表关系 - 如何配置自引用关系的详细说明,relationship.remote_side 的使用。

    98310

    MySQL8 中文参考(二)

    这意味着不可能使用外键删除引用自身的行。 没有存储引擎,包括InnoDB,识别或执行引用完整性约束定义中使用的MATCH子句。...SQL 标准中的MATCH子句控制如何处理复合(多列)外键中的NULL值,当与引用表中的主键进行比较时。MySQL 基本上实现了MATCH SIMPLE定义的语义,允许外键全部或部分为NULL。...在这种情况下,包含这种外键的(子表)行可以被插入,即使它与引用(父表)中的任何行都不匹配。(可以使用触发器实现其他语义。) 出于性能原因,MySQL 要求引用的列被索引。...另一方面,NDB存储引擎要求在任何作为外键引用的列上显式唯一键(或主键)。 对于包含非唯一键或包含NULL值的外键引用的处理对于诸如UPDATE或DELETE CASCADE等操作并不明确定义。...建议您使用仅引用UNIQUE(包括PRIMARY)和NOT NULL键的外键。 对于不支持外键的存储引擎(如MyISAM),MySQL 服务器解析并忽略外键规范。

    72410

    优化OEA中的聚合SQL

    之前写过几篇关于聚合对象SQL的文章,讲的是如果设计框架,使用一句SQL语句来加载整个聚合对象树中的所有数据。...本文中的内容与前面几篇的内容、与OEA框架中的内容相关性比较大,有兴趣的朋友可以关注CodePlex中的项目:《OpenExpressApp》 结果对比     优化前的代码,在前面的文章中已经有所展示...而列名的生成在原来的模式中已经使用了“表名+列名”的格式进行了约定,所以现在我们只需要把“描述如何加载的描述性数据”进行管理就可以了。...{ /// /// 加载子对象集合属性 /// Children, /// /// 加载外键引用实体...框架中对象的聚合加载的实现,和手写时一样,也是基于原有的ReadFromTable方法的,也不复杂,贴下代码,不再一一描述: /// /// 聚合实体的加载器 /// </summary

    2K70

    iOS面试题梳理(二)

    2.多个对象间依然会存在循环引用问题,形成一个环,在编程中,形成的环越大越不容易察觉,如下图所示: 解决方法: 1,事先知道存在循环引用的地方,在合理的位置主动断开一个引用,是对象回收; 2.使用弱引用的方法...KeyPath、KVC、KVO 键路径(KeyPath): 1.在一个给定的实体中,同一个属性的所有值具有相同的数据类型。 2.键-值编码技术用于进行这样的查找,它是一种间接访问对象属性的机制。...; 2.KVC的缺点:一旦使用 KVC 你的编译器无法检查出错误,即不会对设置的键、键路径进行错误检查,且执行效率要低于合成存取器方法和自定的 setter 和 getter 方法。...当我们释放我们的对象时,为什么需要调用[super dealloc]方法,它的位置又是如何的呢因为子类的某些实例是继承自父类的,因此需要调用[super dealloc]方法, 来释放父类拥有的实例,其实也就是子类本身的.... 2.在模块内的 static 全局变量可以被模块内所用函数访问,但不能被模块外其它函数访问. 3.在模块内的static函数只可被这一模块内的其它函数调用,这个函数的使用范围被限制在声明. 4.在类中的

    1.5K101

    C# .NET面试系列三:集合、异常、泛型、LINQ、委托、EF!

    如何自定义委托?在C#中,你可以通过声明一个委托类型来自定义委托。委托类型定义了委托可以引用的方法的签名。...7、代码优先EF支持代码优先(Code First)开发方式,开发人员可以通过编写实体类来定义数据库模型,然后通过迁移生成数据库,而不是通过数据库先有表结构再生成实体类。23. 什么是 ORM ?...通过使用 ORM,开发人员可以使用面向对象的代码来表示数据库中的表和记录,而无需手动编写和执行 SQL 查询。ORM 框架负责将对象模型与数据库结构进行映射,以及在应用程序中执行数据库操作。...它提供简单的API和高性能的查询,适用于小型和中型项目。33. 如何如何获取 EF 生成的 Sql 脚本?...2、类型安全使用泛型能够在编译时捕获类型错误,而不是在运行时。这提高了代码的可靠性和可维护性,因为在编写代码时就能够发现并解决潜在的类型相关问题。

    40910

    这个 IDEA 的兄弟,真香!

    JetBrains DataGrip 2020功能 数据编辑器 工具提示中的列注释 ? 智能代码 完成DataGrip提供上下文相关的代码完成,帮助您更快地编写SQL代码。...完成可以识别表格结构、外键,甚至是您正在编辑的代码中创建的数据库对象。 ? 即时分析和快速修复 DataGrip会检测代码中可能存在的错误,并建议动态修复它们的最佳选项。...它会立即让您了解未解决的对象,使用关键字作为标识符,并始终提供解决问题的方法。 ? 日志更新 完整的SQL日志,现在您将看到DataGrip在控制台输出中运行的每个查询。...要自定义Tab的此行为,请转到“首选项”| 编辑| 一般| 智能键并选择 跳转到关闭括号外/使用Tab键引用。 ?...导航 从“ 查找操作”分配快捷方式以前,如果使用 默认键盘映射,则无法从“ 查找操作”中指定快捷方式。我们已修复此错误,现在它适用于任何键盘映射和任何布局。一个很好的理由提醒你,这是可能的!

    1.9K10

    干掉 Navicat:这个 IDEA 的兄弟真香!

    JetBrains DataGrip 2020功能 数据编辑器 工具提示中的列注释 ? 智能代码 完成DataGrip提供上下文相关的代码完成,帮助您更快地编写SQL代码。...完成可以识别表格结构、外键,甚至是您正在编辑的代码中创建的数据库对象。 ? 即时分析和快速修复 DataGrip会检测代码中可能存在的错误,并建议动态修复它们的最佳选项。...它会立即让您了解未解决的对象,使用关键字作为标识符,并始终提供解决问题的方法。 ? 日志更新 完整的SQL日志,现在您将看到DataGrip在控制台输出中运行的每个查询。...要自定义Tab的此行为,请转到“首选项”| 编辑| 一般| 智能键并选择 跳转到关闭括号外/使用Tab键引用。 ?...导航 从“ 查找操作”分配快捷方式以前,如果使用 默认键盘映射,则无法从“ 查找操作”中指定快捷方式。我们已修复此错误,现在它适用于任何键盘映射和任何布局。一个很好的理由提醒你,这是可能的!

    1.5K20

    SqlAlchemy 2.0 中文文档(十二)

    ,其中表包含对自身的外键引用,换句话说是自引用关系。...在这里,city标准没有影响,因为刷新过程只关心将主键值同步到引用外键值中。## 创建自定义外键条件 主要连接条件的另一个元素是如何确定那些被认为是“外部”的列的。...## 重叠的外键 当使用复合外键时,可能会出现罕见的情况,使得单个列可能是通过外键约束引用的多个列的主题。...这里的 city 条件没有效果,因为刷新过程只关心将主键值同步到引用外键值。 创建自定义外键条件 主要连接条件的另一个元素是如何确定那些被认为是“外部”的列的。...重叠的外键 很少见的情况可能会出现,即使用复合外键,以便单个列可能是通过外键约束引用的多个列的主题。

    65910

    有了这个 IDEA的兄弟,你还用 Navicat 吗?全家桶不香吗?

    JetBrains DataGrip 2020功能 数据编辑器 工具提示中的列注释 ? 智能代码 完成DataGrip提供上下文相关的代码完成,帮助您更快地编写SQL代码。...完成可以识别表格结构、外键,甚至是您正在编辑的代码中创建的数据库对象。 ? 即时分析和快速修复 DataGrip会检测代码中可能存在的错误,并建议动态修复它们的最佳选项。...它会立即让您了解未解决的对象,使用关键字作为标识符,并始终提供解决问题的方法。 ? 日志更新 完整的SQL日志,现在您将看到DataGrip在控制台输出中运行的每个查询。...要自定义Tab的此行为,请转到“首选项”| 编辑| 一般| 智能键并选择 跳转到关闭括号外/使用Tab键引用。 ?...导航 从“ 查找操作”分配快捷方式以前,如果使用 默认键盘映射,则无法从“ 查找操作”中指定快捷方式。我们已修复此错误,现在它适用于任何键盘映射和任何布局。一个很好的理由提醒你,这是可能的!

    1.9K21

    干掉Navicat:这个IDEA的兄弟真香!

    JetBrains DataGrip 2020功能 数据编辑器 工具提示中的列注释 ? 智能代码 完成DataGrip提供上下文相关的代码完成,帮助您更快地编写SQL代码。...完成可以识别表格结构、外键,甚至是您正在编辑的代码中创建的数据库对象。 ? 即时分析和快速修复 DataGrip会检测代码中可能存在的错误,并建议动态修复它们的最佳选项。...它会立即让您了解未解决的对象,使用关键字作为标识符,并始终提供解决问题的方法。 ? 日志更新 完整的SQL日志,现在您将看到DataGrip在控制台输出中运行的每个查询。...要自定义Tab的此行为,请转到“首选项”| 编辑| 一般| 智能键并选择 跳转到关闭括号外/使用Tab键引用。 ?...导航 从“ 查找操作”分配快捷方式以前,如果使用 默认键盘映射,则无法从“ 查找操作”中指定快捷方式。我们已修复此错误,现在它适用于任何键盘映射和任何布局。一个很好的理由提醒你,这是可能的!

    1.4K20

    这个IDEA的兄弟,真香!

    JetBrains DataGrip 2020功能 数据编辑器 工具提示中的列注释 智能代码 完成DataGrip提供上下文相关的代码完成,帮助您更快地编写SQL代码。...完成可以识别表格结构、外键,甚至是您正在编辑的代码中创建的数据库对象。 即时分析和快速修复 DataGrip会检测代码中可能存在的错误,并建议动态修复它们的最佳选项。...它会立即让您了解未解决的对象,使用关键字作为标识符,并始终提供解决问题的方法。 日志更新 完整的SQL日志,现在您将看到DataGrip在控制台输出中运行的每个查询。...要自定义Tab的此行为,请转到“首选项”| 编辑| 一般| 智能键并选择 跳转到关闭括号外/使用Tab键引用。...导航 从“ 查找操作”分配快捷方式以前,如果使用 默认键盘映射,则无法从“ 查找操作”中指定快捷方式。我们已修复此错误,现在它适用于任何键盘映射和任何布局。一个很好的理由提醒你,这是可能的!

    1.2K20

    IDEA用好这个插件,终于可以扔掉Navicat了!

    JetBrains DataGrip 2020功能 数据编辑器 工具提示中的列注释 ? 智能代码 完成DataGrip提供上下文相关的代码完成,帮助您更快地编写SQL代码。...完成可以识别表格结构、外键,甚至是您正在编辑的代码中创建的数据库对象。 ? 即时分析和快速修复 DataGrip会检测代码中可能存在的错误,并建议动态修复它们的最佳选项。...它会立即让您了解未解决的对象,使用关键字作为标识符,并始终提供解决问题的方法。 ? 日志更新 完整的SQL日志,现在您将看到DataGrip在控制台输出中运行的每个查询。...要自定义Tab的此行为,请转到“首选项”| 编辑| 一般| 智能键并选择 跳转到关闭括号外/使用Tab键引用。 ?...导航 从“ 查找操作”分配快捷方式以前,如果使用 默认键盘映射,则无法从“ 查找操作”中指定快捷方式。我们已修复此错误,现在它适用于任何键盘映射和任何布局。一个很好的理由提醒你,这是可能的!

    5K20

    分享 Python 常见面试题及答案(下)

    ,读取速度快 2、建立索引、外键等 58、使用pop和del删除字典中的"name"字段,dic={"name":"zs","age":18} ?...59、列出常见MYSQL数据存储引擎 InnoDB:支持事务处理,支持外键,支持崩溃修复能力和并发控制。...,代码没有正确的对齐 IndexError:下标索引超出序列边界 KeyError:试图访问你字典里不存在的键 SyntaxError:Python代码逻辑语法出错,不能执行 NameError:使用一个还未赋予对象的变量...; 3、InnoDB 支持外键,MyISAM 不支持; 4、对于自增长的字段,InnoDB 中必须包含只有该字段的索引,但是在 MyISAM 表中可以和其他字段一起建立联合索引; 5、清空整个表时,InnoDB...2、方法定义、类定义与第一个方法之间,都应该空一行 3、三引号进行注释 4、使用Pycharm、Eclipse一般使用4个空格来缩进代码 94、正则表达式匹配第一个URL findall结果无需加group

    2.3K30

    使用ORM框架,必须迁就数据库的设计吗?

    - 非常复杂的数据库关系和架构,比如多个外键,级联查询,唯一性约束,参照完整性约束。...--由于PDF.NET框架是在实际商业产品中的应用,所以维护一直在进行,功能扩展和Bug修复一直在进行中; (3)ORM的框架众多,lz的产品优势在哪里?定位简单还是功能强大?...--框架的主要特点是具有iBatis的SQL-MAP功能和支持.NET 2.0的面向对象方式的查询表达式OQL,定位是简单易用,在使用 SQL-MAP的时候,只需要写好SQL语句,有代码工具自动生成DAL...--正因为有不同数据库的方言问题,所以框架使用SQL-MAP技术,将那些需要高效执行的、数据库特性的SQL单独写到配置文件中,当需要切换数据库的时候, 仅仅替换这个SQL配置文件即可(SQL-MAP配置文件...比如自定义函数和SQL类型等等 --PDF.NET的实体类本着从简的原则,实体类没有引入复杂关系的概念,遇到这些复杂的查询,可以使用SQL-MAP功能,它可以将DataReader的结果读入实体类中;

    2.4K90

    说实话,DataGrip真得牛逼,只是你不会用而已~

    如果需要激活教程:blog.idejihuo.com1、数据编辑器工具提示中的列注释智能代码完成DataGrip提供上下文相关的代码完成,帮助您更快地编写SQL代码。...完成可以识别表格结构、外键,甚至是您正在编辑的代码中创建的数据库对象。即时分析和快速修复DataGrip会检测代码中可能存在的错误,并建议动态修复它们的最佳选项。...它会立即让您了解未解决的对象,使用关键字作为标识符,并始终提供解决问题的方法。 2、日志更新完整的SQL日志,现在您将看到DataGrip在控制台输出中运行的每个查询。...要自定义Tab的此行为,请转到“首选项”| 编辑| 一般| 智能键并选择 跳转到关闭括号外/使用Tab键引用。...7、导航 从“ 查找操作”分配快捷方式以前,如果使用 默认键盘映射,则无法从“ 查找操作”中指定快捷方式。我们已修复此错误,现在它适用于任何键盘映射和任何布局。一个很好的理由提醒你,这是可能的!

    15.3K20
    领券