很久以前,在一个遥远的系统上…
尝试将数据库从mysql迁移到postgresql。我读过的所有文档都非常详细地介绍了如何迁移结构。我几乎没有找到关于迁移数据的文档。该架构有13个表(已成功迁移)和9 GB的数据。
MySQL版本:5.1.x
PostgreSQL版本:8.4.x
我想用r编程语言用sql select语句来分析数据,postgresql有pl/r,mysql没有pl/r(据我所知)。
新的希望
创建数据库位置(/var空间不足;也不喜欢到处都有PostgreSQL版本号——升级会破坏脚本!):sudo mkdir -p /home/postgres/mainsudo cp -Rp /var/lib/postgresql/8.4/main /home/postgressudo chown -R postgres.postgres /home/postgressudo chmod -R 700 /home/postgressudo usermod -d /home/postgres/ postgres
一切都很好。接下来,重新启动服务器并使用以下命令配置数据库:sudo apt-get install postgresql pgadmin3sudo /etc/init.d/postgresql-8.4 stopsudo vi /etc/postgresql/8.4/main/postgresql.conf
将data_directory更改为/home/postgres/mainsudo /etc/init.d/postgresql-8.4 startsudo -u postgres psql postgres\password postgressudo -u postgres createdb climatepgadmin3
使用pgadmin3配置数据库并创建架构。
这一事件在一个名为bash的远程shell中继续,两个数据库都在运行,并且安装了一组带有相当不寻常徽标的工具:installation instructions。perl Makefile.PLsudo make installsudo apt-get install perl-doc(奇怪的是,它没有被称为perldoc)perldoc SQL::Translator::Manual
提取PostgreSQL友好的DDL和所有MySQL数据:sqlt -f DBI --dsn dbi:mysql:climate --db-user user --db-password password -t PostgreSQL > climate-pg-ddl.sql
编辑climate-pg-ddl.sql并将标识符转换为小写,然后插入模式引用(使用vim)::%s/"\([A-Z_]*\)"/\L\1/g:%s/ TABLE / TABLE climate./g:%s/ on / on climate./gmysqldump --skip-add-locks --complete-insert --no-create-db --no-create-info --quick --result-file="climate-my.sql" --databases climate --skip-comments -u root -p
只需将mysql中的表和列重命名为小写就可以了:select concat( 'RENAME TABLE climate.', TABLE_NAME, ' to climate.', lower(TABLE_NAME), ';' ) from INFORMATION_SCHEMA.TABLES where TABLE_SCHEMA='climate';
执行上一步中的命令。
可能有一种方法可以对列执行同样的操作;我手动更改它们,因为这比找出如何编写查询要快。
数据库反击
在PostgreSQL中重新创建结构如下:pgadmin3(切换到它)
单击“执行任意SQL查询”图标
打开climate-pg-ddl.sql
搜索“替换为”(插入架构名称)
搜索“替换为”(插入架构名称)
按TABLE "执行
这将导致:
Query returned successfully with no result in 122 ms.
TABLE climate."转换为climate以便对PostgreSQL执行它们?最佳答案
我通常为这种迁移做两方面的工作:
从MySQL中提取整个数据库定义,并使其适应PostgreSQL语法。
检查数据库定义并转换它,以利用PostgreSQL中MySQL中不存在的功能。
然后进行转换,用您最熟悉的语言编写一个程序,完成以下任务:
从MySQL数据库中读取数据。
对要存储在PostgreSQL数据库中的数据执行任何必要的转换。
将现在转换的数据保存在PostgreSQL数据库中。
为PostgreSQL重新设计表以利用其特性。
如果您只需要使用sed脚本将SQL转储从一种格式转换为下一种格式,那么您所要做的就是将MySQL数据库放入PostgreSQL服务器。您可以这样做,这样做仍然会有一些好处,但是如果您要迁移,请完全迁移。
这将需要更多的前期时间,但我还没有遇到一个不值得的情况。
关于mysql - 在Linux(Kubuntu)上从MySQL迁移到PostgreSQL,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2831009/
文章目录一、概述简介原理模块二、配置Mysql使用版本环境要求1.操作系统2.mysql要求三、配置canal-server离线下载在线下载上传解压修改配置单机配置集群配置分库分表配置1.修改全局配置2.实例配置垂直分库水平分库3.修改group-instance.xml4.启动监听四、配置canal-adapter1修改启动配置2配置映射文件3启动ES数据同步查询所有订阅同步数据同步开关启动4.验证五、配置canal-admin一、概述简介canal是Alibaba旗下的一款开源项目,Java开发。基于数据库增量日志解析,提供增量数据订阅&消费。Git地址:https://github.co
我已经找到了几个使用datamapper的示例,并且能够让它们正常工作。不过,所有这些示例都是针对sqlite数据库的。我正在尝试将数据映射器与postgresql一起使用。我将datamapper中的调用从sqlite3更改为postgres,并且我已经安装了dm-postgres-adapter。但它仍然不起作用。我还需要做什么? 最佳答案 与SQLite不同,PostgreSQL不将数据库存储在单个文件中。在你拥有createdyourdatabase之后,尝试这样的事情:DataMapper.setup:default,{:
我看到其他人也遇到过类似的问题,但没有一个解决方案对我有用。0.3.14gem与其他gem文件一起存在。我已经完全按照此处指示完成了所有操作:https://github.com/brianmario/mysql2.我仍然得到以下信息。我不知道为什么安装程序指示它找不到include目录,因为我已经检查过它存在。thread.h文件存在,但不在ruby目录中。相反,它在这里:C:\RailsInstaller\DevKit\lib\perl5\5.8\msys\CORE\我正在运行Windows7并尝试在Aptana3中构建我的Rails项目。我的Ruby是1.9.3。$gemin
我已经开始使用mysql2gem。我试图弄清楚一些基本的事情——其中之一是如何明确地执行事务(对于批处理操作,比如多个INSERT/UPDATE查询)。在旧的ruby-mysql中,这是我的方法:client=Mysql.real_connect(...)inserts=["INSERTINTO...","UPDATE..WHEREid=..",#etc]client.autocommit(false)inserts.eachdo|ins|beginclient.query(ins)rescue#handleerrorsorabortentirelyendendclient.commi
我找到了这样的东西:Rails:Howtolistdatabasetables/objectsusingtheRailsconsole?这一行没问题:ActiveRecord::Base.connection.tables并返回所有表但是ActiveRecord::Base.connection.table_structure("users")产生错误:ActiveRecord::Base.connection.table_structure("projects")我认为table_structure不是Postgres方法。如何列出Postgres数据库的Rails控制台中表中的所有
我想使用PostgreSQL中的point类型。我已经完成了:railsgmodelTestpoint:point最终的迁移是:classCreateTests当我运行时:rakedb:migrate结果是:==CreateTests:migrating====================================================--create_table(:tests)rakeaborted!Anerrorhasoccurred,thisandalllatermigrationscanceled:undefinedmethod`point'for#/hom
我正在使用带有单个“帐户”表的STI模型来保存用户和技术人员的信息(即用户...8)错误:test_the_truth(用户测试):ActiveRecord::StatementInvalid:PGError:ERROR:关系“技术人员”不存在:从“技术人员”中删除...从本质上讲,标准框架不承认Technicians和Users表(或PostgreSQL称它们为“关系”)不存在,事实上,应该别名为Accounts。有什么想法吗?我对RoR比较陌生,不知道如何解决这个问题而又不完全删除STI。 最佳答案 原来问题是由于存在:./te
我正在使用PostgreSQL9.1.3(x86_64-pc-linux-gnu上的PostgreSQL9.1.3,由gcc-4.6.real(Ubuntu/Linaro4.6.1-9ubuntu3)4.6.1,64位编译)和在ubuntu11.10上运行3.2.2或3.2.1。现在,我可以使用以下命令连接PostgreSQLsupostgres输入密码我可以看到postgres=#我将以下详细信息放在我的config/database.yml中并执行“railsdb”,它工作正常。开发:adapter:postgresqlencoding:utf8reconnect:falsedat
Linux操作系统——网络配置与SSH远程安装完VMware与系统后,需要进行网络配置。第一个目标为进行SSH连接,可以从本机到VMware进行文件传送,首先需要进行网络配置。1.下载远程软件首先需要先下载安装一款远程软件:FinalShell或者xhell7FinalShellxhell7FinalShell下载:Windows下载http://www.hostbuf.com/downloads/finalshell_install.exemacOS下载http://www.hostbuf.com/downloads/finalshell_install.pkg2.配置CentOS网络安装好
文章目录一基础定义二创建逻辑卷2-1准备物理设备2-2创建物理卷2-3创建卷组2-4创建逻辑卷2-5创建文件系统并挂载文件三扩展卷组和缩减卷组3-1准备物理设备3-2创建物理卷3-3扩展卷组3-4查看卷组的详细信息以验证3-5缩减卷组四扩展逻辑卷4-1检查卷组是否有可用的空间4-2扩展逻辑卷4-3扩展文件系统五删除逻辑卷5-1备份数据5-2卸载文件系统5-3删除逻辑卷5-4删除卷组5-5删除物理卷六LVM逻辑卷缩容6-1缩容注意事项6-2标准缩容步骤一基础定义LVM,LogicalVolumeManger,逻辑卷管理,Linux磁盘分区管理的一种机制,建立在硬盘和分区上的一个逻辑层,提高磁盘分