почему ADODB вставляет значения NULL при обновлении? - PullRequest
0 голосов

у меня есть:

With rs
    .AddNew ' create a new record
    ' add values to each field in the record
    .Fields("datapath") = dpath
    .Fields("analysistime") = "atime"
    .Fields("reporttime") = "rtime"
    .Fields("lastcalib") = "lcalib"
    .Fields("analystname") = "aname"
    .Fields("reportname") = "rname"
    .Fields("batchstate") = "bstate"
    .Fields("instrument") = "NA"
    .Update ' stores the new record
End With

когда я проверяю базу данных, похоже, ТОЛЬКО вставлено последнее поле!

кто-нибудь сталкивался с этой проблемой?

1 Ответ

3 голосов
/ 13 мая 2010

РЕДАКТИРОВАТЬ: приведенный ниже код работает, но более подходящее решение можно найти здесь: Подключение Excel к Mysql Update ПРОБЛЕМА

Это связано с трудностями использования текстовых типов данных.


Кажется, это работает, но не спрашивайте меня, почему:

dpath = "a" ''Trim(Range("B2").Text)
atime = "a" ''Trim(Range("B3").Text)
rtime = "a" ''Trim(Range("B4").Text)
lcalib = "a" ''Trim(Range("B5").Text)
aname = "a" ''Trim(Range("B6").Text)
rname = "a" ''Trim(Range("B7").Text)
bstate = "a" ''Trim(Range("B8").Text)

cn.Open strCon
cmd.ActiveConnection = cn
cmd.CommandText = _
    "INSERT INTO `batchinfo` (`datapath`, `analysistime`," _
       & "`reporttime`,`lastcalib`,`analystname`,`reportname`," _
       & "`batchstate`,`instrument`) " _
       & "VALUES (?,?,?,?,?,?,?,?);"

cmd.Parameters.Append _
    cmd.CreateParameter("datapath", adChar, adParamInput, 100)
cmd.Parameters.Append _
     cmd.CreateParameter("analysistime", adChar, adParamInput, 100)
cmd.Parameters.Append _
     cmd.CreateParameter("reporttime", adChar, adParamInput, 100)
cmd.Parameters.Append _
     cmd.CreateParameter("lastcalib", adChar, adParamInput, 100)
cmd.Parameters.Append _
     cmd.CreateParameter("analystname", adChar, adParamInput, 100)
cmd.Parameters.Append _
     cmd.CreateParameter("reportname", adChar, adParamInput, 100)
cmd.Parameters.Append _
     cmd.CreateParameter("batchstate", adChar, adParamInput, 100)
cmd.Parameters.Append _
     cmd.CreateParameter("instrument", adChar, adParamInput, 100)

cmd.Parameters("datapath").Value = "abc"
cmd.Parameters("analysistime").Value = atime
cmd.Parameters("reporttime").Value = rtime
cmd.Parameters("lastcalib").Value = lcalib
cmd.Parameters("analystname").Value = aname
cmd.Parameters("reportname").Value = rname
cmd.Parameters("batchstate").Value = "bstate"
cmd.Parameters("instrument").Value = "NA"

cmd.Execute
...