Re: MSSQL to PostgreSQL Migration

Поиск
Список
Период
Сортировка
От Holger Jakobs
Тема Re: MSSQL to PostgreSQL Migration
Дата
Msg-id bb68633a-28d7-2a46-f815-c64dbb2660d2@jakobs.com
обсуждение исходный текст
Ответ на Re: MSSQL to PostgreSQL Migration  (Gurudutt Dhareshwar <gurudutt.dhareshwar@gmail.com>)
Ответы Re: MSSQL to PostgreSQL Migration  (JP Pozzi <jpp@jppozzi.dyndns.org>)
Список pgsql-admin
Am 12.01.23 um 04:21 schrieb Gurudutt Dhareshwar:
> For data you can move it using the SQL tool itself or take a BCP Out 
> and then insert using the psql -d option .


Actually, bcp.exe does not do a very good job. It cannot make a 
difference between an empty string and a NULL value, for instance.

If you try to export in tab-separated format 
(https://www.iana.org/assignments/media-types/text/tab-separated-values), 
carriage returns, newlines, tab character will all mess up the output. 
And contained backslashes are not doubled as necessary for PG's copy 
statement.

In case your tables aren't too large, you can export via PowerShell 
keeping the differences between NULL and empty string. The way via JSON 
may be a bit slow and heavy on memory, though.


### Code for Powershell

install-module sqlserver

$SqlParams = @{
   ServerInstance = 'server_name'
   UserName = 'user_name'
   Password = 'very_secret'
   Database = 'db_name'
}

$tableName = 'whatever_tablename'
(invoke-sqlcmd @SqlParams -query "Select * from $tableName" | 
select-object * -excludeproperty 
itemarray,table,rowerror,rowstate,haserrors | 
convertto-json).replace('null', '"§n§"') | convertfrom-json | export-csv 
-path "$($tableName).csv" -usequotes asneeded


### import using psql
\copy whatever_tablename from whatever_tablename.csv (format csv, header 
on);

Kind Regards,

Holger


-- 
Holger Jakobs, Bergisch Gladbach, Tel. +49-178-9759012


Вложения

В списке pgsql-admin по дате отправления:

Предыдущее
От: Alex Aquino
Дата:
Сообщение: Re: MSSQL to PostgreSQL Migration
Следующее
От: JP Pozzi
Дата:
Сообщение: Re: MSSQL to PostgreSQL Migration