mysql server 和 WAMP server 共存问题

mysql server 和 WAMP server 共存问题,第1张

安装好MySQL的数据接口后,你必须在你的代码中引入它才能使用。你可以使用 MySql.Data.MySqlClient这个名空间来连接 MySQL 服务器

。在C#中,可以使用using语句来引入MySQL数据接口:

 using MySql.Data.MySqlClient

另外,你也可以在一个ASP.NET的网页表单(Web Form)中通过使用导入(Import)指令来引入MySQL数据接口:

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

或者,你也可以在你的代码里在使用这个名空间时,写全一个类的完整路径,但是这样的话会比使用Import指令来导入输入更多的字符,

浪费更多的字节。指定了名空间后,我们就可以和MySQL数据库进行数据交互了。MySql.Data.MySqlClient这个名空间提供了许多用于处理

MySQL数据的类。下面是这些类的一个样本:

 * MySqlConnection: 管理和 MySQL 服务器/数据库的连接;

* MySqlDataAdapter: 一套用于填充DataSet对象和更新MySQL数据库的命令和连接的集合;

* MySqlDataReader: 让你能够从一个 MySQL 数据库读取数据。它是一个单向的数据流;

* MySqlCommand: 提供向数据库服务器发送指令的功能;

* MySqlException: 当发生问题时提供例外处理。1.http://dev.mysql.com/downloads/connector/net/5.2.html 下载 mysql connector/net

有几个项,应该是下Windows Binaries (ZIP) 那个,我测试就是用的它,Sources (ZIP)应该指源码。

2. 安装

3. 到安装目录(默认是在C:\Program Files\MySQL)的Binaries文件夹的.NET 2.0文件夹里找MySql.Data.dll ,复制到网站的BIN文件夹里

4. 我在mysql里建了表测试

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>http://www.zddh.net</title>

</head>

<body>

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

<div>

<asp:Label ID="lbl1" runat="server" Text="显示:"></asp:Label>

<asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>

<asp:Button ID="Btn1" runat="server" Text="提交" onclick="Btn1_Click" />

</div>

<asp:GridView ID="GridView1" runat="server" CellPadding="4" ForeColor="#333333"

GridLines="None" Height="181px" Width="406px">

<FooterStyle BackColor="#507CD1" Font-Bold="True" ForeColor="White" />

<RowStyle BackColor="#EFF3FB" />

<PagerStyle BackColor="#2461BF" ForeColor="White" HorizontalAlign="Center" />

<SelectedRowStyle BackColor="#D1DDF1" Font-Bold="True" ForeColor="#333333" />

<HeaderStyle BackColor="#507CD1" Font-Bold="True" ForeColor="White" />

<EditRowStyle BackColor="#2461BF" />

<AlternatingRowStyle BackColor="White" />

</asp:GridView>

</form>

</body>

</html>

using System

using System.Configuration

using System.Data

using System.Linq

using System.Web

using System.Web.Security

using System.Web.UI

using System.Web.UI.HtmlControls

using System.Web.UI.WebControls

using System.Web.UI.WebControls.WebParts

using System.Xml.Linq

using MySql.Data.MySqlClient

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

{

protected void Page_Load(object sender, EventArgs e)

{

string conmysql = "server=localhostuserid=rootdatabase=abcpassword=123"

string sql = "select * from table

MySqlConnection con = new MySqlConnection(conmysql)

MySqlCommand cmd = new MySqlCommand(sql, con)

MySqlDataAdapter myDataAdapter = new MySqlDataAdapter(sql, con)

DataSet ds = new DataSet()

myDataAdapter.Fill(ds)

GridView1.DataSource = ds

GridView1.DataBind()

}

这种架构一般用在以下三类场景

1. 备份多台 Server 的数据到一台如果按照数据切分方向来讲,那就是垂直切分。比如图 2,业务 A、B、C、D 是之前拆分好的业务,现在需要把这些拆分好的业务汇总起来备份,那这种需求也很适用于多源复制架构。实现方法我大概描述下:业务 A、B、C、D 分别位于 4 台 Server,每台 Server 分别有一个数据库来隔离前端的业务数据,那这样,在从库就能把四台业务的数据全部汇总起来,而不需要做额外的 *** 作。那没有多源复制之前,要实现这类需求,只能在汇总机器上搭建多个 MySQL 实例,那这样势必会涉及到跨库关联的问题,不但性能急剧下降,管理多个实例也没有单台来的容易。

2. 用来聚合前端多个 Server 的分片数据。

同样,按照数据切分方向来讲,属于水平切分。比如图 3,按照年份拆分好的数据,要做一个汇总数据展现,那这种架构也非常合适。实现方法稍微复杂些:比如所有 Server 共享同一数据库和表,一般为了开发极端透明,前端配置有分库分表的中间件,比如爱可生的 DBLE。

3. 汇总并合并多个 Server 的数据

第三类和第一种场景类似。不一样的是不仅仅是数据需要汇总到目标端,还得合并这些数据,这就比第一种来的相对复杂些。比如图 4,那这样的需求,是不是也适合多源复制呢?答案是 YES。那具体怎么做呢?


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/6201378.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-17
下一篇 2023-03-17

发表评论

登录后才能评论

评论列表(0条)

保存