Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/400.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 哪个更好在MySQL中使用DATABASE Vs DATABASE.TABLE_名称_Java_Mysql_Database - Fatal编程技术网

Java 哪个更好在MySQL中使用DATABASE Vs DATABASE.TABLE_名称

Java 哪个更好在MySQL中使用DATABASE Vs DATABASE.TABLE_名称,java,mysql,database,Java,Mysql,Database,我在一个多共享数据库环境MySQL中工作,我需要经常在多个数据库之间切换 假设我的主数据库是MainDB 此外,每个用户都有共享数据库,如ShardDB1、ShardDB2 因为我使用的是JAVA连接池,所以在执行每个查询时,我必须获得要执行的连接,并在完成执行后将其释放到池中 我尝试了以下方法,但没有发现任何性能差异或任何问题 每次我想使用SharedDB,我都会像使用ShardDB1一样切换到SharedDB;再次执行查询执行后,切换回MainDB,如使用MainDB 编写查询,如Selec

我在一个多共享数据库环境MySQL中工作,我需要经常在多个数据库之间切换

假设我的主数据库是MainDB

此外,每个用户都有共享数据库,如ShardDB1、ShardDB2

因为我使用的是JAVA连接池,所以在执行每个查询时,我必须获得要执行的连接,并在完成执行后将其释放到池中

我尝试了以下方法,但没有发现任何性能差异或任何问题

每次我想使用SharedDB,我都会像使用ShardDB1一样切换到SharedDB;再次执行查询执行后,切换回MainDB,如使用MainDB

编写查询,如Select*from+ShardDB1+.TABLE_NAME,其中


第二种方法对我来说更容易在代码中使用。但是在我把它推向生产之前,我想知道在使用第二种方法时是否有任何问题。我在谷歌上搜索了一下,但没有找到。请阐明这一点。

性能没有真正的区别。在第一种情况下,服务器编辑请求,添加前缀本身。在第二个示例中,前缀是一个java变量。如果存在差异,则约为0.1 ms或更小

USE DATABASE语句是开发人员编写请求的快捷方式。 在处理多个数据库时,最好不要使用此语句,而是使用db名称作为表的前缀。然后,如果您忘记在请求中指定名称,就不会冒险更改错误的数据库