LoginSignup
1
1

More than 3 years have passed since last update.

俺でもわかるAWS DMS CASTメモ(随時更新するとおもう)

Last updated at Posted at 2020-07-15

俺です。

DMSを使う際は同機種または異機種間であってもソース/ターゲットでテーブルの型は一致させておく必要があります。
型が異なる場合は内部で多分CASTが行われていると思われる上に、Full LoadとCDCで挙動が異なります。

ただ型が違っても俺にはレプリしたい理由がそこにある。そういう俺のために無理やりねじ込んだらどうなるのか、DMSがサポートしてないことをAWSサポートに泣きつくことはできないのでメモを残しておきます。

こんな情報誰がほしいのかって?俺だよ!

移行方式

Aurora PostgreSQL 10.X to Aurora MySQL 5.7

レプリケーションタイプ ソーステーブルの型 ターゲットの型 変換結果 dead or alive 対処方法
Full Load boolean boolean(tinyint) false('f')もtrue('t')も0が挿入される ('A`) ドキュメント通りvarchar(1)に移行する
CDC boolean boolean(tinyint) false => 102, true => 116 ('A`)
Full Load int datetime 0になる ('A`)
Full Load int varchar ロード可 J( 'ー`)し
CDC int varchar 10進数の文字コードに変換される ('A`)

参考

DMS内部データ型
PostgreSQLの制限
PostgreSQLのソースデータ型

1
1
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
1
1