我正在开发一个 GUI 应用程序,该应用程序将用于对 AI 算法生成的大型数据集执行“手动评估”。评估的性质对这个问题并不重要;只是程序需要从服务器定期检查新数据,下载,然后上传结果,用户产生。就这个问题而言,每个数据集只是一个二进制 blob。
将托管数据的机器当前设置有 Microsoft SQL Server。出于管理原因,我可能不得不使用 SQL Server(而不是在同一台机器上运行的 Web 服务器)来存储数据。我知道 SQL,但我怀疑我在学习 Microsoft 版本的 SQL 时会遇到困难。
这是困难的部分:该程序需要在 Mac OS X 和 Windows 上运行。我在 Windows 开发方面没有太多经验,我的大部分代码都是在 Mac 上使用 XCode 编写的——使用交叉编译器和 Windows VM 来编译/测试 Windows 版本。 (但是,我已经在 Windows 上使用了 GUI,所以这不是问题所在。代码在 Objective-C 中,但我很乐意使用纯 C 甚至 C++ 来访问数据库.)
该程序只需要连接到 SQL Server 并执行简单的查询。我真的很想要一个库,我可以将它链接到我的应用程序中,以便它可以做它的事情——我可以用 SQLite 做到这一点。 ,但我显然会传递连接字符串而不是数据库文件名。我希望最终用户不必在他们的机器上安装任何额外的东西。到目前为止,这是我发现的内容:
最后两个是开源的。快速查看代码显示 FreeTDS 使用 BSD 套接字连接到服务器(我还没有弄清楚 IODBC 使用什么,但可能是一样的),我不明白为什么代码的任何其他部分会是不可携带。如有必要,我会准备尝试将 FreeTDS 套接字代码移植到 Winsock,前提是我可以相当确定我不会遇到任何进一步的障碍。
我能否获取这些库之一(或任何其他库)以链接到我的应用程序的 Mac 和 Windows 版本?
如果不是,请使用什么库的最佳组合来确保最少的麻烦?无论哪种情况,在分发 Windows 版本时是否有任何我需要了解的问题,例如需要在用户计算机上安装的 DLL?
在@TomTom 的推荐下,我打算尝试 FreeTDS。不管我最初怎么想,它确实可以在 Windows 上编译,而且似乎使用 TDS 的 native 实现被认为比 ODBC 更好,后者显然已经过时 10 年了。
最佳答案
iOBDC 是一个 ODBC 驱动程序管理器,而不是一个实际的 ODBC 驱动程序,因此如果您要使用它,MS SQL Server 也需要一个 ODBC 驱动程序。如果您在 Mac OS X 上开发并且有一个用于 Windows 的交叉编译器,那么您可以创建一个 ODBC 应用程序来执行您在 Mac OS X 上需要的这些数据库操作,然后为 Windows 进行交叉编译。构建 ODBC 应用程序的美妙之处在于,您随后只需要目标数据库和操作系统的源代码和 ODBC 驱动程序,这样您就不会被调查。例如,OpenLink Software 有一套适用于包括 SQL Server 在内的大多数流行关系数据库的 ODBC 驱动程序,详见 http://uda.openlinksw.com/sqlserver-odbc/。
关于 OLEDB,它可能是一种比 ODBC 更新的技术,但由于它是特定于 Windows 的,因此未能通过时间的考验,并且已经被 ADO.Net 取代,这是另一种特定于 Windows 的技术(除非您有 Mono)。而 ODBC 是一种主要的通用数据访问 API,可用于大多数商业操作系统的 Windows、Linux/Unix、Mac OS X 等,并继续由其他第三方供应商(如 OpenLink Software)提供支持和维护,他们将确保它保持稳健且可行的跨平台和独立于数据库的 API。
关于sql-server - 从跨平台应用程序连接到 MS SQL Server,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3490348/
我需要在客户计算机上运行Ruby应用程序。通常需要几天才能完成(复制大备份文件)。问题是如果启用sleep,它会中断应用程序。否则,计算机将持续运行数周,直到我下次访问为止。有什么方法可以防止执行期间休眠并让Windows在执行后休眠吗?欢迎任何疯狂的想法;-) 最佳答案 Here建议使用SetThreadExecutionStateWinAPI函数,使应用程序能够通知系统它正在使用中,从而防止系统在应用程序运行时进入休眠状态或关闭显示。像这样的东西:require'Win32API'ES_AWAYMODE_REQUIRED=0x0
对于具有离线功能的智能手机应用程序,我正在为Xml文件创建单向文本同步。我希望我的服务器将增量/差异(例如GNU差异补丁)发送到目标设备。这是计划:Time=0Server:hasversion_1ofXmlfile(~800kiB)Client:hasversion_1ofXmlfile(~800kiB)Time=1Server:hasversion_1andversion_2ofXmlfile(each~800kiB)computesdeltaoftheseversions(=patch)(~10kiB)sendspatchtoClient(~10kiBtransferred)Cl
Rackup通过Rack的默认处理程序成功运行任何Rack应用程序。例如:classRackAppdefcall(environment)['200',{'Content-Type'=>'text/html'},["Helloworld"]]endendrunRackApp.new但是当最后一行更改为使用Rack的内置CGI处理程序时,rackup给出“NoMethodErrorat/undefinedmethod`call'fornil:NilClass”:Rack::Handler::CGI.runRackApp.newRack的其他内置处理程序也提出了同样的反对意见。例如Rack
我想用ruby编写一个小的命令行实用程序并将其作为gem分发。我知道安装后,Guard、Sass和Thor等某些gem可以从命令行自行运行。为了让gem像二进制文件一样可用,我需要在我的gemspec中指定什么。 最佳答案 Gem::Specification.newdo|s|...s.executable='name_of_executable'...endhttp://docs.rubygems.org/read/chapter/20 关于ruby-在Ruby中编写命令行实用程序
我构建了两个需要相互通信和发送文件的Rails应用程序。例如,一个Rails应用程序会发送请求以查看其他应用程序数据库中的表。然后另一个应用程序将呈现该表的json并将其发回。我还希望一个应用程序将存储在其公共(public)目录中的文本文件发送到另一个应用程序的公共(public)目录。我从来没有做过这样的事情,所以我什至不知道从哪里开始。任何帮助,将不胜感激。谢谢! 最佳答案 无论Rails是什么,几乎所有Web应用程序都有您的要求,大多数现代Web应用程序都需要相互通信。但是有一个小小的理解需要你坚持下去,网站不应直接访问彼此
我尝试运行2.x应用程序。我使用rvm并为此应用程序设置其他版本的ruby:$rvmuseree-1.8.7-head我尝试运行服务器,然后出现很多错误:$script/serverNOTE:Gem.source_indexisdeprecated,useSpecification.Itwillberemovedonorafter2011-11-01.Gem.source_indexcalledfrom/Users/serg/rails_projects_terminal/work_proj/spohelp/config/../vendor/rails/railties/lib/r
刚入门rails,开始慢慢理解。有人可以解释或给我一些关于在application_controller中编码的好处或时间和原因的想法吗?有哪些用例。您如何为Rails应用程序使用应用程序Controller?我不想在那里放太多代码,因为据我了解,每个请求都会调用此Controller。这是真的? 最佳答案 ApplicationController实际上是您应用程序中的每个其他Controller都将从中继承的类(尽管这不是强制性的)。我同意不要用太多代码弄乱它并保持干净整洁的态度,尽管在某些情况下ApplicationContr
我是一个Rails初学者,但我想从我的RailsView(html.haml文件)中查看Ruby变量的内容。我试图在ruby中打印出变量(认为它会在终端中出现),但没有得到任何结果。有什么建议吗?我知道Rails调试器,但更喜欢使用inspect来打印我的变量。 最佳答案 您可以在View中使用puts方法将信息输出到服务器控制台。您应该能够在View中的任何位置使用Haml执行以下操作:-puts@my_variable.inspect 关于ruby-on-rails-如何在我的R
如何检查Ruby文件是否是通过“require”或“load”导入的,而不是简单地从命令行执行的?例如:foo.rb的内容:puts"Hello"bar.rb的内容require'foo'输出:$./foo.rbHello$./bar.rbHello基本上,我想调用bar.rb以不执行puts调用。 最佳答案 将foo.rb改为:if__FILE__==$0puts"Hello"end检查__FILE__-当前ruby文件的名称-与$0-正在运行的脚本的名称。 关于ruby-检查是否
是否可以在应用程序中包含的gem代码中知道应用程序的Rails文件系统根目录?这是gem来源的示例:moduleMyGemdefself.included(base)putsRails.root#returnnilendendActionController::Base.send:include,MyGem谢谢,抱歉我的英语不好 最佳答案 我发现解决类似问题的解决方案是使用railtie初始化程序包含我的模块。所以,在你的/lib/mygem/railtie.rbmoduleMyGemclassRailtie使用此代码,您的模块将在