- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
关于 PostgreSQL 导入(以及具体的 SQLite->PostgreSQL 情况)已经有一些问题和答案。这个问题是关于一个特定的极端情况。
背景
我有一个用 python( Pyramid )编写并使用 alembic 来轻松迁移模式的现有生产中网络应用程序。由于数据库在异常高的写入负载下吱吱作响(可能是由于我自己代码的复杂性),我决定迁移到 PostgreSQL。
数据迁移
有一些关于数据迁移的建议。最简单的涉及使用
sqlite3 my.db .dump > sqlitedumpfile.sql
然后导入
psql -d newpostgresdb < sqlitedumpfile.sql
这需要对 sqlitedumpfile 进行一些编辑。特别是,删除一些不兼容的操作,更改值(sqlite 将 bool 值表示为 0/1)等。最终以编程方式对我的数据进行操作太复杂了,手动处理的工作量太大(某些表有 20k 行左右) .
我最终选择的一个很好的数据迁移工具是 pgloader ,立即“起作用”。然而,对于这种类型的数据迁移来说,这是典型的,这暴露了我的数据库中的各种数据不一致,我必须在进行迁移之前从源头解决这些问题(特别是,删除非唯一列的外键,这在当时似乎是个好主意)方便连接和删除依赖于已删除的其他表中的行的孤立行的时间)。这些都解决了,我就可以了
pgloader my.db postgresql:///newpostgresdb
并适本地获取我的所有数据。
问题是什么?
pgloader 对数据工作得很好,但对表结构本身就不太好。这导致了三个问题:-
我不得不创建一个包含大量更改的新 alembic 修订版(大部分与数据类型相关,但也有一些与问题 2 相关)。
约束/索引名称不可靠(生成了唯一的数字名称)。实际上有 an option禁用它,这是一个问题,因为我需要一个可靠的升级路径,该路径可在生产中复制,而无需手动调整 alembic 代码。
大多数主键的序列/自动增量都失败了。这破坏了我的网络应用程序,因为我无法为某些(不是全部)数据库添加新行。
相比之下,使用 alembic 重新创建一个空白数据库来维护模式效果很好,而无需更改我的任何 webapps 代码。但是 pgloader 默认覆盖现有表,所以这会让我无处可去,因为数据才是真正需要迁移的。
如何使用我已经定义(并且有效)的模式进行正确的数据迁移?
最佳答案
总而言之,最终起作用的是:-
在 postgresql://newpostgresdb 中创建适当的数据库结构(我刚刚为此使用了 alembic upgrade head
)
使用 pgloader 将数据从 sqlite 移动到 postgresql 中的另一个数据库。正如问题中提到的,在这一步之前需要解决一些数据不一致的问题,但这与本问题本身无关。
createdb tempdb
pgloader my.db postgresql:///tempdb
将数据转储到tempdb
中使用 pg_dump
pg_dump -a -d tempdb > dumped_postgres_database
编辑生成的转储以完成以下操作:-
SET session_replication_role = replica
因为我的一些行是循环引用同一个表中的其他行
删除 alembic_version
表,因为我们正在为 alembic 重新启动一个新分支。
重新生成任何序列,相当于 SELECT pg_catalog.setval('"table_colname_seq"', (select max(colname) from table));
最后,psql
可用于将数据加载到您的实际数据库中
psql -d newpostgresdb < dumped_postgres_database
关于postgresql - SQLite 到 PostgreSQL 的仅数据传输(以保持 alembic 功能),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45122494/
我需要将数据从一个表传输到另一台已截断的服务器中的同一个表。最简单的方法是什么? 最佳答案 设置 linked servers然后在目标数据库上使用以下内容: INSERT INTO existing
我尝试从 mysql 服务器获取数据到 ms sql 服务器。我已经在本地主机(使用 ODBC 连接器)中完成了这个过程。 但是现在这些服务器作为在线数据库托管。谁能告诉我这样做的方法吗? 我想我不能
我有一个论坛在这里或http://neue.st/index.php 我想将数据从该论坛转移到不同目录中的新论坛http://neue.st/forums 我也只想选择要传输的数据,例如用户、帖子、主
我正在 Android 操作系统上开发 BLE 应用程序。我必须通过我的应用程序在 BLE 硬件上写入数据。我对必须发送的传输数据的类型感到困惑。下面的图像显示了我必须发送的字节数据。对于每个字节,它
我正在尝试将 RabbitMQ 用于分布式系统,其工作原理如下: 生产者将 JSON 格式的订单 ID 列表放入队列 多个消费者从该队列中取出,使用该订单 ID 执行业务逻辑,并将结果(JSON 格式
我正在将 ARM ComputeLibrary 集成到一个项目中。 这不是我所熟悉的语义的 API,但我正在研究文档和示例。 目前,我正在尝试将 std::vector 的内容复制到 CLTensor
我正在使用面向连接的 channel 开发 BLE 应用程序。我使用 nordic semiconductor nrf52 作为外围设备,iPhone 6 作为中央管理器。 我使用了蓝牙 SIG 提供
我有一个 redis 数据库、logstash 和两个 elasticsearch 和一个 influxdb。我正在将 key 从 redis 传输到 elasticsearch,它工作正常并且想测试
例如,我们在master1上运行一个主节点 在server2,server3上运行的两个数据节点 我们说分片重定位发生在server2到server3之间 现在要复制数据文件夹,elasticsear
基本上,我想做的是创建一个方法,可以采用任何数据类型,并将其转换为 php 识别的数据或 JSON。假设我想传递一个数组、一个二维数组或只是一些基本字符串。我会调用这个函数,传入参数并将其发送到 ph
我们在 UI 中使用 JSF,在业务层中使用 Spring,在持久层中使用 Hibernate。现在我的问题是如何将数据从 JSF UI 传递到 Spring 业务层。我可以直接在支持 bean 中使
我正在构建一个 android 应用程序(使用 java 1.6) - 这是实际的客户端 它向 Windows 计算机发送和接收数据,该计算机托管使用 networkStream 和 socket T
我将编写一个对用户输入使用react并将用户输入数据发送到服务器的应用程序。如果没有互联网连接,应用程序将批量数据并尽快发送。加密并不重要,因为只是发送了一堆关键信息,如果没有相应的真实数据,这些信息
我知道 Javascriptbridge 可以将数据从 js 发送到 tizen。 Is there any way to pass data from native to javascript 最佳
几年前,我编写了一个小实用程序,用于将数据从 Oracle 数据库移动到 Postgres 数据库。我使用 Java 和 JDBC 来完成此任务,因为我希望 Java 处理准备好的语句中使用的数据的数
我最近加入了 Facebook(我知道我迟到了),昨晚我带着一个奇迹醒来。看起来像实时聊天模块大约每秒“寻找”新的应答消息。在我看来,这有点太快了。我不知道他们是如何设法不得到他们的服务器处于事件状态
因此,我正在使用 jdbc 与 MySQL 数据库通信。对于许多表和许多查询/ View ,我创建了一个类,它封装了表的一行或查询/表结果。对 DB 的访问返回此类的一个对象(当我确切知道只有一个匹配
我尝试创建一个在我的虚拟机中运行的程序,以便我可以将数据从目录传输到我的 azure blob 存储帐户。每当我在程序外部(在命令行上)运行该命令时,它都会起作用,但是,如果我运行包含运行该命令的子进
我正在尝试建立一个小型系统,让一台服务器(也称为传感器)在发现另一台服务器(也称为服务器)可用时将数据文件传输到另一台服务器(也称为服务器)(都运行 node.js 应用程序)。 理想情况下,服务器应
我有一个带有两个按钮和两个文本字段的 DialogFragment。 我只希望当我在两个文本字段中输入数据并按下“确定”按钮时,它可以匹配两个字段的数据并将结果保存到 String。 Toast ms
我是一名优秀的程序员,十分优秀!