【问题标题】: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()你的preparedStatementresultSet

标签: java sql jdbc dao


【解决方案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。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2011-02-19
      • 2021-02-09
      • 1970-01-01
      • 2016-09-13
      • 2018-10-07
      • 2013-02-15
      • 2020-04-08
      • 2011-02-28
      相关资源
      最近更新 更多