为了账号安全,请及时绑定邮箱和手机立即绑定

在 java 中存储 sql 查询的最佳方法是什么

在 java 中存储 sql 查询的最佳方法是什么

慕田峪7331174 2023-01-05 10:19:57
我正在使用 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将查询存储为最终字符串,或者是否有更有效的方法来做到这一点?
查看完整描述

2 回答

?
一只甜甜圈

TA贡献1836条经验 获得超5个赞

由于这是一个常量,建议使用这样的 Constants 类:


//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;


查看完整回答
反对 回复 2023-01-05
?
拉莫斯之舞

TA贡献1820条经验 获得超10个赞

这取决于你想投入多少时间。

如果它只是一些查询并且您不想产生太多开销,请使用最终字符串创建一个 java 类并在必要时引用它们。所以这条线

connection.prepareStatement("select * from clients where login=?");

会变成:connection.prepareStatement(SQLQueries.SELECT_CLIENTS);

当您使用 Java Servlet(已经严重过时)时,我认为这就足够了 :)

如果数据量更大,您还可以使用 liquibase 与 MySQLExpressServer2014(两者都是免费的)一起更改结构,或者直接将脚本作为 .sql 类运行。

然后可以选择使用 Spring/Spring Boot,如果你真的想惹麻烦或知道自己在做什么。


查看完整回答
反对 回复 2023-01-05
  • 2 回答
  • 0 关注
  • 109 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信