亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

ASP.NET講座(5)-數據庫的操作ADO.NET

2019-11-18 19:51:28
字體:
來源:轉載
供稿:網友

  自若干年前推出開放式數據庫連接 (ODBC) 應用程序編程接口 (API) 以來,出現了各種各樣的數據庫訪問技術,而 ADO.NET 是其中最新的一種。在這過程中,發生了許多有趣的事。例如,COM 闖入數據庫領域,開始培植 OLE DB 的殖民進程。然后,大致相當于 OLE DB 自動化版本的 ActiveX? Data Objects (ADO) 被選來統治 Windows? 數據庫開發者的 Visual Basic? 和 asp 社區。

  通過 .NET,Microsoft 正在提供通用框架(即 Framework Class Library),其中將包括所有現有的 Windows API 甚至更多的內容。特別值得一提的是,它包括大量常用的庫,而這些庫現在需要通過各個 COM 對象分別獲得。在這些庫中,您會發現 xml 和 ADO 對象模型,它們被集成到了叫做 ADO.NET 的類子樹中。

  ADO.NET 事實上成為構建數據感知 .NET 應用程序的基礎。和 ADO 不同的是,ADO.NET 遵循更通用的原則,不那么專門面向數據庫。ADO.NET 集合了所有允許數據處理的類。這些類表示具有典型數據庫功能(如索引、排序和視圖)的數據容器對象。盡管 ADO.NET 是 .NET 數據庫應用程序的權威解決方案,但從總體設計上來看,它不象 ADO 模型那樣以數據庫為中心,這是 ADO.NET 的一大特點。

  ADO.NET 與 ADO 有很大差異。ADO.NET 是新的數據訪問編程模型,需要開發人員的全面理解、投入和新思維。然而,一旦開始掌握 ADO.NET,您將意識到:原有的 ADO 技巧非常有助于您以不同、卻更巧妙和可靠的方式來創建有效的應用程序和解決各種老問題。
(以上譯自 Microsoft .NET部一位官員的講話)

  5.1 目前的ADO.net

  目前 ADO.NET 提供了兩種托管提供程序:一種用于 SQL Server 7.0 或更高版本,另一種用于其他所有您可能已經安裝的 OLE DB 提供程序。在這兩種情況下您分別使用不同的類,但遵循相似的命名規則。除前綴外,名稱都是相同的。前一種情況前綴為 SQL,后一種情況則是 ADO。

<% @ Import Namespace="System.Data.ADO" %>
<% @ Import Namespace="System.Data.SQL" %>

  您應該使用 SQL 類訪問 SQL Server 表,因為它們直接進入數據庫服務器的內部 API,跳過了由 OLE DB 提供程序表示的中間層。ADO 類是 OLE DB 提供程序上的 .NET 接口,它們使用 COM Interop 橋進行工作。

  5.2 連接一個數據庫

Dim myConnection As New
 SQLConnection("server=localhost;uid=sa;pwd=;database=pubs")
Dim myCommand As New
 SQLDataSetCommand("select * from Authors", myConnection)

或者
 SQLConnection myConnection = new SQLConnection();
 myConnection.DataSource = "localhost";
 myConnection.UserID = "sa";
 myConnection.PassWord = "";
 myConnection.ConnectionTimeout = 30;
 myConnection.Open();
 myConnection.Database = "pub";
 myConnection.IsolationLevel = IsolationLevel.ReadCommitted
  

  這里我們需要講述一下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 結構如下:

uidusernameEmail
1 User1Mail1
2 User2Mail2
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>

?。糷3><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"/>


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美成人激情图片网| 日韩有码在线播放| 亚洲黄页视频免费观看| 成人性教育视频在线观看| 国产69精品久久久久9999| 亚洲视频在线视频| 伊人精品在线观看| 亚洲国产精品电影| 欧美激情一区二区三区成人| 欧美性猛交xxx| 欧美成人一区二区三区电影| 国产这里只有精品| 成人国内精品久久久久一区| 国产精品久在线观看| 色综合视频一区中文字幕| 国产亚洲精品久久久久久777| 国产一区二区日韩精品欧美精品| 亚洲视频免费一区| 91性高湖久久久久久久久_久久99| 最新中文字幕亚洲| 国产一区私人高清影院| 欧美大片在线免费观看| 色先锋久久影院av| 国产亚洲欧美日韩美女| 国产亚洲激情在线| 国产欧美日韩精品专区| 不用播放器成人网| 国产精品视频成人| 成人夜晚看av| 色av中文字幕一区| 在线视频免费一区二区| 欧美日韩亚洲一区二区三区| 成人久久久久久| 欧美国产日韩一区二区| 亚洲自拍欧美另类| 精品久久久中文| 欧洲成人午夜免费大片| 亚洲夜晚福利在线观看| 欧美精品免费播放| 国产精品小说在线| 久久成人18免费网站| 成人免费高清完整版在线观看| 在线免费观看羞羞视频一区二区| 国产精品视频精品| 久久深夜福利免费观看| 国产91精品最新在线播放| 国产精品美女www| 亚洲国产精品小视频| 久久久亚洲欧洲日产国码aⅴ| 日韩av资源在线播放| 好吊成人免视频| 国产精品夫妻激情| 九九视频这里只有精品| 久久久精品视频在线观看| 欧美日韩精品在线播放| 亚洲一区中文字幕在线观看| 亚洲国产高清福利视频| 精品国产乱码久久久久久虫虫漫画| 国产精品专区第二| 亚洲欧美日韩国产中文| 亚洲片在线观看| 国产免费久久av| 国产69精品久久久久9| 精品国产31久久久久久| 国产丝袜一区视频在线观看| 国产精品爽爽爽爽爽爽在线观看| 中文一区二区视频| 欧美亚洲在线视频| 亚洲自拍偷拍第一页| 日韩精品免费在线| 欧美xxxx14xxxxx性爽| 欧美性猛xxx| 国产精品中文字幕在线| 国内精品视频一区| 青青草原成人在线视频| 国产精品久久久久久久久免费看| 2019中文字幕在线免费观看| 欧美日韩国产丝袜另类| 久久中文字幕在线| 国产日韩欧美成人| 尤物99国产成人精品视频| 国产视频丨精品|在线观看| 欧洲精品在线视频| 欧美激情精品在线| 国产成人+综合亚洲+天堂| 国产精品久久激情| 亚洲欧美一区二区三区四区| 欧美日韩性视频在线| 2019日本中文字幕| 欧美午夜美女看片| 爽爽爽爽爽爽爽成人免费观看| 成人h视频在线观看播放| 国产91精品不卡视频| 欧美综合在线观看| 成人福利视频网| 国产精品久久久久福利| 88国产精品欧美一区二区三区| 一区二区三区回区在观看免费视频| 久久国产精品久久久久| 亚洲国产福利在线| 国产精品美乳一区二区免费| 亚洲xxxx视频| 在线观看欧美www| 欧美日韩在线视频观看| 91影院在线免费观看视频| 日韩av在线电影网| 宅男66日本亚洲欧美视频| 中文字幕日韩精品在线观看| 7777精品视频| 亚洲欧美日韩一区二区三区在线| 久久久久久国产精品三级玉女聊斋| 欧美小视频在线| 中文字幕亚洲专区| 中文字幕亚洲无线码在线一区| 亚洲国产精品999| 亚洲精品午夜精品| 97精品视频在线观看| 日韩视频在线免费| 精品欧美激情精品一区| 国产精品一区二区三区在线播放| 日韩国产在线看| 国产精品极品尤物在线观看| 欧美激情在线一区| 性欧美xxxx视频在线观看| 日韩动漫免费观看电视剧高清| 久久在线精品视频| 国产主播欧美精品| 国产日韩欧美影视| 日韩欧美一区视频| 91久久在线视频| 4388成人网| 亚洲精品乱码久久久久久金桔影视| 成人写真视频福利网| 久久亚洲精品视频| 欧美性色xo影院| 国产精品av电影| 亚洲黄色有码视频| 日本三级久久久| 精品视频久久久久久久| 欧美肥老妇视频| 97国产精品人人爽人人做| 国产精品久久中文| 亚洲一区制服诱惑| 国产日韩中文字幕在线| 精品视频偷偷看在线观看| 亚洲人成网7777777国产| 2020欧美日韩在线视频| 欧美日韩不卡合集视频| 国产精品欧美日韩| 91精品国产高清| 欧美日韩激情视频8区| 精品伊人久久97| 精品久久久免费| 欧美激情综合色综合啪啪五月| 久久亚洲影音av资源网| 欧美亚洲国产视频小说| 亚洲肉体裸体xxxx137| 一区二区三区无码高清视频| 国产xxx69麻豆国语对白| 国产精品久久久久9999| 亚洲视频在线观看网站| 亚洲自拍小视频免费观看| 欧美成人精品xxx| 欧美极品少妇与黑人|