自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

ASP.NET連接MySQL數(shù)據(jù)庫的正確解決方案

數(shù)據(jù)庫 MySQL
今天主要和大家一起討論的是ASP.NET連接MySQL數(shù)據(jù)庫,我前兩天在相關(guān)網(wǎng)站看見其相關(guān)資料,今天就拿出來供大家分享。

以下的文章主要描述的是ASP.NET連接MySQL數(shù)據(jù)庫的正確解決方案,如果你在實(shí)際操作中遇到ASP.NET連接MySQL數(shù)據(jù)庫這一要求,但是你卻不知道對其如何正確的解決,那么以下的文章對你而言一定是良師益友。

由于富有競爭力的價格和易于使用,MySQL在市場占有率方面逐步提升。開放源代碼社區(qū)為了擴(kuò)展MySQL的使用范圍,開發(fā)出了.Net框架(.NET Framework)中可以使用的數(shù)據(jù)庫連接器。我們就來學(xué)習(xí)一下如何在.Net應(yīng)用程序中使用MySQL。

MySQL漸漸的成為了在選擇數(shù)據(jù)庫平臺時一個切實(shí)可行的數(shù)據(jù)庫方案。能夠證明這一點(diǎn)的就是許多公司都選擇mySQL作為他們的數(shù)據(jù)庫平臺,例如 Google、美聯(lián)社(The Associated Press) 以及美國國家航空宇航局( NASA)。雖然對于一個開放源代碼來說,低廉的價格常常被當(dāng)作主要優(yōu)點(diǎn)來說服客戶,但是對于象Google那樣的大規(guī)模的組織來說,他們不會放心的把非常有用的信息存放在一個只有價格優(yōu)勢的數(shù)據(jù)庫產(chǎn)品中。MySQL真正的實(shí)力遠(yuǎn)遠(yuǎn)的超過了他的價格優(yōu)勢,他提供了豐富的來自開放源代碼社區(qū)和商業(yè)化的附加工具。

和.NET的數(shù)據(jù)整合

MySQL 社區(qū)已經(jīng)開發(fā)出了MySQL的數(shù)據(jù)接口,他提供了連接數(shù)據(jù)源和程序代碼的基本功能。在Windows平臺上,有如下的MySQL連接器:

MySQL Connector/Net 1.0 (之前被稱為ByteFX.Data):是一個為MySQL設(shè)計(jì)的開放源代碼.NET數(shù)據(jù)接口。它是完全用C#來開發(fā)的,我們可以在在 MySQL.com網(wǎng)站上找到它。(注意:在本文的例子中,我們都會使用MySQL Connector/Net 1.0這個數(shù)據(jù)接口來連接MySQL數(shù)據(jù)庫,利用Windows安裝程序即可輕易安裝它,它的代碼實(shí)例和文檔也包含其中。)

MySQLDirect .NET Data Provider: 是一個由 Core Lab 開發(fā)的商業(yè)數(shù)據(jù)接口。他的價格由購買的許可證的類型決定,但是我們可以下載它的試用版。

如果你使用 Mono,那么在 Mono網(wǎng)站上可以找到PHP連接器的下載。如果你在Windows平臺上運(yùn)行Mono的話,你下載的連接器包含了安裝程序。如果不是的話,那就要根據(jù)你的操作系統(tǒng)的種類去下載合適的連接器了。

使用MySQL數(shù)據(jù)接口

安裝好MySQL的數(shù)據(jù)接口后,你必須在你的代碼中引入它才能使用。你可以使用 MySql.Data.MySqlClient這個名空間來連接 MySQL 服務(wù)器。在C#中,可以使用using語句來引入MySQL數(shù)據(jù)接口:

  1. using MySql.Data.MySqlClient; 

另外,你也可以在一個ASP.NET的網(wǎng)頁表單(Web Form)中通過使用導(dǎo)入(Import)指令來引入MySQL數(shù)據(jù)接口

  1. <%@ Import Namespace "MySql.Data.MySqlClient" %> 

或者,你也可以在你的代碼里在使用這個名空間時,寫全一個類的完整路徑,但是這樣的話會比使用Import指令來導(dǎo)入輸入更多的字符,浪費(fèi)更多的字節(jié)。指定了名空間后,我們就可以和MySQL數(shù)據(jù)庫進(jìn)行數(shù)據(jù)交互了。MySql.Data.MySqlClient這個名空間提供了許多用于處理MySQL數(shù)據(jù)的類。下面是這些類的一個樣本:

MySqlConnection: 管理和 MySQL 服務(wù)器/數(shù)據(jù)庫的連接;

MySqlDataAdapter: 一套用于填充DataSet對象和更新MySQL數(shù)據(jù)庫的命令和連接MySQL數(shù)據(jù)庫的集合;

MySqlDataReader: 讓你能夠從一個 MySQL 數(shù)據(jù)庫讀取數(shù)據(jù)。它是一個單向的數(shù)據(jù)流;

MySqlCommand: 提供向數(shù)據(jù)庫服務(wù)器發(fā)送指令的功能;

MySqlException: 當(dāng)發(fā)生問題時提供例外處理。

我們會使用其中的一些類去和我們的范例數(shù)據(jù)庫進(jìn)行數(shù)據(jù)交互。

連接 MySQL 數(shù)據(jù)庫

使用MySQL數(shù)據(jù)庫的***步是要通過MySQLConnection類和數(shù)據(jù)庫建立連接。通過一個連接字串,MySqlConnection 將會被實(shí)例化成一個示例。連接字符串將告訴代碼到哪里去找MySQL服務(wù)器以及其他一些選項(xiàng)。

表A就是一個連接字串的例子。這個連接字串告訴代碼使用指定的用戶名和密碼去連接一個名為MySQLTestServer的MySQL服務(wù)器,并進(jìn)入techrepublic數(shù)據(jù)庫。我在我的測試機(jī)上設(shè)定了允許匿名登陸(這樣的設(shè)定有非常大的安全漏洞,所以不建議你在生產(chǎn)服務(wù)器上也這么做),所以在范例中將會使用如下的連接字串:

  1. "server=localhostdatabase=sitepoint;" 

指定了連接字串后, MySqlConnection 對象的Open方法就被調(diào)用并打開連接。連接MySQL數(shù)據(jù)庫建立后,你就可以給MySQL數(shù)據(jù)庫發(fā)送命令或從數(shù)據(jù)庫獲得數(shù)據(jù)了。

ASP.NET和MySQL的組合

讓我們更深入的討論一下結(jié)合MySqlConnection類和其他的類來生成一個MySQL服務(wù)器上的數(shù)據(jù)庫列表。表 B列出了一個使用C#寫的ASP.NET的網(wǎng)頁表單。它建立了一個連接,接著給服務(wù)器下了一個指令(SHOW DATABASES),然后通過MySqlReader對象把結(jié)果顯示出來。

使用 MySqlCommand 對象向MySQL服務(wù)器發(fā)送 SHOW DATABASES 命令和直接在 MySQL 管理工具中輸入這個命令得結(jié)果是一樣的。***的區(qū)別是,我們在代碼中必須使用另一個對象來獲取結(jié)果集。MySqlDataReader 對象在獲取結(jié)果時被實(shí)例化(通過 MySqlCommand 類的 ExecuteReader 方法)。MySqlDataReader 對象的 GetString 方法被用于通過ASP.NET的標(biāo)簽控制來顯示結(jié)果集中的數(shù)據(jù)。GetString 方法的指針0指定了顯示結(jié)果集的當(dāng)前行(在while循環(huán)中)的***列數(shù)據(jù)。

Mono提示

如果你使用開放源代碼的Mono開發(fā)平臺,例子中的代碼只需要做小小的改動就能正常的運(yùn)行。MySQL的數(shù)據(jù)接口在 ByteFX.Data.MySqlClient 這個空間名里,而不是Windows上的MySql.Data.MySqlClient空間名。事實(shí)上 MySQL 的數(shù)據(jù)接口原來是由 ByteFX公司開發(fā)的,但是后被MySQL公司收購。所以如果你使用Mono的話,你必須這樣聲明空間名:

  1. using ByteFX.Data.MySqlClient; 

結(jié)語

MySQL 和 .NET 的組合提供了一個強(qiáng)大的開發(fā)平臺。MySQL在開源社區(qū)得到了強(qiáng)大的技術(shù)支持,.NET也通過 Mono 而被開放源代碼社區(qū)所接受。這樣的組合提供了一個在Windows,及其他語言如UNIX或Linux,環(huán)境下高度靈活的開發(fā)平臺。 以上的相關(guān)內(nèi)容就是對ASP.NET連接MySQL數(shù)據(jù)庫的介紹,望你能有所收獲。

 【編輯推薦】

  1. MySQL數(shù)據(jù)庫返回影響行數(shù)的實(shí)際操作流程
  2. 用SubSonic連接MySQL數(shù)據(jù)庫的正確配置方案
  3. MySQL數(shù)據(jù)庫權(quán)限設(shè)置的實(shí)際運(yùn)行過程
  4. MySQL 觸發(fā)器insert 的3個示例演示
  5. 用linux安裝MySQL時產(chǎn)生問題破解
責(zé)任編輯:佚名 來源: cnblogs
相關(guān)推薦

2010-06-07 14:34:49

連接MySQL 數(shù)據(jù)庫

2010-05-25 08:49:33

連接MySQL

2009-07-28 17:36:21

ASP.NET數(shù)據(jù)庫連

2010-05-24 17:12:23

連接MYSQL

2009-07-29 09:12:31

ASP.NET數(shù)據(jù)庫連

2009-08-05 15:40:49

ASP.NET連接數(shù)據(jù)

2011-08-01 23:34:34

ASP.NETOracle

2012-01-11 10:55:02

ASP.NET MVC

2009-07-24 11:24:33

ASP.NET中文亂碼

2009-07-31 17:07:40

ASP.NET數(shù)據(jù)庫連

2011-07-12 14:37:47

ASP.NET鏈接字符串

2009-07-29 09:33:14

ASP.NET數(shù)據(jù)庫連

2009-07-28 14:16:31

ASP.NET與MyS

2009-07-22 11:00:30

ASP.NET MVC

2009-07-22 17:37:06

ASP.NET Ses

2009-02-23 15:20:03

SQL Server數(shù)據(jù)庫ASP.NET

2009-07-31 09:57:47

ASP.NET數(shù)據(jù)庫緩

2011-03-07 16:42:05

MySQL數(shù)據(jù)庫安全

2010-06-04 18:24:20

2009-07-30 16:02:53

點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號