如何在Java中运行.sql脚本(从文件)并使用Spring返回ResultSet?

Ale*_*sel 4 java sql spring jdbc

如何在Java中运行.sql脚本(来自文件)并ResultSet使用Spring 返回?

我有一个程序SQL在数据库上运行查询,返回后ResultSet我处理并使用我的类中的数据.我目前正在使用JDBCJava程序中的脚本.

StringBuilder query = new StringBuilder("some script on multiple lines");
PreparedStatement statement = connection.prepareStatement(query.toString());
ResultSet resultSet = statement.executeQuery();
Run Code Online (Sandbox Code Playgroud)

我想将Java程序之外的SQL查询移动到.sql文件,但我想保留executeQuery语句中的所有程序逻辑.这意味着我希望查询返回ResultSet.

我查看了几个方法,比如使用a ScriptRunner,使用Spring JdbcTestUtils.executeSqlScript或使用a 读取.sql文件BufferReader,然后将字符串传递给我的语句.在ScriptRunner和Spring JdbcTestUtils.executeSqlScript似乎不返回ResultSet,或者我找不到正确执行.我想要远离该BufferReader方法,因为它需要文本解析和许多异常来处理.

ScriptRunner scriptRunner = new ScriptRunner(connection, true, true);
scriptRunner.runScript(new FileReader("script.sql"));
Run Code Online (Sandbox Code Playgroud)

runScript方法返回void.Spring实现方式相同:

MysqlDataSource ds = new MysqlDataSource();
ds.setServerName("host");
ds.setUser("user");
ds.setPassword("password");

JdbcTemplate jdbcTemplate = new JdbcTemplate(ds);

Resource resource = new ClassPathResource("script.sql");
JdbcTestUtils.executeSqlScript(jdbcTemplate, resource, true);
Run Code Online (Sandbox Code Playgroud)

我仔细查看了Springapi,但找不到类似于我想要的东西.有没有办法从文件加载脚本然后运行它所以它返回一个ResultSet使用Spring?我更喜欢使用,Spring因为它是积极的.

Ale*_*sel 6

我找到了一种使用Spring的方法:

MysqlDataSource ds = new MysqlDataSource();
ds.setServerName("host");
ds.setUser("user");
ds.setPassword("password");

JdbcTemplate jdbcTemplate = new JdbcTemplate(ds);

BufferedReader in = new BufferedReader(new FileReader("script.sql"));
LineNumberReader fileReader = new LineNumberReader(in);
String query = JdbcTestUtils.readScript(fileReader);
Run Code Online (Sandbox Code Playgroud)

现在我们将使用jdbcTemplate.query我们读取的.sql脚本来查询数据库.该ResultSet要求将作为参数传递给传递extractDataResultSetExtractor实施或对mapRow中的RowMapper执行情况.因此,处理ResultSet将在extractDatamapRow实现中完成,我们将返回我们需要的Collection/Object

List<YourClass> result = jdbcTemplate.query(query, new RowMapper<YourClass>() {
            @Override
            public YourClass mapRow(ResultSet rs, int i) throws SQLException {
                // processing of the ResultSet
                return result;
            }
        });
Run Code Online (Sandbox Code Playgroud)

要么

YourClass object = jdbcTemplate.query(query, new ResultSetExtractor<YourClass>() {
            @Override
            public YourClass extractData(ResultSet rs) throws SQLException, DataAccessException {
                // processing of the ResultSet
                return result;
            }
        });
Run Code Online (Sandbox Code Playgroud)

当然,使用最后一个实现,您可以返回所需的任何对象,甚至是对象的集合.

  • 使用 **JdbcTestUtils** 的问题是你必须将测试 jars 打包到你部署的应用程序中。 (3认同)

Evg*_*rov 0

我会使用属性文件来存储 sql 查询。

例如:

person-save=insert into person values....
person-get-all=select * from person....
Run Code Online (Sandbox Code Playgroud)

这样您就可以从文件中读取语句

在上下文中:

<util:properties id="sqlProps" location="classpath:sqlProps.properties" />
Run Code Online (Sandbox Code Playgroud)

在 DAO 中:

@Autowired
@Qualifier("sqlProps")
private Properties sqlProps;
Run Code Online (Sandbox Code Playgroud)

...

String query = sqlProps.getProperty("person-get-all");
PreparedStatement statement = connection.prepareStatement(query);
ResultSet resultSet = statement.executeQuery();
Run Code Online (Sandbox Code Playgroud)

如果你想执行一个文件中的所有语句,你必须自己实现。只需循环遍历属性并一一执行它们即可。您将需要一些标志来确定它是选择还是更新/删除语句。循环属性:

Enumeration e = props.propertyNames();

    while (e.hasMoreElements()) {
      String key = (String) e.nextElement();
      String query= props.getProperty(key);
    }
Run Code Online (Sandbox Code Playgroud)