在 java 中存储 sql 查询的最佳方式是什么
What is the best way to store sql queries in java
我正在使用 java servlet 编写一个简单的服务器。为了从数据库中获取数据,我编写了特殊的 Dao 层 class,我想了解应该将 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;
}
我是否需要创建一个特殊的 class SQLQueries
来将查询存储为最终字符串,或者是否有更有效的方法来做到这一点?
这取决于你想投入多少时间。
如果只是一些查询并且您不想产生太多开销,请使用最终字符串创建 java class 并在必要时引用它们。
所以这一行
connection.prepareStatement("select * from clients where login=?");
会变成:
connection.prepareStatement(SQLQueries.SELECT_CLIENTS);
当您使用 Java Servlet(严重过时)时,我认为这就足够了 :)
如果数据量更大,您还可以使用 liquibase 与 MySQLExpressServer2014 一起更改结构(两者都是免费的)或 运行 脚本直接作为 .sql classes。
然后有使用 Spring/Spring 引导的选项,如果你真的想惹麻烦或知道自己在做什么。
因为这是常量,建议使用这样的常量class:
//cannot be extended
public final class Constants {
//private constructor
private Constants(){}
public static String SQL_FIND_CLIENTS_FOR_LOGIN="select * from clients where login=?;
}
现在在你的主 class 中做一个静态导入并使用它:
import static Constants.SQL_FIND_CLIENTS_FOR_LOGIN;
我正在使用 java servlet 编写一个简单的服务器。为了从数据库中获取数据,我编写了特殊的 Dao 层 class,我想了解应该将 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;
}
我是否需要创建一个特殊的 class SQLQueries
来将查询存储为最终字符串,或者是否有更有效的方法来做到这一点?
这取决于你想投入多少时间。
如果只是一些查询并且您不想产生太多开销,请使用最终字符串创建 java class 并在必要时引用它们。 所以这一行
connection.prepareStatement("select * from clients where login=?");
会变成: connection.prepareStatement(SQLQueries.SELECT_CLIENTS);
当您使用 Java Servlet(严重过时)时,我认为这就足够了 :)
如果数据量更大,您还可以使用 liquibase 与 MySQLExpressServer2014 一起更改结构(两者都是免费的)或 运行 脚本直接作为 .sql classes。
然后有使用 Spring/Spring 引导的选项,如果你真的想惹麻烦或知道自己在做什么。
因为这是常量,建议使用这样的常量class:
//cannot be extended
public final class Constants {
//private constructor
private Constants(){}
public static String SQL_FIND_CLIENTS_FOR_LOGIN="select * from clients where login=?;
}
现在在你的主 class 中做一个静态导入并使用它:
import static Constants.SQL_FIND_CLIENTS_FOR_LOGIN;