使用mysql.data.mysqlclient實現C#串連MySQL資料庫

來源:互聯網
上載者:User

在現在的公司做開發兩年多了,前幾天有個朋友問我能不能用.net去串連MySQL資料庫,當時就有些發懵,不過仔細回味回味,發現做的這麼多項目
裡,ASP/ASP.Net始終是和SQL
Server資料庫搭配的,而Java在絕大多數情況下也是和MySQL/Oracle資料庫搭配的,就好像喝豆汁一定要配焦圈一樣。突然要用.Net連
接MySQL還真讓我覺著不那麼舒坦。但是朋友提出的這個問題確實也是一種挑戰,為了幫朋友解決問題,雖然可以通過.Net的控制項來解決,但是這個需要在
伺服器上建立MySQL的ODBC才可以,如果網站遷移到別的伺服器,就需要重建立立資料來源,感覺非常不爽。無奈,在百度上google了一下,發現原來
MySQL原來早想到了和.Net串連的問題,並且提供瞭解決方法,這可比微軟厚道多了,贊一個先。
  MySQL提供的是一個dll檔案——“MySql.Data.dll”,目前我用的就是這個dll檔案,將這個檔案(:http://download.csdn.net/source/1497487
)放到網站的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);
        }
    }
}

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.