【问题标题】:ASP classic connection to MySql not working与 MySql 的 ASP 经典连接不起作用
【发布时间】:2017-05-23 18:04:10
【问题描述】:

我不得不迁移一个使用经典 ASP (VBScript) 和 MS 访问数据库在远程 Windows 服务器上运行多年的旧网站。

新的托管公司 (123-reg) 在他们的 Windows 服务器上不支持 MS Access,所以我现在使用 MySQL。我在其他网站上成功使用过 MySQL,但一直使用 PHP 而不是经典的 ASP,所以我以前从未从 ASP 连接到 MySQL 数据库。

该网站有数百个页面,我希望我所要做的就是更改连接字符串。但是我现在收到 500 错误

80004005|[Microsoft] ODBC_Driver_Manager]_Data_source_name_not_found_and_no_default_driver_specified

这让我很难过。

我试过了

set Conn=server.createobject("ADODB.CONNECTION")
set rs = server.createobject("ADODB.Recordset")
conn.open "DRIVER={MySQL ODBC 3.51 Driver}; SERVER=" & servername & "; DATABASE=" & database & "; UID=" & username & ";PASSWORD=" & pword & "; OPTION=3;"

我也试过了:

conn.open "DRIVER={SQL Server};SERVER=" & servername & "\SQLEXPRESS;DATABASE=" & database & ";UID=" & username & ";PWD=" & pword"

在阅读this previous answer 到类似的问题之后:

conn.open "DRIVER={MySQL ODBC 5.1 Driver}; SERVER=" & servername & "; DATABASE=" & database & "; UID=" & username & ";PASSWORD=" & pword & "; OPTION=3;charset=utf8;"

仍然出现同样的错误。

我搜索过 Internet 和这个站点,但每当我找到信息时,它都假定我使用的是我自己的服务器,而我不是。位于:https://support.microsoft.com/en-gb/kb/306345 的页面建议我对服务器注册表进行更改,这当然是我无法做到的,而且无论如何我发现很难接受像 123-reg 这样大的公司必须在他们的服务器允许我连接到数据库。

因此,我得出结论,我的连接编码有问题(可能很简单)。

我确实提出了 123-reg 的罚单,但他们告诉我这是一个编码问题,他们对此没有帮助,这加强了我的理论。

对于这方面的任何帮助,我将不胜感激。我现在确实计划用 PHP 重新编写该站点,并且我知道我可以使它正常工作,但是由于要编写代码的页面有数百个,因此我需要花费几个月的时间,我正在寻找一个快速修复程序以使该站点生效再次使用当前页面,同时我用 PHP 重写整个网站。

非常感谢

更新:1 月 11 日 123-reg 回复我说 ODBC 版本是 5.1.8。我已经更改了连接字符串,但仍然收到 500 错误,即:

HTTP/1.1 500 内部服务器错误缓存控制:私有 内容长度:250 内容类型:text/html 服务器:Microsoft-IIS/7.5 设置 Cookie:ASPSESSIONIDCCQSTSCA=FLAJJCCDFENAOEMMCGFGNPCF;路径=/ X-Powered-By:ASP.NET 日期:2017 年 1 月 11 日星期三 14:46:07 GMT 连接: 关闭处理URL时服务器发生错误

没有行号,也没有错误描述。

我写了一个简单的页面来测试连接,我的完整代码是:

  <%@ Language=VBScript %>
    <%
    option explicit
    Response.Buffer = true
    '=============================
    'database connection variables
    dim servername, username, pword, database
    servername = "cust-mysql-123-19" 'The name of the Server
    username = "atourist" 'The username for the database
    pword = "redacted for this post" 'The password for the database
    database = "atourist" 'The database to use
    '============================
    dim rs
    dim strSQL
    dim conn
    dim ds
    dim county
    dim numrec
    county="Grampian"
    %>
    <html>
    <head>
    <title>Test Page</title>]
    </head>
    <body>
        <%
    ' connect to database and retrieve recordset
    set conn=server.createobject("ADODB.CONNECTION")
    set rs = server.createobject("ADODB.Recordset")
    strSQL = "select * from ukgh where county='" & county &  "' ORDER by random ASC"
    conn.open "DRIVER={MySQL ODBC 5.1.8. Driver}; SERVER=" & servername & "; DATABASE=" & database & "; UID=" & username & ";PASSWORD=" & pword & "; OPTION=3;"
    set rs = conn.Execute(strSQL)
    '===============================
    ds=rs.GetRows()
    rs.close
    conn.close
    set rs = nothing
    set conn = nothing

    'display records
    for Numrec =LBound(ds, 2) To UBound(ds, 2)

    response.write DS(1, numrec) & ", " & DS(2, numrec) & "<br />"

    Next
    %>
    </body>
    </html>
    <%
    response.end
    %>

【问题讨论】:

  • 几点。首先,如果您的数据库是 MySQL,那么(显然)您需要一个 MySQL ODBC 连接字符串 - 忘记 SQL Server 一个。如今,5.1 版比 3.51 版更可能被安装,但如果安装了任何一个,请向技术支持寻求帮助可能是值得的。此页面是一个有用的资源。 connectionstrings.com/mysql 。其次,Jet (Access) OLEDB 驱动程序仍默认安装在 Windows 服务器上,因此即使他们说它不受支持,也可能值得上传您现有的 Access 数据库并查看它是否有效。
  • 相当。如果您在 Windows 上安装 MySQL,则会附带一个 ODBC 驱动程序。版本 5.3 似乎是当前版本,值得一提的是,在我的笔记本电脑上工作的 conn 字符串 Provider=MSDASQL;Driver={MySQL ODBC 5.3 UNICODE Driver};Server=localhost;Database=mydatabase;User=myuserid; Password=mypassword;Option=3;
  • @约翰。我真的很感谢你的帮助。 123-reg 已回复 ODBC 版本。我在原始帖子的底部添加了信息和完整的代码:-)
  • 如果去掉除了 SQL 语句的连接和执行之外的所有内容会发生什么?您确定连接字符串的 ODBC 驱动程序部分有一个尾随句点吗?我见过的所有其他示例都是 5.1 或 3.51,没有尾随句点。
  • 尤里卡!将驱动程序语法更改为没有尾随句点的 5.1 有效。沮丧的日子结束了。现在我可以开始用 PHP 重写整个网站了。非常感谢大家的时间和帮助:-)

标签: mysql asp-classic


【解决方案1】:

如果您的主机是 x64 机器,请同时尝试 x64 connection stringsProvider=MSDASQLMySQL ODBC 5.2w Driver(不确定您是否应该在 "5.1.8." - "5.1" 或 "5.2w 中提及 "8." “ 应该没事)。如果没有帮助 - 检查 123-reg 是否为数据库提供 DSN(您使用 DSN-less 连接)或尝试连接数据库的 IP。

为确保这是一个 asp 问题,请尝试从测试 php 脚本连接(例如 [1][2])。

【讨论】:

  • 是的,我在设置 MySQL 数据库时确实测试了 PHP 连接,它工作正常。问题似乎与 MySQL ODBC 版本有关。 :-)
【解决方案2】:

我在连接字符串 5.3 中只添加了 Unicode Driver 并解决了问题

改变这个:

Conn.Open "DRIVER={MySQL ODBC 5.3 };SERVER=localhost; DATABASE=psa; UID=admin;PASSWORD=mypassword;Port=8306; OPTION=3"

收件人:

Conn.Open "DRIVER={MySQL ODBC 5.3 **Unicode Driver**};SERVER=localhost; DATABASE=psa; UID=admin;PASSWORD=mypassword;Port=8306; OPTION=3"

最好的问候

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2016-03-20
    • 2017-06-21
    • 1970-01-01
    • 2015-05-19
    • 1970-01-01
    相关资源
    最近更新 更多