与MySql的ASP经典连接无法正常工作

时间:2017-01-09 13:00:56

标签: mysql asp-classic

我被迫使用经典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;"

仍然会出现同样的错误。

我已经搜索了互联网和这个网站,但每当我找到信息时,它都假定我使用自己的服务器,而我不是。位于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   Set-Cookie:ASPSESSIONIDCCQSTSCA = FLAJJCCDFENAOEMMCGFGNPCF;路径= /   X-Powered-By:ASP.NET日期:2017年1月11日星期三14:46:07 GMT连接:   close处理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
    %>

2 个答案:

答案 0 :(得分:1)

如果您的主机是x64框,请同时Provider=MSDASQL MySQL ODBC 5.2w Driver- (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string{ CGPoint buttonPosition = [textField convertPoint:CGPointZero toView:viewsTbl]; NSIndexPath *indexPath = [viewsTbl indexPathForRowAtPoint:buttonPosition]; NSString *text = [textField.text stringByReplacingCharactersInRange:range withString:string]; dataArr = [NSMutableDictionary dictionaryWithDictionary:countArr[indexPath.row]]; NSMutableDictionary *datadict = [NSMutableDictionary dictionary]; if (number == indexPath.row) { [datadict setValue:text forKey:@"TextFieldOne"]; [datadict setValue:dataArr[@"TextFieldTwo"] forKey:@"TextFieldTwo"]; } else if(number == indexPath.row +1000) { [datadict setValue:dataArr[@"TextFieldOne"] forKey:@"TextFieldOne"]; [datadict setValue:text forKey:@"TextFieldTwo"]; } [countArr replaceObjectAtIndex:indexPath.row withObject:datadict]; return YES; } - (void)textFieldDidBeginEditing:(UITextField *)textField { number = textField.tag; } {不确定是否提及#34; 8。&#34;&# 34; 5.1.8。&#34; - &#34; 5.1&#34;或&#34; 5.2w&#34;应该没问题。如果它没有帮助 - 检查123-reg是否为数据库提供DSN(您使用无DSN连接)或尝试连接数据库的IP。

要确保这是一个asp问题,请尝试从测试php脚本(示例x64 connection strings[1])进行连接。

答案 1 :(得分:-1)

我只在连接字符串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"

最好的问候