PostgreSQL 与 SQL Server 的数据类型映射

数据类型在做数据库迁移的时候要用到,不同数据库间的数据类型不尽相同,因此迁移的时候一定要注意数据类型转换,否则会造成数据数据精度丢失、数据截断、乱码等异常问题。

PostgreSQL 与 SQL Server 的数据类型映射

注意:PostgreSQL 中的 money(货币)数据类型现在已经废弃,用 numeric 或 decimal 以及和 to_char 函数一起使用就可以取代它。

  • SQL Server 中的 datetime、smalldatetime 数据类型均包含日期和时间部分,区别只在于精度不同。其对应于 PostgreSQL 中的 timestamp 类型(包含日期和时间)。在 PostgreSQL 中如果只需要日期部分,则可以使用 date 类型,而只需要时间部分则可使用 time 类型。
  • PostgreSQL 中的 bytea(n) 始终为变长的二进制字节数组,相当于 SQL Server 中的 varbinary(n),如果没有指定 bytea 的最大字节数则表示为不限长度的变长字节数组,相当于 SQL Server 中的 image 数据类型。
  • PostgreSQL 中的字符类型没有像 SQL Server 中有对应的本地文本类型和国际化文本类型的两种文本数据类型的区别,存储在 PostgreSQL 中的文本类型的数据是否国际化还是本地化取决于数据库的文本编码设置。
    为了保证数据存储的国际化,建议将数据库的文本编码方式设置为 UTF-8 或者 Unicode,以确保存储的文本可被不同地区和文化下的用户查看和存储。
  • 对于 GUID 类型的数据,在 PostgreSQL 中可以使用 bytea(16) 来保存,可用字节数组函数来对其进行比较等操作。

本文作者: GavinDong

版权属于: GavinDong博客

文章链接: https://www.gavindong.com/2611.html

如果使用过程中遇到问题,可 **点击此处** 交流沟通。

版权所有,转载时必须以链接形式注明作者和原始出处及本声明。

发表评论

登录后才能评论

评论列表(5条)

  • ag
    ag 2018.07.17 13:29

    对于数值型的,M就是字段的总长度,D就是精度了
    对于字符型的,长度就是字段的总长度,精度可以忽略

  • ag
    ag 2018.07.17 09:20
    • ag
      ag 2018.07.17 13:32

      @ag用了下这个工具:https://github.com/dalibo/sqlserver2pgsql
      挺方便的,基本原理是导出sqlserver的建表、视图SQL语句为文本文件,然后运行这个脚本解析刚才导出的文本文件,会产生三个文件(SQL语句),根据需要修改这三个文件后在目标数据库中执行SQL语句就好了。
      在sqlserver2pgsql.pl中搜索public,修改为目标scmeha名称,这样产生的sql语句中的schema名就都是目标schema名了。

    • ag
      ag 2018.07.17 13:39

      @ag自动产生的脚本里里,我注释掉了创建外键的几行、删除了几个not null!

  • ag
    ag 2018.07.17 09:14

    From MSSQL to PG:
    bit – becomes boolean
    datetime,smalldatetime – becomes timestamp with out timezone
    float,real – becomes double precision
    money,smallmoney – becomes numeric(19,4)
    nchar,ntext,nvarchar – become char,text and varchar; PostgreSQL must use UTF8 encoding, see above.
    tinyint – becomes smallint

email