sqlSave: сопоставление временных меток фрейма данных с временными метками SQL Server - PullRequest
13 голосов
/ 16 декабря 2011

Я пытаюсь загрузить фрейм данных в таблицу на сервере sql, используя sqlSave (). В этом фрейме данных есть метка времени, и я хотел бы сопоставить столбец метки времени с полем даты и времени в SQLServer.

У меня две проблемы.

1. Отображает временную метку фрейма данных с плавающей точкой. 2. Создает таблицу, но данные не загружаются, и я получаю сообщение об ошибке.

Вот пример фрейма данных, 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

Вот что происходит, когда я пытаюсь использовать 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

Кроме того, когда я смотрю на типы данных таблицы, я не получаю «datetime» для метки времени. Мне не имеет смысла, почему RODBC отображает временную метку POSIXct на что-либо кроме 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

Как мне обойти это?

1 Ответ

16 голосов
/ 16 декабря 2011

Два варианта:

1) Ленивый: допустите ошибку, таблица будет создана и вручную измените столбец (столбцы) на datetime в вашей базе данных.Это будет работать в следующий раз.

2) Правильно: используйте varTypes

Обратите внимание, что ваша проблема может быть устранена путем удаления ненужных вещей.Кроме того, я бы, вероятно, не использовал бы метку времени имени столбца на сервере 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)
...