Liquibase不承诺我的更改



我正在使用JTDS驱动程序从Java应用程序运行Liquibase到MSSQL。当我运行更新时,我会看到它们被显示,但实际上没有任何东西被提交到数据库。有什么想法吗?下面的代码在Servlet中运行。

    Connection con = null;
    try {
        Properties props = new Properties();
        props.load(getClass().getResourceAsStream("/datasource.properties"));
        String driver = props.getProperty("database.driver");
        String url = props.getProperty("database.url");
        String username = props.getProperty("database.username");
        String password = props.getProperty("database.password");
        Class.forName(driver);
        con = DriverManager.getConnection(url, username, password);
        Database database = DatabaseFactory.getInstance().findCorrectDatabaseImplementation(new JdbcConnection(con));
        Liquibase liquibase = new Liquibase("db.xml", new ClassLoaderResourceAccessor(), database);
        response.getWriter().print("<PRE>");
        liquibase.update("", response.getWriter());
        con.commit();
    } catch (Exception e) {
        log.error(e.getMessage(), e);
        throw new ServletException(e.getMessage(), e);
    } finally {
        if (con != null) {
            try {
                con.close();
            } catch (SQLException e) {
                log.warn(e.getMessage(), e);
            }
        }
    }
    response.flushBuffer();

使用编写器的update()方法不会执行更改,而是输出要运行的内容。

如果您改为调用likibase.update(")或likibase.update(null),它将执行更改。

相关内容

  • 没有找到相关文章

最新更新