- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个在 ASP VBScript 上运行的站点,原始代码从不关闭数据库连接。它打开连接作为任何给定页面的“启动”的一部分,然后执行它所做的一切并停止——但从不显式关闭连接。现在,这会导致 Web 服务器级别崩溃的问题——可能是由于缺乏垃圾收集。
所以我想创建一个函数,作为整个站点中所有 MyConn.Execute( sqlQuery ) 命令的替代品。我找到了一些不错的候选人,但似乎没有一个很管用。最有前途的似乎是下面的代码,但是当我尝试实际使用返回的记录集时,我得到了一个错误。
Function GetRS(strSQL)
'this function returns a disconnected RS
'Set some constants
Const adOpenStatic = 3
Const adUseClient = 3
Const adLockBatchOptimistic = 4
'Declare our variables
Dim oConn
Dim strSQL
Dim oRS
'Open a connection
Set oConn = Server.CreateObject("ADODB.Connection")
oConn.ConnectionString = "Driver={MySQL ODBC 5.3 Unicode Driver};Server=localhost;User=foo;Password=bar;Database=baz"
oConn.Open
'Create the Recordset object
Set oRS = Server.CreateObject("ADODB.Recordset")
oRS.CursorLocation = adUseClient
'Populate the Recordset object with a SQL query
oRS.Open strSQL, oConn, adOpenStatic, adLockBatchOptimistic
'Disconnect the Recordset
Set oRS.ActiveConnection = Nothing
'Return the Recordset
Set GetRS = oRS
'Clean up...
oConn.Close
oRS.Close
Set oConn = Nothing
Set oRS = Nothing
End Function
'call the function
strSQL = "SELECT * FROM Authors"
set RS = GetRS(strSQL)
(来源:https://web.archive.org/web/20211020134116/https://www.4guysfromrolla.com/webtech/080101-1.shtml)
这是我的测试代码:
Set rs = GetRS( "SELECT `first_name` FROM `users` WHERE `id`=123" )
x = rs( "first_name" )
response.write x
我得到错误:
ADODB.Recordset error '800a0cc1'
Item cannot be found in the collection corresponding to the requested name or ordinal.
/test.asp, line 25
使用序数 -- rs(0) -- 返回相同的错误。
对我来说看起来像一个空记录集,但它是一个返回记录的合法查询。
有谁知道为什么这不起作用,或者可以向我指出可以完成这项工作的其他代码? (尤其是 4guys 文章缺少的实际使用示例。)
最佳答案
我的理解是 Recordset 与数据源相关联。当您执行查询时,默认情况下,客户端(您的程序)不会获取查询的全部内容,而是会等到您实际请求数据。这样,您可以选择特定的页面大小、页面偏移量等,以有效地从数据库中选择行,而无需通过网络传输可能数百万行。
这样做的副作用是,如果您关闭数据库连接,您将无法再使用 Recordset。在完成连接之前,您必须保持连接打开。同样,关闭 Recordset 本身将阻止您与它进一步交互。
您有两个选择:在关闭之前将数据从 Recordset 复制到您自己的变量/数组中,或者使用不同的技术来管理您的连接。我将在这里讨论后一种选择。
有一种技术可以让您打开数据库连接一次,并确保它在终止时由 VBScript 正确关闭。
Class DbConnectionManager
Private Sub Class_Initialize()
Set oConn = Server.CreateObject("ADODB.Connection")
oConn.ConnectionString = "Driver={MySQL ODBC 5.3 Unicode Driver};Server=localhost;User=foo;Password=bar;Database=baz"
oConn.Open
End Sub
Private Sub Class_Terminate()
oConn.Close
End Sub
End Class
Dim connMgr : Set connMgr = New DbConnectionManager
此代码片段未经测试,但一般原则是您通过定义一个类并创建它的一个实例来启动您的程序。当一个类实例被创建时,Class_Initialize
被调用,当您的程序结束时(或者实例被移除并被垃圾回收),Class_Terminate
将被调用。这意味着 oConn.Close
应始终在您的程序结束之前调用,即使出现错误也是如此。
这是类如何工作的一个非常基本的示例,但您实际上可以进一步扩展该类并将您的执行函数插入到类本身中以封装数据库连接详细信息以便于维护。如果您还没有在 VBScript 中使用过类,但您对面向对象编程的工作原理有基本的了解,我强烈建议您尝试一下。
额外奖励:看起来您正在传递原始 SQL 字符串。为避免 SQL 注入(inject)漏洞,请勿动态构建 SQL 查询。相反,请使用 ADO 和参数,这样任何用户创建的内容都可以安全地传递到查询中而没有安全风险。 How do I run a parameterized SQL query in classic ASP? And is it secure? W3School 也有一节介绍如何使用 ADO。
关于mysql - 经典 ASP VBScript 需要替换 MyConn.Execute( query ),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45105318/
有时我一直在努力理解为什么在尝试创建航路点任务时任务管理器会收到错误“无法执行执行”。我附上了我正在使用的工作流程,如果您能看一下,我将不胜感激。 1.Initialize FlightControl
我正在 Python 中使用 SQLAlchemy 核心,并且我已多次阅读文档,但仍然需要有关 engine.execute() 的说明。与 connection.execute() . 据我了解,e
在我的 Zend 框架项目中,我想检查是否设置了 cookie。如果是这种情况,我想使用 cookie 内容登录用户。 由于我必须在调用任何 Controller 之前执行此自动登录,因此我尝试将其放
我正在尝试为我创建的 2 个选择语句的 UNION 创建一个 View 。 UNION 在单独执行时工作正常 但问题是当我将它作为 View 执行时,只有 UNION 的第一部分被执行。 我正在使用的
下面我写了一个简单的例子来演示我遇到的问题。执行代码后,我得到一个 cygwin 异常 7200。我环顾四周并尝试了一些事情,但没有解决。有人可以解释为什么我得到它,我该如何解决?感谢您抽出宝贵时间,
从池中获取连接然后在连接上调用 execute 而不是直接在池对象上调用 execute 的用例是什么? 在 Pool 的文档中类,显示此示例: con = await pool.acquire()
我正在尝试通过 SQL 将变量中的 2 个值插入表中,代码完成时没有错误,但条目未显示在表中。 我尝试在即时窗口中执行代码,但这给了我一个关于括号的错误(我真的不知道如何在那里正确输入提示),所以我将
我对广播接收器有点困惑。我有一个广播接收器,它在 TIME_SET 和 TIMEZONE_CHANGED 操作时触发(代码在下面给出)。我想知道的是,当 TIME_SET 和 TIMEZONE_CHA
我必须与需要随每个请求发送访问 token 的外部服务集成。访问 token 的到期时间很短(只有几个小时)。我决定以乐观的方式使用访问 token 。我将使用当前 token 调用外部服务。如果出现
如果我在 swift 中运行以下代码,步骤 1.、2.、3. 和 4. 是否始终按此顺序执行(它们应该如此),或者如果循环存在异步执行的风险,排序等,花费的时间比预期的要长? // 1. fo
我在我的 C++ 应用程序中看到访问冲突错误。在发生违规并使用 !analyze 时将 windbg 附加到进程时,我发现访问违规是由于试图执行不可执行的地址。我知道导致此问题的正在执行的地址。什么可
在使用 Ubuntu 大约一年之后,这对我来说是第一次。 我接手了一个跟踪维修的汽车服务项目。我可以看到每个文件的完整源代码,但是有一个没有扩展名的文件,但在 Ubuntu 中,属性显示为可执行文件(
什么是 LinqPad“自动跟踪执行”和“跳转到执行点”?如何使用它们,如果你能给出一个详细的例子将不胜感激。 最佳答案 这不是一个详细的示例,但它说明了该功能。如果你有一个像 "1".Dump()
我使用 Q.js 来实现 promise 。在下面的代码中,每个方法都会进行 ajax 调用,然后返回一个 Promise。一切都按预期进行,每个方法在下一个方法开始之前执行并完成: function
我有一个类,它实现了 Runnable接口(interface),并且是一个一旦启动就会无限期运行的任务(长时间运行的线程)。 public class LongRunningTask impleme
PDOStatement::execute() [pdostatement.execute]: SQLSTATE[HY093]: 无效的参数数量:绑定(bind)变量的数量与标记数量不匹配 我收到此错
关闭。这个问题是not reproducible or was caused by typos .它目前不接受答案。 这个问题是由于错别字或无法再重现的问题引起的。虽然类似的问题可能是on-topi
想要为执行的每个 linux 命令添加 aspect:executionTime 有什么方法可以添加默认方面环境,以便必须为执行的 linux 命令获取 executionTime 最佳答案 根据 m
我正在尝试安装一个名为 MFOC 的工具.我按照其网站中提到的说明进行操作,如下所示: ebrahim@ubuntu:~$ cd Desktop/mfoc-master/ ebrahim@ubuntu
我刚开始使用 numba 来提高我的程序的性能。我已经减少了我将要呈现的情况 import numba as nb import numpy as np from time import time d
我是一名优秀的程序员,十分优秀!