asp sql封装成函数

<%
' 定义数据库连接字符串
Dim connectionString
connectionString = "Provider=sqloledb;Data Source=你的数据库服务器;Initial Catalog=你的数据库名;User Id=你的用户名;Password=你的密码;"

' 定义数据库连接和命令对象
Dim conn, cmd, rs

' 定义函数来执行SQL查询并返回记录集
Function ExecuteSQL(sql)
Set conn = Server.CreateObject("ADODB.Connection")
Set cmd = Server.CreateObject("ADODB.Command")
Set rs = Server.CreateObject("ADODB.Recordset")

' 打开连接
conn.Open connectionString

' 设置命令对象的连接和SQL文本
Set cmd.ActiveConnection = conn
cmd.CommandText = sql

' 执行命令并返回记录集
Set rs = cmd.Execute()

' 关闭命令对象和连接
Set cmd.ActiveConnection = Nothing
conn.Close()
Set conn = Nothing

' 返回记录集
Set ExecuteSQL = rs
End Function

' 使用函数执行SQL查询
Dim sql, rsResults
sql = "SELECT * FROM 你的表名"
Set rsResults = ExecuteSQL(sql)

' 处理记录集
If Not rsResults.EOF Then
Response.Write("<table>")
Do While Not rsResults.EOF
Response.Write("<tr>")
For i = 0 To rsResults.Fields.Count - 1
Response.Write("<td>" & rsResults.Fields(i).Value & "</td>")
Next
Response.Write("</tr>")
rsResults.MoveNext
Loop
Response.Write("</table>")
Else
Response.Write("没有数据。")
End If

' 释放记录集资源
rsResults.Close
Set rsResults = Nothing
%>

数据库使用ASP连接的函数封装的说明

  我们在一个需要读写数据库的页面里包含类似的代码时,实际上,通常情况下即使你没有进行任何读写数据库操作时,这个数据库连接仍然是打开的,依然在消耗着服务器的资源,如果您使用的是虚拟主机,那您就要注意有可能成为耗资源的用户,影响整台服务器的运转。那么,我们有没有办法让数据库连接仅在需要读取数据库时才打开,不读取时就没有任何动作呢,下面就将提供这种思路,以求抛砖引玉。这种思路也就是将数据库连接代码封装在函数里面,在需要读取时调用这个函数。

  下面是SQL连接代码:

  Function Open_conn()

  dim Conn,Strconn

  set Conn=server.createobject("adodb.connection")

  Strconn = "Provider = Sqloledb; User ID = 数据库登录帐号; Password = 数据库登录密码; Initial Catalog = 数据库名称; Data Source = (local);"

  Conn.open Strconn

  set Open_conn=Conn

  If Err Then

  err.Clear

  Conn.close:set Conn=nothing

  Response.Write "对不起,数据库连接出错。"

  Response.End

  End If

  End Function

  调用方法:

  将原来的

  rs.open sql,conn

  改成

  rs.open sql,Open_conn()

  以下是ACCESS连接代码:

  Function Open_conn()

  dim Dbpath,Conn

  Dbpath=server.MapPath("数据库路径")

  set Conn=server.createObject("ADODB.connection")

  Conn.open "data source="&dbpath&";provider=microsoft.Jet.OLEDB.4.0;"

  set Open_conn=Conn

  If Err Then

  err.Clear

  Conn.close:set Conn=nothing

  Response.Write "对不起,数据库连接出错。"

  Response.End

  End If

  End Function

  调用方法:

  将原来的

  rs.open sql,conn

  改成

  rs.open sql,Open_conn()

  如问题还未解决,请联系售后技术支持。

posted @ 2024-09-19 23:15  黑旗君  阅读(7)  评论(0编辑  收藏  举报