Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/mysql/70.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

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/0/performance/5.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
Mysql 从JDBC调用存储过程时的最佳实践_Mysql_Performance_Stored Procedures_Jdbc - Fatal编程技术网

Mysql 从JDBC调用存储过程时的最佳实践

Mysql 从JDBC调用存储过程时的最佳实践,mysql,performance,stored-procedures,jdbc,Mysql,Performance,Stored Procedures,Jdbc,我试图通过将多个查询调用组合到存储过程中来提高应用程序的性能。这将减少n/w流量、往返,并将数据处理逻辑与应用程序分离 当我在做这件事的时候,我想用最有效的方法来做 到目前为止,我计划使用PreparedStatement和prepareCall方法 如果有更好的方法,请提出建议 我需要将许多IN-params传递给过程,还需要OUT-params返回JAVA代码 据我所知,没有“更好”的办法。您已经在应用程序中做了总体上更好的事情。使用存储过程,而不是普通SQL。所以你得到了曲线。如果您确实迫

我试图通过将多个查询调用组合到存储过程中来提高应用程序的性能。这将减少n/w流量、往返,并将数据处理逻辑与应用程序分离

当我在做这件事的时候,我想用最有效的方法来做

到目前为止,我计划使用
PreparedStatement
prepareCall
方法

如果有更好的方法,请提出建议


我需要将许多
IN-params
传递给过程,还需要
OUT-params
返回
JAVA
代码

据我所知,没有“更好”的办法。您已经在应用程序中做了总体上更好的事情。使用存储过程,而不是普通SQL。所以你得到了曲线。如果您确实迫切需要性能,那么您可能还想看看数据库本身。缓存、索引等。从应用程序中,您可以使用memcache,一个缓存层。但我想这些不是您现在想要的。

而您的问题可以通过指导您学习一些教程来轻松回答,例如:

。。。我仍然想指出,在MySQL中使用存储过程有很多注意事项。请考虑回答这个问题:

例如,第一个问题:

MySQL存储过程在会话第一次使用时进行编译,但在会话结束时会丢弃编译后的版本。与Oracle或其他RDBMS品牌中的存储过程不同,Oracle或其他RDBMS品牌中的存储过程保持编译版本的持久性。这意味着MySQL给过程增加了很多开销,特别是当您的模式是每个会话只调用一次过程时