首页 > Unity3D频道 > 【Unity3D研究院之游戏开发】 > Unity3D研究院之Unity中连接本地或局域网MySQL数据库(五十九)
2013
05-11

Unity3D研究院之Unity中连接本地或局域网MySQL数据库(五十九)

         最近MOMO身心疲惫。。今天是周末在家无聊我还是决定来学习。不知道学什么,就学MySQL吧。本篇主要记录从MySQL安装到局域网内任意机器连接数据库,也算是对自己学习的总结。今天我没用Mac电脑,而是选择Windows,没有别有用心,而是想熟悉一下Windows下操作Unity。

官网上下载MySQL的安装程序,这里有一篇详细的安装文章,http://www.jb51.net/article/23876.htm  为了让中文完美的运行,配置MySQL的时候Character Set处设置成UTF-8,好像默认是不能显示中文。配置完毕后就可以在本机中启动MySQL,也可以在cmd命令行中start和stop 启动与关闭MySQL。

 

 为了让本机MySQL数据库可以在局域网中任意机器都可以访问,请看 下面这个网址。

http://dzb3688.blog.163.com/blog/static/105068522201292671444891/

文章有一点点讲的不是很清楚,所以我在补充一下、

我用的是Navicat Pewmium查看数据库,我觉得这个数据库挺好的,因为我在Mac上也是用的这个数据库 。(大家可以在网络上下载它,Windows版本居然有汉化的)如下图所示,点击用户,然后双击”root@%” 最后把主机的名字改成 “%”即可、

Unity3D研究院之Unity中连接本地或局域网MySQL数据库(五十九) - 雨松MOMO程序研究院 - 1

 

 

下面就是重点了,打开cmd 窗口cd到MySQL的路径下,一定要cd到这个路径下,不然mysql 会是无法识别的指令噢。

Unity3D研究院之Unity中连接本地或局域网MySQL数据库(五十九) - 雨松MOMO程序研究院 - 2

 

然后执行命令:

mysql grant all privileges on *.* to root@”%” identified by ‘abc’ with grant option;  
flush privileges;

在执行命令:

mysql flush privileges;

OK这样就行了。

然后开始看看代码怎么写,为了方便数据库的创建、增加、删除、修改、查询、我封装了一个类。欢迎大家测试 啦啦啦啦。

SqlAccess.cs

 

然后在来看看调用,把如下脚本绑定在任意对象即可,调用包括、创建表、插入信息、查找信息、删除信息、更新信息。代码比较简单我就不一一注释了,这里我用try catch如果有错误信息将打印在屏幕中。 创建表包括是否递增ID,所以有两种创建表的方式。如果你的数据库是提前预制的话可以这样来读取数据库。

然后是用到的dll 一个都不能少,不然会出现各种问题。最后的下载地址我会给出,并且包含这些文件。

 

Unity3D研究院之Unity中连接本地或局域网MySQL数据库(五十九) - 雨松MOMO程序研究院 - 3

 

 

为了测试局域网的连接, 我还编译到了Android手机上,在Android上访问这个数据库,也是没问题的。当然手机和电脑用的是同一个wifi网络。 目前这个项目在 Windows 和  Android上都可以很好的运行,我感觉在Mac上和iPhone上应该也木有问题,欢迎大家测试,如果发现在别的平台下有问题请告诉我,我会进一步研究的。 欢迎大家留言,一起学习啦啦啦啦 嘿嘿嘿~~。。

 

Unity3D研究院之Unity中连接本地或局域网MySQL数据库(五十九) - 雨松MOMO程序研究院 - 4

 

 

下载地址:http://vdisk.weibo.com/s/B5ac9

雨松MOMO提醒您:亲,如果您觉得本文不错,快快将这篇文章分享出去吧 。另外请点击网站顶部彩色广告或者捐赠支持本站发展,谢谢!

--

最后编辑:
作者:雨松MOMO
专注移动互联网,Unity3D游戏开发
捐 赠如果您愿意花10块钱请我喝一杯咖啡的话,请用手机扫描二维码即可通过支付宝直接向我捐款哦。

Unity3D研究院之Unity中连接本地或局域网MySQL数据库(五十九)》有 85 条评论

  1. jsjm 说:

    这种unity直接操作数据库 可以拿到增删改的回调么

  2. 刘玉婷 说:

    你好 , 我下载的你的源码导入, Unity 5.4.6, 在编辑器运行正常, 但是发布exe 时候, 出现
    ReflectionTypeLoadException: The classes in the module cannot be loaded.
    System.Reflection.Assembly.GetTypes () (at /Users/builduser/buildslave/mono/build/mcs/class/corlib/System.Reflection/Assembly.cs:371)
    UnityEditor.AttributeHelper+c__Iterator31[System.Collections.Generic.IEnumerable1[UnityEditorInternal.PluginDesc]].MoveNext () (at C:/buildslave/unity/build/Editor/Mono/AttributeHelper.cs:277)
    UnityEditor.PluginImporter+c__Iterator0.MoveNext () (at C:/buildslave/unity/build/Editor/Mono/PluginImporter.cs:41)
    DesktopStandalonePostProcessor.CopyNativePlugins () (at C:/buildslave/unity/build/Editor/Mono/BuildPipeline/DesktopStandalonePostProcessor.cs:116)
    DesktopStandalonePostProcessor.SetupStagingArea () (at C:/buildslave/unity/build/Editor/Mono/BuildPipeline/DesktopStandalonePostProcessor.cs:145)
    DesktopStandalonePostProcessor.PostProcess () (at C:/buildslave/unity/build/Editor/Mono/BuildPipeline/DesktopStandalonePostProcessor.cs:23)
    UnityEditor.WindowsStandalone.WindowsDesktopStandalonePostProcessor.PostProcess (BuildPostProcessArgs args) (at C:/buildslave/unity/build/PlatformDependent/WinPlayer/Extensions/Managed/WindowsDesktopStandalonePostProcessor.cs:118)
    UnityEditor.PostprocessBuildPlayer.Postprocess (BuildTarget target, System.String installPath, System.String companyName, System.String productName, Int32 width, Int32 height, System.String downloadWebplayerUrl, System.String manualDownloadWebplayerUrl, BuildOptions options, UnityEditor.RuntimeClassRegistry usedClassRegistry, UnityEditor.BuildReporting.BuildReport report) (at C:/buildslave/unity/build/Editor/Mono/BuildPipeline/PostprocessBuildPlayer.cs:176)
    UnityEditor.HostView:OnGUI()
    这个要怎么设置呢

  3. 天雨寒 说:

    雨松老师 求问在WINDOWS系统下U3D测试环境下都连MYSQL库测试正常,可是转到安卓发布出APK来,结果都无法连接到库,I18等DLL 文件 以及.NET设置都OK的一直没有找到问题啊会不会和我引入的VUFOIRA的包有冲突还是怎么着这个问题纠结3天了

  4. 天雨寒 说:

    解决了么 我也是这个问题

  5. 政井海人Kite 说:

    感谢博主分享!另外说下我碰到的问题,如果有人碰到相同的问题希望有所帮助看了博主的分享之后我自己做了个简陋的登陆界面在编辑器时测试时毫无问题但发布到Android真机上之后无法使用登录功能写了个try catch把发生的错误输出了出来发现是这样的描述“Encoding name ‘gb2312’ not supported”问题出现在select也就是查询时百度过后有人说这是MySQL.data的问题 但更换了几个版本也没有解决后来我突发奇想直接跑到EditorDataMonolibmono2.0文件夹下将I18开头的几个dll通通导入到项目plugins下再次发布到手机上问题就解决了

  6. 温佳兴 说:

    发布到Android出现问题:ReflectionTypeLoadException: The classes in the module cannot be loaded.System.Reflection.Assembly.GetTypes () (at /Users/builduser/buildslave/mono-runtime-and-classlibs/build/mcs/class/corlib/System.Reflection/Assembly.cs:371)把System.Drawing.dll去掉,选择.net 2.0就可以发布了

留下一个回复

你的email不会被公开。