Win8 Javascript Metro App,带有C#WinRT组件和SQLite

我正在创建一个Windows 8商店应用程序.这个应用程序的前端(主项目)是HTML5 / Javascript.我正在关注this guide by Tim Heuer创建一个C#WinRT组件,它包装了SQLite调用并充当控制器.前端通过Javascript调用此组件,以更新数据并获取演示文稿内容.

所以我的解决方案中有2个项目,javascript中的“main”和C#中的“db”.我已经设法让SQLite按照指南工作了.我有这种结构的原因是我正在尝试将应用程序从iOS移植到Win8. “控制器”部分是一个独立的组件,它已经移植到C#.

但是,有一点需要注意.因为this known problem,我必须从’db’项目中删除对C Runtime v11的引用,以使其可编译.虽然它在开发机器上运行良好.

然后我得到了这台测试机(三星xe700t1a确切地说是Intel i5),我发现当在这台测试机器上“调试远程”时,Visual Studio将不会部署SQLite3.结果,我的SQLite调用失败并出现错误:“无法加载DLL的sqlite3”:找不到指定的模块.(HRESULT异常:0x8007007E)“.

根据我之前提到的指南,SQLite通过WinRT扩展可用,是为了自动部署.

我想知道为什么会发生这种情况以及如何使其正确?我也想知道这个结构中的应用程序是否存在针对Windows应用商店的任何认证问题?

我还遇到了this postthis post,表明目前无法在WinRT组件中使用SQLite.但现在改变现在为时已晚,如果没有混合结构,这个项目将无法实现.

解决方法:

我找到了解决方案.我使用了this post的提示,而且非常简单.

我要做的是在解决方案中创建另一个项目,输出类型设置为C#类库.将引用移动到SQLite for WinRT,并将sqlite-net(nuget)包装器移动到这个新项目.之后,我必须手动浏览sqlite-net中的类,并将所有“内部”类更改为“public”.

对于原始控制器项目,我使用myclasslib添加;以便找到类定义.

显然,这种解决方法将完美无瑕地运作.部署了SQLite3,并且没有针对缺少引用的警告.

相关文章

SQLite架构简单,又有Json计算能力,有时会承担Json文件/RES...
使用Python操作内置数据库SQLite以及MySQL数据库。
破解微信数据库密码,用python导出微信聊天记录
(Unity)SQLite 是一个软件库,实现了自给自足的、无服务器...
安卓开发,利用SQLite实现登陆注册功能