- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个包含用户数据的数据库(本地主机)。我使用 mySQL。
我想使用 Excelsheet 更新这些数据。我写了一些 VBA 代码。我调查了this solution: adodb trouble with parameters and vba但这对我不起作用。
我做了一个 VBA 宏并做了一些测试。该宏仅适用于“普通”SQL 字符串。
我在代码中加入了不同的测试和错误。我无法弄清楚我做错了什么。
我已经用谷歌搜索了不同的错误,但我找不到足够的信息
[MySQL][ODBC 8.0(w) 驱动程序][mysqld-5.5.5-10.4.14-MariaDB] 参数类型无效
我检查了数据库和列(varChar)的值类型设置,所以看起来(?)没问题。
有人可以帮我吗?
此致
M。
Sub Addres_to_Database_2_Update()
'Update an MySQL database (database: samueldb, table: users) on localhost
'with data form an excel sheet called "Testblad"
Dim Connect As ADODB.Connection
Dim sqlQuery As String
Dim user_id As String
Dim firstname As String
Dim lastname As String
Dim address As String
Dim contact As String
user_id = Sheets("Testblad").Range("B6").Value
firstname = Sheets("Testblad").Range("B7").Value
lastname = Sheets("Testblad").Range("B8").Value
address = Sheets("Testblad").Range("B9").Value
contact = CStr(Sheets("Testblad").Range("B10").Value)
MsgBox "Data: " & user_id & " " & firstname & " " & lastname & " " & address & " " & contact
Set Connect = New ADODB.Connection
Connect.Open "DRIVER= {MySQL ODBC 8.0 Unicode Driver}; SERVER=localhost;DATABASE=samueldb;USER=root; PASSWORD=;"
'password is empty
'This normal SQL string works fine
'sqlQuery = "UPDATE users " & _
' "SET FirstName = '" & firstname & "', " & _
' "LastName = '" & lastname & "', " & _
' "address = '" & address & "', " & _
' "contact = '" & contact & "' WHERE user_id= " & user_id & " "
Debug.Print sqlQuery
'Result: UPDATE users SET FirstName = 'Henkie', LastName = 'Strijbos', address = 'Amsterdam', contact = '35673567' WHERE user_id= 23
'Result = OK
'Database will be Updated when SQL is executed
'=== But: testing with parameters does not work
'see: https://stackoverflow.com/questions/43679797
sqlQuery = "UPDATE users " & _
"SET firstname = ?firstname, " & _
"lastname = ?lastname, " & _
"address = ?address, " & _
"contact = ?contact " & _
"WHERE user_id = user_id"
Debug.Print sqlQuery
'Result when debugged > UPDATE users SET firstname = ?firstname, lastname = ?lastname, address = ?address, contact = ?contact WHERE user_id = user_id
'Result = OK
With New ADODB.command
.ActiveConnection = Connect
.CommandType = adCmdText
.NamedParameters = True
.CommandText = sqlQuery
' ========== Test 1 > Run-time error '3708':
'
' .Parameters.Append .CreateParameter("?firstname", , adParamInput, , firstname)
'RESULT: Run-time error '3708':Parameter Object is improperly defined. Inconsistent or incomplete information was provided
' code stops her
' .Parameters.Append .CreateParameter("?lastnamer", , adParamInput, , lastname)
' .Parameters.Append .CreateParameter("?address", , adParamInput, , address)
' .Parameters.Append .CreateParameter("?contact", , adParamInput, , contact)
'========== Test 2 This does not work, same failure > Run-time error '3708':
'
' .Parameters.Append .CreateParameter("?firstname", , , , firstname)
'RESULT: Run-time error '3708':Parameter Object is improperly defined. Inconsistent or incomplete information was provided
' code stops her
' .Parameters.Append .CreateParameter("?lastnamer", , , , lastname)
' .Parameters.Append .CreateParameter("?address", , , , address)
' .Parameters.Append .CreateParameter("?contact", , , , contact)
'========== Test 3 This does not work, Run-Time error 13
'
' .Parameters.Append .CreateParameter("?firstname", firstname)
'Result: Run-Time error 13: Type Mismatch.
' code stops her
' .Parameters.Append .CreateParameter("?lastnamer", lastname)
' .Parameters.Append .CreateParameter("?address", address)
' .Parameters.Append .CreateParameter("?contact", contact)
'======= Test 4 This does not work
'
' .Parameters.Append .CreateParameter("?firstname", adChar, adParamInput, 30, firstname)
' .Parameters.Append .CreateParameter("?lastnamer", adChar, adParamInput, 30, lastname)
' .Parameters.Append .CreateParameter("?address", adChar, adParamInput, 150, address)
' .Parameters.Append .CreateParameter("?contact", adChar, adParamInput, 20, contact)
'Debug.Print sqlQuery
'Result when debugged > UPDATE users SET firstname = ?firstname, lastname = ?lastname, address = ?address, contact = ?contact WHERE user_id = user_id
'I do not understand, because the values should be appointed
'should it not be:
'UPDATE users SET FirstName = 'Henkie', LastName = 'Strijbos', address = 'Amsterdam', contact = '35673567' WHERE user_id= 23
'When executed >Run-time Error -2147217887 (80040e21)
' [MySQL][ODBC 8.0(w) Driver][mysqld-5.5.5-10.4.14-MariaDB] Invalid parameter Type
'=========== Test 5 This does not work
.Parameters.Append .CreateParameter("?", adChar, adParamInput, 30, firstname)
.Parameters.Append .CreateParameter("?", adChar, adParamInput, 30, lastname)
.Parameters.Append .CreateParameter("?", adChar, adParamInput, 150, address)
.Parameters.Append .CreateParameter("?", adChar, adParamInput, 20, contact)
Debug.Print sqlQuery
'Result when debugged > UPDATE users SET firstname = ?firstname, lastname = ?lastname, address = ?address, contact = ?contact WHERE user_id = user_id
'I do not understand, because the values should be appointed
'should it not be:
'UPDATE users SET FirstName = 'Henkie', LastName = 'Strijbos', address = 'Amsterdam', contact = '35673567' WHERE user_id= 23
'When executed >Run-time Error -2147217887 (80040e21)
' [MySQL][ODBC 8.0(w) Driver][mysqld-5.5.5-10.4.14-MariaDB] Invalid parameter Type
' ==
.Execute
End With
Connect.Close
End Sub
最佳答案
我从来没有设法使用命名参数,所以我只会展示如何使用未命名参数。
a) sql 命令文本得到一个简单的?
在要插入参数的地方。
sqlQuery = "UPDATE users " _
& " SET firstname = ?, lastname = ?, address = ?, contact = ? " _
& " WHERE user_id = ?"
b) 参数必须以正确的顺序附加。您可以设置参数名称,但它是可选的。重要的是顺序,您需要为每个
?
创建一个参数。在您的查询中。您可能还有
Where
的参数- 子句(在您当前的查询中,您将更新整个表,因为 where 子句
user_id = user_id
对所有记录都为真(除了那些 user_id 为空的记录)。
.Parameters.Append .CreateParameter(, adChar, adParamInput, 30, firstname)
.Parameters.Append .CreateParameter(, adChar, adParamInput, 30, lastname)
.Parameters.Append .CreateParameter(, adChar, adParamInput, 150, address)
.Parameters.Append .CreateParameter(, adChar, adParamInput, 20, contact)
.Parameters.Append .CreateParameter(, adChar, adParamInput, 20, user_id)
c) 不是 100% 确定 mySQL,但我认为您需要将参数类型设置为 adVarChar,将长度参数设置为实际字符串长度。
.Parameters.Append .CreateParameter(, adVarChar, adParamInput, len(firstName), firstname)
(...)
d) 与
Debug.Print
,您将始终看到您输入的命令文本。该命令与参数一起发送到数据库引擎,引擎会解决这个问题。 ADODB 不关心在数据库端使用的语法。这可以让您和 ADODB 从为 Date 参数添加所有正确引号或正确语法或使用哪个字符作为小数分隔符的噩梦中解脱出来。
关于mySQL、Excel、VBA 和 ADODB(命令)参数问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66532094/
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 关闭 9 年前。 Improve this
我有一系列 SQL 命令,我想在大约 40 个不同的表上运行。必须有一种方法可以在不编写 40 条不同命令的情况下执行此操作... 我在 SQL Server 中运行它。所有表都有不同的名称,我要操作
我习惯在 PHP 中使用命令“mysql_insert_id()”来返回插入到我的数据库中的最后一行的 id。 在 C# 中的 SQLite 中是否有等效的命令? 谢谢! -阿德娜 最佳答案 选择 l
试图找出一种方法来回填 ds 分区 Hive 表的分区。 我知道如何从 CLI 运行 Hive 命令,例如 $HIVE_HOME/bin/hive -e 'select a.col from tab1
我有 .bat 文件。看起来像下一个 ....many commands1 ftp -i -s:copy.txt ...many commands2 copy.txt 包含下一个命令 open ...
基本上我想输入 show 并检查是否有 show 命令或别名已定义并触发它,如果未定义则触发 git show 。 例如 rm 应该执行 rm 但 checkout 应该执行 git checkout
我公司的主数据库是 iSeries 机器,我已经非常习惯使用 DB2 命令和结构。我现在正在尝试做一个小项目,更新一个包含超过 300 万条记录的表。我想出一种比较和“清理”数据的更快方法是使用 My
我想在带有 Node 的终端中制作一个简单的按钮板,并“blessed”用于连接或运行不同的命令。 ----------------------------------------------- _
我们有一个 selenium IDE 脚本,正在转换为 python webdriver。以下命令未转换: [openWindow | http://mywebsite.com/index.php |
我正在学习这个关于从 GIT HUB 下载和安装 Web 文件的在线教程。我进入主题:启动我们的静态网站,系统提示我输入命令以下载和安装 Web 文件。但是,当我输入命令 yarn install 时
我在 shell 脚本中使用 elif 命令时遇到问题,就像在 fortran 中一样。 我有 100 家公司的员工名单。我想屏蔽那些员工少于 500 人的公司。我的脚本是 rm -f categor
我有一些 Linux 命令可以生成 token 。我在 Linux 机器上使用操作系统库形式的 Python 自动化了这些命令。它工作正常。 但是,当我在 Windows 中尝试相同的代码时,它没有返
本文分享自华为云社区《Git你有可能不知道交互式暂存》,作者:龙哥手记。 本节中的几个交互式 Git 命令可以帮助你将文件的特定部分组合成提交。 当你在修改了大量文件后,希望这些改动能拆分为若干提交而
我想知道如何使用 IN 比较语法来做到这一点。 当前的 SQL 查询是: select * from employee where (employeeName = 'AJAY' and month(e
我在这个位置安装了 Hadoop /usr/local/hadoop$ 现在我想列出 dfs 中的文件。我使用的命令是: hduser@ubuntu:/usr/local/hadoop$ bin/ha
是否有一个单一的 docker 命令可用于清除所有内容?如果正在运行,请停止所有容器、删除所有图像、删除所有卷...等。 最佳答案 我认为没有一个命令可以做到这一点。您首先需要停止所有容器使用 $ d
我基本上是在 clojure/nrepl 模式中寻找与 C-u C-x C-e 或 C-c C-p 等效的 Scheme。 我想要一个 C-x C-e 将输出打印到缓冲区,而不是仅仅在 repl 中。
我可以在 vim 中使用 pudb(一个 ncurses Python 调试器),因为,例如,:!python %在实际的终端窗口中运行。我更喜欢使用 gvim,但 gvim 运行 :!python
我正在尝试编写一个 FFMPEG 命令: 取为 输入 一个视频 input.mp4 和一个图像 pic.jpg 作为 输出 将 input.mp4 拆分为 20 秒的视频,按顺序重命名;对于每个分割视
我想转储视频每帧的比特率。我正在尝试使用 -vstats 获取此信息命令。当我运行此命令时 - ffmpeg -i input.mp4 -vstats 它显示至少应该定义一个文件。 如果有人能建议我任
我是一名优秀的程序员,十分优秀!