我正在做一些应用程序(遗留代码),它基本上扫描设备的歌曲和提供浏览。
现在,为了提高某些特性的性能,需要使用3个数据库,如下所示:

我使用的是sqlite3,我打开一个数据库会话并附加另外两个数据库。
现在,如果您在没有附加别名的情况下触发SQL查询,比如SELECT * FROM songs;,它将选择别名main的数据库。
遗留浏览器模块具有所有这样的SQL查询(没有附加数据库别名,我无法更改它们,因此它们将继续使用别名main的数据库。
解决方案是在需要时将别名main分配给适当的数据库。
我的问题是:
发布于 2014-11-06 07:51:15
不可能更改已附加的数据库(包括main)的数据库名称。
然而,文档说:
如果不同数据库中的两个或多个表具有相同的名称,并且在表引用上不使用数据库名称前缀,那么所选择的表就是最近附加的数据库中的表。
因此,您可以做的是打开一些空数据库作为主数据库(只需使用:memory:),并按照所需的顺序附加其他三个数据库。
https://stackoverflow.com/questions/26773590
复制相似问题