我一直试图让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#中的Explicit和Implicit详情 2023-05-06
- C#把文件上传到服务器中的指定地址 2023-06-04
- C#中String和StringBuilder的简介与区别 2023-01-06
- Unity 修改FBX模型动画的操作 2023-04-10
- ASP.NET Core 搭配 Nginx 的真实IP问题 2023-09-28
- C#使用 NAudio 实现音频可视化的方法 2023-04-15
- C# .NET及Mono跨平台实现原理解析 2023-02-17
- C# VB.NET 将Html转为Excel 2023-05-26
- C#中GDI+绘制圆弧及圆角矩形等比缩放的绘制 2023-07-04
- 在C#中处理多个数据库连接的最佳方法是什么? 2023-11-13