I am trying to upload a data frame to a table in sql server using sqlSave(). This dataframe has a timestamp in it and I'd like to map the timestamp col to a datetime col in sqlserver.
我正在尝试使用sqlSave()将数据帧上载到sql服务器中的表中。这个dataframe包含一个时间戳,我希望将时间戳col映射到sqlserver中的datetime col。
I am getting two problems.
我有两个问题。
1. It maps the data frame's timestamp to a float. 2. It creates a table, but no data is uploaded and I get an error.
1。它将数据帧的时间戳映射到一个浮点数。2。它创建了一个表,但是没有上传任何数据,我得到了一个错误。
Here's an example data frame, mdf:
这里有一个示例数据框架,mdf:
mdf <- structure(list(run = structure(c(1L, 1L, 1L, 1L, 1L, 1L), .Label = c("run_00",
"run_01", "run_02", "run_03", "run_04"), class = "factor"), slot = structure(c(1L,
1L, 1L, 1L, 1L, 1L), .Label = c("slot 3", "slot 4", "slot 5",
"slot 6"), class = "factor"), timestamp = structure(c(1320774563,
1320774624, 1320774686, 1320774747, 1320774809, 1320774871), class = c("POSIXct",
"POSIXt"), tzone = ""), channel = structure(c(1L, 1L, 1L, 1L,
1L, 1L), .Label = c("och01", "och02", "och09", "och10"), class = "factor"),
variable = structure(c(2L, 2L, 2L, 2L, 2L, 2L), .Label = c("num_blocks",
"num_collection", "num_corr_0", "num_corr_1", "num_uncorr_srow",
"post_fec_err_rate", "pre_fec_err_rate"), class = "factor"),
value = c(1, 62, 124, 185, 247, 309)), .Names = c("run",
"slot", "timestamp", "channel", "variable", "value"), row.names = c(NA,
6L), class = "data.frame")
> mdf
run slot timestamp channel variable value
1 run_00 slot 3 2011-11-08 12:49:23 och01 num_collection 1
2 run_00 slot 3 2011-11-08 12:50:24 och01 num_collection 62
3 run_00 slot 3 2011-11-08 12:51:26 och01 num_collection 124
4 run_00 slot 3 2011-11-08 12:52:27 och01 num_collection 185
5 run_00 slot 3 2011-11-08 12:53:29 och01 num_collection 247
6 run_00 slot 3 2011-11-08 12:54:31 och01 num_collection 309
Here's what happens when I try sqlSave to a sql server database...
当我尝试sqlSave到sql服务器数据库时,会发生以下情况……
> sqlSave(dbandle,mdf,tablename="mdf")
Error in sqlSave(dbandle, mdf, tablename = "mdf") :
[RODBC] Failed exec in Update
22018 0 [Microsoft][ODBC SQL Server Driver]Invalid character value for cast specification
Also, when I look at the data types of the table, I don't get "datetime" for the timestamp. It doesn't make sense to me why RODBC would map a POSIXct timetamp to anything other than datetime.
另外,当我查看表的数据类型时,我没有得到时间戳的“datetime”。我不理解为什么RODBC会将一个POSIXct timetamp映射到datetime之外的任何东西。
[rownames] [varchar](255) NULL,
[run] [varchar](255) NULL,
[slot] [varchar](255) NULL,
[timestamp] [float] NULL,
[channel] [varchar](255) NULL,
[variable] [varchar](255) NULL,
[value] [float] NULL
How do I get around this?
我该怎么解决这个问题呢?
1 个解决方案
#1
16
Two options:
两个选择:
1) Lazy one: let the error occur, the table will be created, and change the column(s) to datetime manually in your database. It will work the next time.
1) Lazy one:让错误发生,将创建表,并在数据库中手动将列更改为datetime。下次还行。
2) Correct: use varTypes
2)正确的:使用varTypes
Note that your problem can be stripped down by removing unnecessary stuff. As an aside, I probably would not use the column name timestamp in an sql server, because I have seen confusions because of the internal timestamp data type is totally different.
注意,您的问题可以通过删除不必要的内容来消除。顺便提一下,我可能不会在sql服务器中使用列名时间戳,因为由于内部时间戳数据类型完全不同,我曾遇到过混淆。
library(RODBC)
mdf = data.frame(timestamp=as.POSIXct(Sys.time()))
varTypes = c(timestamp="datetime")
channel = odbcConnect("test")
sqlSave(channel,mdf,rownames=FALSE,append=TRUE,varTypes=varTypes)
close(channel)
#1
16
Two options:
两个选择:
1) Lazy one: let the error occur, the table will be created, and change the column(s) to datetime manually in your database. It will work the next time.
1) Lazy one:让错误发生,将创建表,并在数据库中手动将列更改为datetime。下次还行。
2) Correct: use varTypes
2)正确的:使用varTypes
Note that your problem can be stripped down by removing unnecessary stuff. As an aside, I probably would not use the column name timestamp in an sql server, because I have seen confusions because of the internal timestamp data type is totally different.
注意,您的问题可以通过删除不必要的内容来消除。顺便提一下,我可能不会在sql服务器中使用列名时间戳,因为由于内部时间戳数据类型完全不同,我曾遇到过混淆。
library(RODBC)
mdf = data.frame(timestamp=as.POSIXct(Sys.time()))
varTypes = c(timestamp="datetime")
channel = odbcConnect("test")
sqlSave(channel,mdf,rownames=FALSE,append=TRUE,varTypes=varTypes)
close(channel)