我一直试图让Linq在Ubuntu上使用Mysql,在存储库(2.10.5)中使用Mono版本,我只会头疼.首先,我不得不修改MySQL提供程序sqlmetal.exe.config,因为它默认设置为旧的和不推荐使用的版本,我设法让它工作设置我在这台机器上...
我一直试图让Linq在Ubuntu上使用Mysql,在存储库(2.10.5)中使用Mono版本,我只会头疼.
首先,我不得不修改MySQL提供程序sqlmetal.exe.config,因为它默认设置为旧的和不推荐使用的版本,我设法让它工作设置我在这台机器上安装的MySQL连接器(来自存储库) )作为sqlmetal的提供者.我为我的目标数据库生成了带有sqlmetal的DataContext,这似乎有效,但我不完全确定.
在生成DataContext之后,我在monodevelop上创建了一个新项目来测试它,起初我尝试使用一个简单的MysqlConenction并检查连接器是否正常工作,我不得不将连接器组件添加到项目中,但这没关系,它工作正常.
然后我尝试使用此代码使用DataContext进行连接:
using System;
using System.Linq;
using System.Data.Linq;
using MySql.Data.MySqlClient;
namespace test
{
public class test
{
public static void Main (String[] args)
{
Test db = new Test (new MySqlConnection("Userid=root;database=test;server=localhost;password=password"));
foreach(var tr in db.Users)
{
Console.Write(tr.Username);
}
}
}
}
此代码失败.似乎Linq正在为MySQL生成错误的SQL代码,至少它抛出的异常似乎是这样说的:
Unhandled Exception: MySql.Data.MySqlClient.MySqlException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '[Id], [Password], [Username]
FROM [test].[Users]' at line 1
at MySql.Data.MySqlClient.MySqlStream.ReadPacket () [0x00000] in <filename unknown>:0
at MySql.Data.MySqlClient.NativeDriver.GetResult (System.Int32& affectedRow, System.Int32& insertedId) [0x00000] in <filename unknown>:0
[ERROR] FATAL UNHANDLED EXCEPTION: MySql.Data.MySqlClient.MySqlException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '[Id], [Password], [Username]
FROM [test].[Users]' at line 1
at MySql.Data.MySqlClient.MySqlStream.ReadPacket () [0x00000] in <filename unknown>:0
at MySql.Data.MySqlClient.NativeDriver.GetResult (System.Int32& affectedRow, System.Int32& insertedId) [0x00000] in <filename unknown>:0
有谁知道是否可以使用Linq和Mono连接到MySQL?有什么我想念的吗?
谢谢!
解决方法:
我不知道为什么每个人似乎都认为LINQ to SQL不适用于Mono.
Mono经常发展:截至今天,LINQ to SQL在Mono和MySQL上运行良好(我在PostgreSQL中成功使用它).
代码中有一点错误:您没有在连接字符串中指定DbLinqProvider.这是生成针对MySQL的SQL代码所必需的.
在这种情况下,生成的SQL代码特定于SQL Server:
"FROM [test].[Users]"
本来应该
"FROM `test`.`Users`"
尝试在连接字符串中添加“DbLinqProvider = MySql”.这应该可以解决您的问题.
见:http://www.mono-project.com/Release_Notes_Mono_2.6#LINQ_to_SQL
您应该知道Mono / DbLinq实现仍然不完整(例如,不支持编译的查询),但足以开发完整的应用程序.
本文标题为:c# – 让Linq与Mysql和Mono玩得很好,有可能吗?
基础教程推荐
- C# params可变参数的使用注意详析 2023-01-27
- C# log4net日志库的用法小结 2023-05-06
- Ruby创建数组方法总结 2023-01-11
- C#实现递归算法经典实例 2023-05-16
- C# .NET 中的缓存实现详情 2023-05-05
- unity中点击某一个按钮播放某一个动作的操作 2023-04-10
- 在 C# 中使用 插值字符串 2023-05-12
- WPF实现自带触控键盘的文本框 2023-07-04
- C# Chart绘制简单图形波形 2023-05-22
- C#打印日志的方法总结 2023-01-22