在现在的公司做开发两年多了,前几天有个朋友问我能不能用.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);
}
}
}
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);
}
}
}
本文转自 sw840227 51CTO博客,原文链接:http://blog.51cto.com/jerrysun/153986,如需转载请自行联系原作者