天天看點

使用mysql.data.mysqlclient實作C#連接配接MySQL資料庫

在現在的公司做開發兩年多了,前幾天有個朋友問我能不能用.net去連接配接MySQL資料庫,當時就有些發懵,不過仔細回味回味,發現做的這麼多項目裡,ASP/ASP.Net始終是和SQL Server資料庫搭配的,而Java在絕大多數情況下也是和MySQL/Oracle資料庫搭配的,就好像喝豆汁一定要配焦圈一樣。突然要用.Net連接配接MySQL還真讓我覺着不那麼舒坦。但是朋友提出的這個問題确實也是一種挑戰,為了幫朋友解決問題,雖然可以通過.Net的控件來解決,但是這個需要在伺服器上建立MySQL的ODBC才可以,如果網站遷移到别的伺服器,就需要重建立立資料源,感覺非常不爽。無奈,在百度上google了一下,發現原來MySQL原來早想到了和.Net連接配接的問題,并且提供了解決方法,這可比微軟厚道多了,贊一個先。

MySQL提供的是一個dll檔案——“MySql.Data.dll”,目前我用的就是這個dll檔案,将這個檔案(見附件)放到網站的bin目錄下,就可以使用了。而且和SQL Server的用法并沒有太大的出入,隻是應用的名稱不一樣而已。

代碼如下:

1.default.aspx:

<%@ Page Language="C#" AutoEventWireup="true"  CodeFile="Default.aspx.cs" Inherits="_Default" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml" >

<head runat="server">

    <title>無标題頁</title>

</head>

<body>

    <form id="form1" runat="server">

    <div>

        <asp:Table ID="tblTest" runat="server">

            <asp:TableHeaderRow ID="tblRowHeader" runat="server">

                <asp:TableHeaderCell ID="tblCellHeader" runat="server" Text="新聞标題"></asp:TableHeaderCell>

            </asp:TableHeaderRow>

        </asp:Table>

    </div>

    </form>

</body>

</html>

2.default.aspx.cs:

using System.Web;

using System.Web.Security;

using System.Web.UI;

using System.Web.UI.WebControls;

using System.Web.UI.WebControls.WebParts;

using System.Web.UI.HtmlControls;

using MySql.Data.MySqlClient;

public partial class _Default : System.Web.UI.Page 

{

    protected void Page_Load(object sender, EventArgs e)

    {

        string connStr = ConfigurationManager.ConnectionStrings["ConnectionString"].ToString();

        MySqlConnection mySqlConn = new MySqlConnection(connStr);

        string sqlStr = "SELECT name FROM t_document ORDER BY id desc";

        mySqlConn.Open();

        MySqlCommand mySqlCmd = new MySqlCommand(sqlStr,mySqlConn);

        MySqlDataReader mySqlRdr = mySqlCmd.ExecuteReader();

        while (mySqlRdr.Read())

        {

            TableRow tr = new TableRow();

            TableCell tc = new TableCell();

            tc.Text = mySqlRdr["name"].ToString();

            tr.Cells.Add(tc);

            tblTest.Rows.Add(tr);

        }

    }

}

<a href="http://down.51cto.com/data/2352493" target="_blank">附件:http://down.51cto.com/data/2352493</a>

本文轉自 sw840227 51CTO部落格,原文連結:http://blog.51cto.com/jerrysun/153986,如需轉載請自行聯系原作者