這裡我們需要講述一下Connection的方法和屬性了。
ConnectionTimeout超時
DataBase 缺省數據庫
DataSource DNS
UserID 原來叫UID
PassWord
State 取得目前連接的狀態
Open() 打開
Close() 關閉
5.3 操作數據庫
通過一個Command對象,我們才可以對數據庫進行操作
Dim myConnection As SQLConnection = New SQLConnection("server=localhost;uid=sa;
pwd=;database=pubs")
Dim myCommand As SQLCommand = New SQLCommand("select * from Authors", myConnection)
myConnection.Open()
Dim dr As New SQLDataReader
myCommand.Execute(dr)
...
myConnection.Close()
或者 這樣做
Dim myConnection As New SQLConnection("server=localhost;uid=sa;pwd=;database=pubs")
Dim mycommand As New SQLCommand( _
"UPDATE Authors SET phone='(800) 555-5555' WHERE au_id = '123-45-6789'", _
myConnection)
myCommand.ActiveConnection.Open()
myCommand.ExecuteNonQuery()
myCommand.ActiveConnection.Close()
這些都是SQLCommand的標准用法,下面列出了Command的所有屬性和相關方法。
ActiveConnection 取得或設置聯結Connections
CommandText 執行的SQL語句或儲存過程(StoredProcedure)名
CommandTimeout 超時
CommandType Command操作的類型(StoredProcedure,Text,TableDirect)三種,默認Text
Parameters 操作儲存過程時使用
Execute() 執行SQL語句或儲存過程
ExecuteNonQuery() 同上,但無返回,或者說,只返回記錄的數量
注意: 和ASP一樣,在運行完以後一定要注意關閉Connection,否則會很耗服務器資源的。
5.4 數據的顯示
在這節的講解前,我們先建立一個數據庫,名字叫 ASPnet 然後裡面有一張表user 結構如下:
uid
username
Email
1
User1
Mail1
2
User2
Mail2
3
User3
Mail3
SQL 語句 Select * From User
數據庫語句 server=localhost;uid=sa;pwd=;database=ASPnet
5.4.1 用 DataReader 方法顯示數據
有兩種方法可以顯示數據 DataReader方法,和DataSet方法,而DataReader只能儲存查詢數據,我們先講用DataReader方法顯示
<script language="VB" runat="server">
Sub Page_Load(Src As Object, E As EventArgs)
Dim MyConnection As SQLConnection =
New SQLConnection("server=localhost;uid=sa;
pwd=;database=ASPnet")
Dim MyCommand As SQLCommand =
New SQLCommand("select * from User", MyConnection)
MyConnection.Open()
Dim DR As SQLDataReader
MyCommand.Execute(DR)
MyDataGrid.DataSource = DR
MyDataGrid.DataBind()
MyConnection.Close()
End Sub
</script>
<ASP:DataGrid id="MyDataGrid" runat="server"
Width="700"
BackColor="#ccccff"
BorderColor="black"
ShowFooter="false"
CellPadding=3
CellSpacing="0"
Font-Name="Verdana"
Font-Size="8pt"
HeaderStyle-BackColor="#aaaadd"
/>
對於顯示的控制,大家可以復習一下前一講,數據的綁定,其實多聯系也是一種很好的方法。
在定制顯示中,還有一種比較使用的方法,而不用綁定
Dim DR As SQLDataReader
DR["字段名"]的方法也可以取到數據
5.4.2 用 DataSet 方法顯示數據
用DataSet記錄的數據其實就是一個表,而對表的操作,只是對DataSet的操作,並沒有改變數據庫,而要到DataSet更新的時候,才完整的寫入數據庫,這個往往是新手容易忽視的地方。
<%@ Import Namespace="System.Data" %>
<%@ Import Namespace="System.Data.SQL" %>
<Html>
<script language="VB" runat="server">
Sub Page_Load(Src As Object, E As EventArgs)
Dim DS As DataSet
Dim MyConnection As SQLConnection
Dim MyCommand As SQLDataSetCommand
MyConnection = New
SQLConnection("server=localhost;uid=sa;pwd=;database=ASPnet")
MyCommand =
New SQLDataSetCommand("select * from User",MyConnection)
DS = new DataSet()
~~~初始化DataSet()
MyCommand.FillDataSet(ds, "User")
~~~FillDataSet顧名思義把整個查詢內容儲存進DataSet中
MyDataGrid.DataSource=ds.Tables("User").DefaultVIEw
MyDataGrid.DataBind()
~~~綁定數據
End Sub
</script>
<body>
<h3><font face="Verdana">
Simple Select to a DataGrid Control
</font></h3>
<ASP:DataGrid id="MyDataGrid" runat="server"
Width="700"
BackColor="#ccccff"
BorderColor="black"
ShowFooter="false"
CellPadding=3
CellSpacing="0"
Font-Name="Verdana"
Font-Size="8pt"
HeaderStyle-BackColor="#aaaadd"
MaintainState="false"
/>
</body>
</Html>
5.5 數據的添加,修改,和刪除
其實他們是在就是簡單的不要再簡單的東西。
添加:
DataRow dr=SQLDataSet.Tables["User"].NewRow();
dr["id"] = "4";
dr["username"] = "user4";
dr["Email"] = "mail4";
SQLDataSet.Tables.Rows.Add(dr);
修改:
SQLDataSet.Tables["user"].Rows[3]["username"]= "user5"
刪除:
SQLDataSet.Tables["user"].Rows[3].Delete()
修改完之後,必須更新數據庫
SQLCommand.Update(SQLDataSet, "user")
5.6 關於顯示中的分頁問題
這個問題,一再在論壇中給眾人提出過,曾經是ASP中,一個比較難解決的問題,不過在ASP.Net中,只不過是DataGrid的一個屬性而已。
AllowPaging="True" 是否支持分頁
PageSize="10" 每頁顯示多少
PagerStyle-HorizontalAlign="Left" 分頁顯示的定位
完整的例子:
<ASP:DataGrid id="dataGrid1" runat="server"
BorderColor="black"
BorderWidth="1"
GridLines="Both"
CellPadding="3"
CellSpacing="0"
HeaderStyle-BackColor="#aaaadd"
AllowPaging="True"
PageSize="10"
PagerStyle-HorizontalAlign="Left"/>