发布说明 1.0
TypeORM 1.0 是一个重大版本,移除了长期弃用的 API,现代化了平台要求,并带来了在 0.3.x 周期中积累的数十个错误修复和新功能。
破坏性变更
有关详细的升级说明,请参阅 升级指南。
平台要求
- 要求 Node.js 20+ — 已移除对 Node.js 16 和 18 的支持,最低 JavaScript 目标版本现为 ES2023 (#11382 by @alumni)
- 移除
Bufferpolyfill — 现在在非 Node 平台上使用Uint8Array处理二进制数据;Node.jsBuffer(继承自Uint8Array)继续像以前一样工作 (#11935 by @pujux) - 替换 Glob 库 —
glob已替换为tinyglobby,rimraf已被移除,减少了依赖项 (#11699 by @alumni) - 哈希迁移至原生
crypto—sha.js和uuid包已被原生crypto模块和crypto.randomUUID()替代 (#11864 by @G0maa, #11769 by @mag123c)
驱动变更
- MySQL / MariaDB:弃用
mysql包 — 仅支持mysql2;已移除connectorPackage选项 (#11766 by @pkuczynski) - MySQL:
legacySpatialSupport默认值改为false— 默认使用标准的ST_GeomFromText/ST_AsText函数 (#12083 by @pkuczynski) - MySQL:移除
width和zerofill列选项 — 这些选项在 MySQL 8.0.17 中已被弃用,并在 MySQL 8.4 中移除 (#12084 by @pkuczynski) - SQLite:弃用
sqlite3,better-sqlite3成为默认驱动 — 不再支持sqlite3包;已移除flags和busyTimeout选项 (#11836 by @pkuczynski) - MongoDB:要求驱动 v7+ — 已放弃对 MongoDB Node.js 驱动 v5/v6 的支持;移除
stats()方法;移除已弃用的连接选项;不再导出内部类型 (#12208 by @naorpeled, #12179 by @pkuczynski, #12120 by @pkuczynski, #12037 by @alumni) - MS SQL Server:移除
domain连接选项 — 请改用类型为 NTLM 的authentication选项 (#12135 by @pkuczynski) - MS SQL Server:
options.isolation重命名为options.isolationLevel— 值格式从READ_COMMITTED更改为READ COMMITTED以匹配IsolationLevel类型;新增SNAPSHOT隔离级别 (#12231 by @Cprakhar) - SAP HANA:移除已弃用的连接别名 — 已移除
hanaClientDriver、pool.max、pool.requestTimeout、pool.idleTimeout等选项,请改用其现代等效选项 (#12080 by @gioboa) - Expo:移除旧版驱动 — 已移除旧版 Expo SQLite 驱动;请使用 Expo SDK v52+ 及现代异步 API (#11860 by @G0maa)
- Redis:移除旧版客户端支持 — 查询结果缓存仅支持现代 Redis 客户端(v4+) (#12057 by @G0maa)
移除的 API
- 移除
Connection和ConnectionOptions— 请改用DataSource和DataSourceOptions(#12022 by @alumni) .connection属性重命名为.dataSource—Driver、QueryRunner、EntityManager、QueryBuilder、EntityMetadata以及所有*Event订阅者接口上的connection属性已重命名为dataSource;提供了一个已弃用的 getter 作为过渡 (#12244, #12245, #12246, #12249 by @pkuczynski)- 移除
ConnectionManager及全局便捷函数 — 已移除createConnection、getConnection、getManager、getRepository、createQueryBuilder及其他全局函数 (#12098 by @michaelbromley) - 移除
getMongoRepository和getMongoManager全局函数 — 请改用dataSource.getMongoRepository()和dataSource.mongoManager(#12099 by @pkuczynski) - 移除
DataSource.name— 命名连接已在 v0.3 中弃用;ConnectionOptionsReader.all()已重命名为get()(#12136 by @pkuczynski) - 移除
TYPEORM_*环境变量支持 — 已移除ConnectionOptionsEnvReader、ormconfig.env以及dotenv自动加载功能 (#12134 by @pkuczynski) - 移除
findByIds— 请改用带有In操作符的findBy(#12114 by @pkuczynski) - 移除
findOneById— 请改用findOneBy(#12198 by @pkuczynski) - 移除
Repository.exist()— 请改用Repository.exists()(#12131 by @pkuczynski) - 移除
AbstractRepository、@EntityRepository和getCustomRepository— 请改用Repository.extend()(#12096 by @pkuczynski) - 移除
@RelationCount装饰器 — 请改用带有子查询的@VirtualColumn(#12181 by @pkuczynski) - 移除 IoC 容器系统 — 已移除
useContainer()、getFromContainer()及相关类型 (#12180 by @pkuczynski) - 移除
readonly列选项 — 请改用update: false(#12132 by @pkuczynski) - 移除
ColumnNumericOptions上的unsigned— 仅影响 decimal/float 类型;整型的unsigned保持不变 (#12133 by @pkuczynski) - QueryBuilder:移除
onConflict()、已弃用的orUpdate()重载以及setNativeParameters()— 请改用orIgnore()/orUpdate()的数组签名以及setParameters()(#12090 by @pkuczynski) - QueryBuilder:移除
printSql()— 该方法是冗余的,因为所有已执行的查询都已通过配置的记录器进行日志记录;请改用getSql()或getQueryAndParameters()来检查 SQL (#12151 by @naorpeled, #12220 by @pkuczynski) - QueryBuilder:移除
WhereExpression类型别名 — 请改用WhereExpressionBuilder(#12097 by @pkuczynski) - QueryBuilder:移除
replacePropertyNames()— 该方法为空操作(no-op) (#12178 by @pkuczynski) - 移除
join查找选项 — 对于 LEFT JOIN 请使用relations,其他连接类型请使用 QueryBuilder (#12188 by @pkuczynski) - 移除基于字符串的
select— 请使用对象语法select: { id: true }替代select: ["id"](#12214 by @pkuczynski) - 移除基于字符串的
relations— 请使用对象语法relations: { profile: true }替代relations: ["profile"](#12215 by @pkuczynski) - 移除已弃用的锁模式 —
pessimistic_partial_write和pessimistic_write_or_fail已被带有onLocked选项的pessimistic_write替代 (#12093 by @pkuczynski) - 移除
QueryRunner.loadedTables和loadedViews— 请改用getTables()和getViews()(#12183 by @pkuczynski) - 移除
MigrationExecutor.getAllMigrations()— 请改用getPendingMigrations()、getExecutedMigrations()或dataSource.migrations(#12142 by @pkuczynski) - 移除
EntityMetadata.createPropertyPath()静态方法 — 属于内部工具方法,无公开替代方案 (#12141 by @pkuczynski) - 从驱动和查询构建器中移除内部
nativeParameters管道逻辑 (#12104 by @pkuczynski) - 从 Broadcaster 中移除内部
broadcastLoadEventsForAll()(#12137 by @pkuczynski) - 移除内部
DriverUtils.buildColumnAlias()— 请改用buildAlias()(#12138 by @pkuczynski) - 移除
RdbmsSchemaBuilder.renameTables()— 该方法为空操作且从未被调用 (#12284 by @naorpeled)
行为变更
- 不可空关联现在使用 INNER JOIN — 标记为
nullable: false的ManyToOne和主控端OneToOne关联现在使用INNER JOIN而非LEFT JOIN,这可能会排除具有悬空外键的行 (#12064 by @pkuczynski) invalidWhereValuesBehavior默认值改为throw— 在 where 条件中传递null或undefined现在会抛出错误,而不是静默忽略该属性;请使用IsNull()进行空值匹配 (#11710 by @naorpeled)invalidWhereValuesBehavior仅作用于高级 API — QueryBuilder 的.where()、.andWhere()、.orWhere()不再受此设置影响 (#11878 by @naorpeled)
新功能
查询构建器
INSERT INTO ... SELECT FROM ...—InsertQueryBuilder新增valuesFromSelect()方法,用于数据迁移和转换查询 (#11896 by @Cprakhar)- update/upsert 的
returning选项 — 仓库和实体管理器的update()和upsert()方法现在在支持RETURNING子句的数据库上支持returning选项 (#11782 by @naorpeled) - 所有 drop 方法的
ifExists参数 —dropColumn、dropIndex、dropPrimaryKey、dropForeignKey、dropUniqueConstraint、dropCheckConstraint、dropExclusionConstraint及其复数变体现在接受ifExists标志 (#12121 by @pkuczynski) QueryRunner的显式资源管理 — 支持await using语法(TypeScript 5.2+)实现自动清理 (#11701 by @alumni)
驱动
- PostgreSQL:枚举变更使用
ADD VALUE— 添加新枚举值时,TypeORM 现在尽可能使用更简单的ALTER TYPE ... ADD VALUE语法,而非四步重命名-创建-迁移-删除方案 (#10956 by @janzipek) - PostgreSQL:附加扩展 — 新增
installExtensions选项,在连接设置期间安装额外的 PostgreSQL 扩展 (#11888 by @Cprakhar) - PostgreSQL:部分索引支持 — 添加对 PostgreSQL 部分索引的支持 (#11318 by @freePixel)
- SAP HANA:SELECT 中的锁定 — 现在在 SAP HANA 查询中支持
FOR UPDATE和其他锁定模式 (#11996 by @alumni) - SAP HANA:表注释 —
@Entity({ comment: "..." })现在支持 SAP HANA (#11939 by @Cprakhar) - SAP HANA:池超时 — 新增
maxWaitTimeoutIfPoolExhausted池选项 (#11868 by @alumni) - SQLite:
jsonb列类型 — SQLite 现在支持jsonb列类型 (#11933 by @Cprakhar) - React Native:加密密钥 — 新增选项用于传递 React Native SQLite 数据库的加密密钥 (#11736 by @HtSpChakradharCholleti)
持久化与插入更新
clear()中的级联截断 —Repository.clear()和EntityManager.clear()现在接受{ cascade: true }以在 PostgreSQL、CockroachDB 和 Oracle 上执行TRUNCATE ... CASCADE(#11866 by @Cprakhar)increment/decrement的更好的类型 — 条件参数现在使用正确的实体感知类型,而非any(#11294 by @OSA413)
列类型与装饰器
其他
- v1 迁移的自动化 codemod — 新增
@typeorm/codemod包,可自动处理大部分破坏性变更:运行npx @typeorm/codemod v1 src/即可更新导入、API 重命名、find 选项语法等 (#12233 by @pkuczynski) - 改进的 ormconfig 错误处理 — 加载失败现在会记录警告日志,而不是静默失败 (#11871 by @Cprakhar)
Bug 修复
查询生成
orderBy中的列别名正确转义 — 防止别名与保留字冲突时产生 SQL 错误 (#12027 by @Cprakhar)addOrderBy解析数据库列名 — 使用数据库列名(例如created_at)而非属性名现已正确工作 (#11904 by @smith-xyz)- 子查询列排序解析 — 修复了按子查询列排序时出现 "Cannot get metadata for given alias" 错误的问题 (#11343 by @trannhan0810)
select列顺序保留 —getQuery()/getSql()现在按照通过select()和addSelect()添加的顺序返回列 (#11902 by @Cprakhar).update()查询生成修复 — 修复了使用 QueryBuilder.update()时 SQL 生成错误的问题 (#11993 by @gioboa)- 带表别名的 Upsert SQL 生成 — 修复了表继承和自定义模式下 upsert 查询中的错误列引用问题 (#11915 by @Cprakhar)
- 带连接的限制 — 修复了使用
skip/take分页与连接时的错误结果问题 (#11987 by @gioboa) - 括号内的连接属性 — 修复了条件包含括号时的连接解析问题 (#11218 by @balkrushna)
- 禁用聚合函数的全局
ORDER BY—repo.max()、repo.min()等不再产生包含ORDER BY子句的无效 SQL (#11925 by @Cprakhar) - 分页子查询包含连接实体的主键 — 带
skip/take的leftJoin现在正确加载相关实体 (#11669 by @mag123c) - camelCase 别名缩短 —
shorten方法现在正确处理camelCase_aliases(#11283 by @OSA413)
关系与贪婪加载
- 非空外键的孤立一对多子记录现会被删除 — 当保存带有级联的一对多关系并替换子记录时,具有非空外键的孤立行现在会被删除,而不是因约束冲突而失败;可空外键的行仍会像以前一样被置为 null (#11982 by @naorpeled)
- 贪婪加载关系现遵循
relationLoadStrategy: "query"— 当设置为"query"策略时,贪婪加载的关系将通过独立查询加载,而不是始终使用 JOIN (#11326 by @SharkSharp, #12256 by @pkuczynski) - 自引用关系别名冲突 — 使用
relationLoadStrategy: "query"的自引用关系不再因别名冲突而产生错误的 SQL (#11066 by @campmarc) - 贪婪加载关系不再重复 JOIN — 在
relations中显式指定贪婪加载关系不再导致重复的 JOIN (#11991 by @veeceey) - 保存已贪婪加载的关系 — 修复了实体具有贪婪加载关系时的保存失败问题 (#11975 by @gioboa)
- 带有
select: false的列不再返回 — 标记为select: false的列现在会正确地从查询结果中排除 (#11944 by @gioboa) - 使用
joinMapOne方法的子查询 — 修复了使用 join map 方法时的不正确行为 (#11943 by @gioboa) - 嵌套嵌入实体中的关系 ID — 修复了在嵌入实体中映射关系 ID 时出现的
TypeError: Cannot set properties of undefined错误 (#11942 by @Cprakhar) RelationIdLoader别名处理 — 使用DriverUtils.getAlias防止标识符长度受限的数据库截断别名 (#11228 by @te1)createPropertyPath中的*-to-many— 移除了阻止某些关系配置的错误处理逻辑 (#11119 by @ThbltLmr)
持久化
- 使用
update: false或generatedType的 Upsert — upsert 现在能正确处理不应被更新的列 (#12030 by @gioboa) - 值转换器应用于
FindOperator—ApplyValueTransformers现在能正确转换In、Between等FindOperator实例内部的值 (#11172 by @ZimGil) - 软删除不再更新已软删除的行 —
softDelete和softRemove现在会跳过已经软删除的行 (#10705 by @hassanmehdi98) - 实体合并尊重
null值 — 合并到实体时不再静默丢弃null属性值 (#11154 by @knoid) - Map/对象比较 — 修复了 Map 和普通对象列值的错误变更检测 (#10990 by @mgohin)
- Date 转换器变更检测 — 修复了日期值转换器导致的误报脏数据检测问题 (#11963 by @gioboa)
- 子节点 mpath 更新 — 树形实体 mpath 在重新设置父节点时现在能正确更新,即使父节点已被软删除 (#10844 by @JoseCToscano)
- 闭包连接表 schema/database 传播 — schema 和 database 设置现在能正确传播到闭包连接表 (#12110 by @pkuczynski)
- Schema 构建器中的虚拟属性处理 — Schema 构建器不再尝试为虚拟属性创建列 (#11000 by @skyran1278)
- 删除无名的
TableForeignKey— 删除未显式指定名称的外键不再失败 (#10744 by @taichunmin) getPendingMigrations不再创建迁移表 — 检查待处理迁移不再产生副作用 (#11672 by @pkuczynski)
驱动特定修复
- PostgreSQL:
timestamptz持久化/填充 —timestamp with time zone列现在能正确持久化和填充 (#11774 by @Minishlink) - PostgreSQL: 几何类型重新保存 — point/circle 值现在在持久化时会被规范化,以避免重新保存填充对象时出现无效输入错误 (#11857 by @Cprakhar)
- PostgreSQL/CockroachDB: 带引号的表名 — 修复了名称中包含特殊字符的表的处理问题 (#10993 by @iskalyakin)
- PostgreSQL: 顺序查询执行 — 现在在同一连接上顺序执行查询,以避免
pg8.19.0 弃用警告 (#12105 by @pkuczynski) - MySQL: PolarDB-X 2.0 版本检测 —
getVersion()不再为 PolarDB-X 2.0 返回undefined(#11837 by @Missna) - MongoDB:
ObjectIdColumn属性名转换 —findOneBy({ id: value })现在能正确转换为 MongoDB 查询中的_id(#12200 by @pkuczynski) - MongoDB: 嵌套文档中的嵌入数组 — 正确处理嵌套文档结构中的嵌入数组 (#10940 by @mciuchitu)
- SQLite: simple-enum 数组 — 带
array: true的simple-enum列不再因 CHECK 约束错误而失败 (#11865 by @Cprakhar) - SAP HANA:
Date参数转义 — JSDate值现在作为查询参数传递,而不是嵌入 SQL 字符串中 (#11867 by @alumni) - CockroachDB: 事务重试中的结构化查询结果 —
useStructuredResult标志现在在 CockroachDB 事务重试回放期间得以保留 (#11861 by @naorpeled) - Cordova: 查询受影响行数 — 查询结果现在包含受影响行的计数 (#10873 by @jacobg)
其他
- CLI
init命令 — 当package.json不存在时不再崩溃 (#11947 by @gioboa);发布的包现在正确包含了脚手架所需的devDependencies(#12281 by @pkuczynski) - Deno
process导入 — 修复了 Deno 上process依赖的错误导入问题 (#11248 by @yohannpoli)
安全修复
- 防止 SQL 注入 — 所有驱动程序在架构内省和 DDL 方法中现已使用参数化查询与转义标识符,从而防止通过数据库/模式/表/列名进行 SQL 注入 (#12207 由 @pkuczynski 贡献,#12197 由 @pkuczynski 贡献,#12185 由 @pkuczynski 贡献)
- OrderBy 条件验证 — QueryBuilder 的
orderBy和addOrderBy现在会在运行时验证条件值,防止通过排序表达式进行注入 (#12217 由 @pkuczynski 贡献)
性能改进
- PostgreSQL / CockroachDB:
clearDatabase()中的批量 DROP — 将单独的 DROP 语句合并为单个批量查询,显著减少测试设置期间的往返次数 (#12164, #12159 由 @pkuczynski 贡献)