分享
 
 
 

.NET2.0下使用LinqMySQL

王朝学院·作者佚名  2010-08-17
窄屏简体版  字體: |||超大  

一、准备工作,我们需要安装一些东西,并拷贝一些东西。

0.打开VS2008或VS2010,新建工程控制台项目LinqMySQL,目标程序集为.NET 3.5

1.下载并一路NEXT安装MySQL

2.下载并一路NEXT安装MySQLWorkBench 打开,并创建test数据库,Customers和Orders两张表

-----------------------------------------------------

create table Customers

(

CustomerID varchar(50) not null PRimary key,

ContractName varchar(50) not null,

Phone varchar(50) not null,

City varchar(50) not null,

Country varchar(50) not null

)

create table Orders

(

OrderID int not null primary key,

OrderDate DateTime,

CustomerId varchar(50) not null,

foreign key(CustomerID) references Customers(CustomerID)

)

-----------------------------------------------------

3.下载并一路NEXT安装MySQL .NET Connector 6.3.2

4.下载并解压DbLinq,并设置路径到系统环境变量

5.在LinqMySql目录下新建LinqDlls文件夹

打开文件夹 C:\Program Files\Reference Assemblies\Microsoft\Framework\v3.5

拷贝以下几个Dll到LinqDlls文件夹

-----------------------------------------------------

System.Core.dll

System.Data.DataSetExtensions.dll

System.Data.Linq.dll

System.Runtime.Serialization.dll

System.xml.Linq.dll

-----------------------------------------------------

6.进入MySQL\MySQL Connector Net 6.3.2\Assemblies\v2.0目录下拷贝

-----------------------------------------------------

MySql.Data.dll

-----------------------------------------------------

到DbLinq的安装目录

二、开始工作了,我们一步步来。

1.打开CMD,CD到DbLinq目录使用DbMetal.exe创建MySQL的DataContext,命令如下:

-----------------------------------------------------

DbMetal.exe

-provider=MySql

-database:MyDatebase

-server:localhost

-user:mysqluser

-passWord:yourpassword

-namespace:LinqMySql

-code:TestDataContext.cs

-sprocs

-----------------------------------------------------

将生成的TestDataContext.cs剪切到LinqMySql项目根目录,并添加到LinqMySql项目

2.在Main函数里面添加如下代码

-----------------------------------------------------

string connStr = @"server=localhost;database=test;user=mysqluser;pwd=yourpassword;";

using (var conn = new MySqlConnection(connStr)){ var t = new Test(conn); var data = from customer in t.Customers select customer.ContractName; foreach (var d in data) { Console.WriteLine(d); }}-----------------------------------------------------3.编译并运行,成功。

4.接下来我们要将.NET 3.5退化到.NET2.0,首先将工程的目标程序集改为.NET2.0,

然后会发现Reference里面有几个dll变为感叹号,将他们都删除,然后将LinqDlls文件夹下的

几个Dll都添加至Referece,然后分别将这几个Dll属性里面的copy local设置为True,将Specify Version设置为False

5.再次编译,则成功!

三、其他故事呢?尝试在.NET2.0下使用LinqDataSet,并且数据库使用MySQL

1.重启VS,使得刚刚添加到MySQL连接器被VS加载。

2.打开Server Explorer,右键Data Connection,添加新链接,改变数据连接器

选择MySql Connector,一路NEXT输入必要的服务器地址,用户名,密码,并测试连接是否成功。

3.将LinqMySql目标程序集更改为.NET3.5,右键工程添加强类型DataSet。

将Server Explorer里的Mysql test数据库下的Customers和Orders表添加到DataSet里。

4.在Main函数里编写测试代码

-----------------------------------------------------

using (var dataSet = new DataSet1()){ var customerAdapter = new DataSet1TableAdapters.CustomersTableAdapter(); var orderAdapter = new DataSet1TableAdapters.OrdersTableAdapter(); customerAdapter.Fill(dataSet.Customers); orderAdapter.Fill(dataSet.Orders); var query = from order in dataSet.Orders where order.OrderDate.Date > new DateTime(2010, 8, 1) select new { order.OrderID, order.CustomerID }; foreach (var order in query) { Console.WriteLine(order.CustomerID); }}-----------------------------------------------------5.编译并运行,成功!

6.等等,现在还只是.NET3.5的,如何来改变到.NET2.0?

尝试直接将目标程序集改变为.NET2.0,编译,失败!

7.TMD查看了下DataSet1.designer.cs,发现在.NET3.5下的如下代码

-----------------------------------------------------public partial class customersDataTable : global::System.Data.TypedTableBase<customersRow>----------------------------------------------------- 现在变成了

-----------------------------------------------------

public partial class customersDataTable : global::System.Data.DataTable, global::System.Collections.IEnumerable-----------------------------------------------------8.所以呢?怎么办?重新将目标程序集设置为.NET3.5,然后到LinqMySql目录下将

-----------------------------------------------------

DataSet1.Designer.cs

DataSet1.xsc

DataSet1.xsd

DataSet1.xss

------------------------------------------------------

几个文件拷贝出来做一个备份,然后将目标程序集再次设置为.NET2.0,然后。。

然后将刚才备份的以上几个文件重新拷贝回工程目录,再次编译运行,成功!

9.至此,我们成功在.NET2.0下使用LinqSQL和LinqDataSet来使用MySql了,但是

我并没有成功在.NET2.0下成功使用LinqEntity来使用MySql。以后再说吧。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有