gpt4 book ai didi

c# - 嵌入式 MySQL 服务器 C# 包装器?

转载 作者:行者123 更新时间:2023-11-29 02:34:15 26 4
gpt4 key购买 nike

我一直在认真考虑添加 Embedded MYSQL Server Library进入我的应用程序。我的软件是游戏服务器和提供额外功能的 Web 管理面板之间的层。我们的许多客户一直在为他们的服务器请求 MySQL 数据库(因为这是他们的插件开发使用的),并且能够在我的软件中运行一个而不是手动设置它们会很棒。

  • 是否有我缺少的这个库的 .NET 包装器?

  • 我的应用程序正在运行的软件需要能够连接到它,但该软件显然是在本地运行。这行得通吗?

最佳答案

我不知道这个库有任何 .NET 包装器,尽管我记得有人讨论过在版本 5 的 .NET 连接器中引入对该库的支持。不过我现在找不到任何相关信息.

Web 上有一些示例代码,您可以在其上扩展您的代码。我想最完整的是http://forums.mysql.com/read.php?38,67281,67917 ->

using System;
using System.Runtime.InteropServices;
using System.Diagnostics;
using System.Configuration;

class EntryPoint
{
[DllImport("libmySQL.dll")]
static extern IntPtr mysql_init(IntPtr mysql);

[DllImport("libmySQL.dll")]
static extern IntPtr mysql_fetch_lengths(IntPtr result);

[DllImport("libmySQL.dll")]
static extern IntPtr mysql_store_result(IntPtr mysql);

[DllImport("libmySQL.dll")]
static extern IntPtr mysql_fetch_row(IntPtr result);

[DllImport("libmySQL.dll")]
static extern IntPtr mysql_real_connect(IntPtr mysql, string host, string user, string passwd, string db, uint port, string unix_socket, uint client_flag);

[DllImport("libmySQL.dll")]
static extern uint mysql_field_count(IntPtr mysql);

[DllImport("libmySQL.dll")]
static extern string mysql_error(IntPtr mysql);

[DllImport("libmySQL.dll")]
static extern int mysql_real_query(IntPtr mysql, string query, uint length);

static Array MarshalArray(Type structureType, IntPtr arrayPtr, int length)
{
if (structureType == null)
throw new ArgumentNullException("structureType");
if (!structureType.IsValueType)
throw new ArgumentException("Only struct types are supported.", "structureType");
if (length < 0)
throw new ArgumentOutOfRangeException("length", length, "length must be equal to or greater than zero.");
if (arrayPtr == IntPtr.Zero)
return null;
int size = System.Runtime.InteropServices.Marshal.SizeOf(structureType);
Array array = Array.CreateInstance(structureType, length);
for (int i = 0; i < length; i++)
{
IntPtr offset = new IntPtr((long)arrayPtr + (size * i));
object value = System.Runtime.InteropServices.Marshal.PtrToStructure(offset, structureType);
array.SetValue(value, i);
}
return array;
}


static void mysql_real_query(IntPtr mysql, string query)
{
int result = (query != null) ? mysql_real_query(mysql, query, (uint)query.Length) : mysql_real_query(mysql, null, 0);
if (result == 0)
return;
throw new ApplicationException(mysql_error(mysql));
}

static int Main(string[] args)
{
IntPtr ptr = mysql_init(IntPtr.Zero);
Debug.Assert(ptr != IntPtr.Zero);

IntPtr mysql = mysql_real_connect(ptr, ConfigurationSettings.AppSettings["server"], ConfigurationSettings.AppSettings["username"], ConfigurationSettings.AppSettings["password"], ConfigurationSettings.AppSettings["database"], 0, null, 0);
Debug.Assert(ptr != IntPtr.Zero, mysql_error(ptr));

string query = "SELECT * FROM proxy_servers";
Console.WriteLine("Executing query: {0}", query);
mysql_real_query(mysql, query);

IntPtr result = mysql_store_result(mysql);
Debug.Assert(result != IntPtr.Zero, mysql_error(mysql));

uint fieldCount = mysql_field_count(mysql);
Console.WriteLine("field count: {0}", fieldCount);

for (IntPtr ptrRow = mysql_fetch_row(result); ptrRow != IntPtr.Zero; ptrRow = mysql_fetch_row(result))
{
IntPtr[] mysqlRow = (IntPtr[])MarshalArray(typeof(IntPtr), ptrRow, (int)fieldCount);
IntPtr ptrLengths = mysql_fetch_lengths(result);
uint[] lengths = (uint[])MarshalArray(typeof(uint), ptrLengths, (int)fieldCount);
for (int i = 0; i < (int)fieldCount; i++)
{
string str = Marshal.PtrToStringAnsi(mysqlRow[i], (int)lengths[i]);
Console.Write("{0}, ", str);
}
Console.WriteLine();
}
return 0;
}
}

关于c# - 嵌入式 MySQL 服务器 C# 包装器?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7818437/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com