在java中存储sql查询的最佳方法是啥
Posted
技术标签:
【中文标题】在java中存储sql查询的最佳方法是啥【英文标题】:What is the best way to store sql queries in java在java中存储sql查询的最佳方法是什么 【发布时间】:2019-10-21 22:35:22 【问题描述】:我正在使用 java servlet 编写一个简单的服务器。为了从数据库中获取数据,我编写了特殊的 Dao 层类,我想了解我应该在哪里存储我的 SQL 查询?
@Override
public boolean checkIsUserExists(String login)
try
PreparedStatement preparedStatement =
connection.prepareStatement("select * from clients where login=?");
preparedStatement.setString(1, login);
ResultSet resultSet = preparedStatement.executeQuery();
if (resultSet.next())
return true;
catch (SQLException e)
e.printStackTrace();
return false;
我是否需要创建一个特殊的类 SQLQueries
来将查询存储为最终字符串,或者有更有效的方法吗?
【问题讨论】:
旁注:你应该close()
你的preparedStatement
和resultSet
【参考方案1】:
由于这是一个常量,建议使用这样的常量类:
//cannot be extended
public final class Constants
//private constructor
private Constants()
public static String SQL_FIND_CLIENTS_FOR_LOGIN="select * from clients where login=?;
现在在你的主类中做一个静态导入并使用它:
import static Constants.SQL_FIND_CLIENTS_FOR_LOGIN;
【讨论】:
【参考方案2】:这取决于你想投入多少时间。
如果只是一些查询并且您不想产生太多开销,请使用最终字符串创建一个 java 类并在必要时引用它们。 所以这一行
connection.prepareStatement("select * from clients where login=?");
会变成: connection.prepareStatement(SQLQueries.SELECT_CLIENTS);
当您使用 Java Servlet(已经严重过时)时,我认为这就足够了 :)
如果数据量更大,您还可以使用 liquibase 与 mysqlExpressServer2014 一起更改结构(两者都是免费的)或直接将脚本作为 .sql 类运行。
如果您真的想遇到麻烦或知道自己在做什么,则可以选择使用 Spring/Spring Boot。
【讨论】:
以上是关于在java中存储sql查询的最佳方法是啥的主要内容,如果未能解决你的问题,请参考以下文章
在 sql 查询中使用 not in 时优化此 SQL 语句的最佳方法是啥?
在 SQL Server(查询分析器)中的查询结果中识别隐藏字符的最佳方法是啥?
Zeppelin:使用 SQL 查询数据并使用它的最佳方法是啥?
Spring jdbc模板:将sql语句保留在代码之外的最佳方法是啥