来自 RODBC 的 sqlSave 仅在 R 中保存日期的年份

Posted

技术标签:

【中文标题】来自 RODBC 的 sqlSave 仅在 R 中保存日期的年份【英文标题】:sqlSave from RODBC only saves the year of a Date in R 【发布时间】:2016-05-11 13:09:36 【问题描述】:

我将 R 连接到我的 mysql 数据库。当我使用命令sqlSave(channel, dataframe) 时,我的数据框将被写入数据库,但所有在 R 中编码为日期的条目(类“POSIXct”“POSIXt”,例如“2016-01-01 CET”)只有 将记录在mysql数据库中。这怎么可能? 谢谢你的帮助。

编辑:列类型是“双”。所以我猜 sqlSave 不能保存为日期/时间?

【问题讨论】:

您是否尝试在数据库中将列类型设置为字符串并将日期转换为字符然后保存? 【参考方案1】:

我使用了确切的功能,但来自library(RMySQL),如下所示,它对我有用。首先确保您的数据格式正确:

toSql$Date<-as.POSIXct(strptime(toSql$Date,"%Y-%m-%d %H:%M",tz="GMT"))

然后还要确保在创建表时使用TIMESTAMP 作为列类型:

create table table_name(
ID INTEGER,
DATE TIMESTAMP,
PRIMARY KEY(ID)
)
;

保存到数据库后如下所示:

dbWriteTable(con, name = "table_name", toSql, overwrite=FALSE,   
              append=TRUE,row.names = NA)

也许还要确保您的dataframe 的名称相同:

names(toSql)
[1] "ID"  "DATE"

【讨论】:

【参考方案2】:

尝试将列转换为字符

dataframe$your_date_column <- as.character(dataframe$your_date_column)

【讨论】:

以上是关于来自 RODBC 的 sqlSave 仅在 R 中保存日期的年份的主要内容,如果未能解决你的问题,请参考以下文章

RODBC sqlSave() 和映射列名

RODBC :: sqlSave()创建表,警告:在列中截断为255个字节?

RODBC sqlSave 列类型:如何确定?

RODBC::sqlSave() 创建表,警告:在列中截断为 255 个字节?

RODBC 错误:SqlSave 无法附加到表

无法在 R 中使用 sqlSave 追加到 SQL Server 表