2017-08-14 14 views
2

ResultSetから文字列値を取得しようとしたときに例外が発生しました。これは、2つの新しい列image_urlとicon_urlをテーブルに追加し(デフォルトのnull)、新しい追加された列を取得しようとした後に発生します。 テーブルのステートメントを作成するには、以下である:Resultset getString throw ArrayIndexOutOfBoundsException

CREATE TABLE `examples` (
`id` int(11) NOT NULL AUTO_INCREMENT, 
`name` varchar(255) COLLATE utf8_unicode_ci DEFAULT NULL, 
`description` text COLLATE utf8_unicode_ci, 
`event_id` int(11) DEFAULT NULL, 
`created_at` datetime NOT NULL, 
`updated_at` datetime NOT NULL, 
`session_id` varchar(255) COLLATE utf8_unicode_ci DEFAULT NULL, 
`location` varchar(255) COLLATE utf8_unicode_ci DEFAULT NULL, 
`start_date` datetime DEFAULT NULL, 
`end_date` datetime DEFAULT NULL, 
`url` varchar(255) COLLATE utf8_unicode_ci DEFAULT NULL, 
`button_label` varchar(255) COLLATE utf8_unicode_ci DEFAULT NULL, 
`hidden` tinyint(1) DEFAULT NULL, 
`image_url` varchar(255) COLLATE utf8_unicode_ci DEFAULT NULL, 
`icon_url` varchar(255) COLLATE utf8_unicode_ci DEFAULT NULL, 
PRIMARY KEY (`id`) 
) ENGINE=InnoDB AUTO_INCREMENT=427 DEFAULT CHARSET=utf8 
COLLATE=utf8_unicode_ci; 

クエリは例からちょうどクエリのすべてのフィールドオブジェクトを、非常に単純です:

@Override 
public List<Example> getExamples(Integer eventId) { 
    return jdbcTemplate.query(
      "SELECT * FROM examples WHERE event_id= ?", 
      new Object[]{eventId}, 
      (rs, rowNum) -> { 
       Example ex = new Example(); 
       ex.setId(rs.getInt("id")); 
       ex.setName(rs.getString("name")); 
       ex.setDescription(rs.getString("description")); 
       ex.setExpoId(rs.getInt("expo_id")); 
       ex.setSessionId(rs.getString("session_id")); 
       ex.setLocation(rs.getString("location")); 
       ex.setStartDate(rs.getString("start_date")); 
       ex.setEndDate(rs.getString("end_date")); 
       ex.setUrl(rs.getString("url")); 
       ex.setButtonLabel(rs.getString("button_label")); 
       ex.setHidden(rs.getBoolean("hidden")); 
       ex.setImageUrl(rs.getString("image_url")); //throw ArrayIndexOutOfBoundsException 
       ex.setIconUrl(rs.getString("icon_url")); // throw ArrayIndexOutOfBoundsException 
      }); 
} 

私は空の文字列にすべてのIMAGE_URLとicon_urlを更新した場合、例外が消えますnull値の代わりに

私はDatasouceをconfigおよび管理するためのHikariCPを使用しています:

@Bean(name = "dataSouce") 
    public DataSource dataSouce() { 
    HikariConfig config = new HikariConfig(); 
    config.setJdbcUrl(env.getProperty("ds.url")); 
    config.setUsername(env.getProperty("ds.username")); 
    config.setPassword(env.getProperty("ds.password")); 
    config.setDriverClassName(env.getProperty("ds.driver.classname")); 
    config.addDataSourceProperty("cachePrepStmts", "true"); 
    config.addDataSourceProperty("prepStmtCacheSize", "250"); 
    config.addDataSourceProperty("useServerPrepStmts", "true"); 
    config.addDataSourceProperty("useLocalSessionState", "true"); 
    config.addDataSourceProperty("useLocalTransactionState", "true"); 
    config.addDataSourceProperty("rewriteBatchedStatements", "true"); 
    config.addDataSourceProperty("cacheResultSetMetadata", "false"); 
    config.addDataSourceProperty("cacheServerConfiguration", "true"); 
    config.addDataSourceProperty("elideSetAutoCommits", "true"); 
    config.addDataSourceProperty("maintainTimeStats", "false"); 
    return new HikariDataSource(config); 
} 

私は時間のためにこれをデバッグしてきたが、それならばそうHikariCPにかなり新しいも何が起こっているのか見つけるの運、わかりませんクエリ結果をキャッシュするには何らかの影響があります。完全な例外トレースは以下の通りです:

2017-08-14 12:09:53.020 [http-apr-8080-exec-2] WARN example.MvcLogger - Handler execution resulted in exception 
java.lang.ArrayIndexOutOfBoundsException: 939 
at com.mysql.cj.mysqla.io.Buffer.readInteger(Buffer.java:284) 
at com.mysql.cj.mysqla.result.BinaryBufferRow.getValue(BinaryBufferRow.java:231) 
at com.mysql.cj.jdbc.result.ResultSetImpl.getString(ResultSetImpl.java:880) 
at com.mysql.cj.jdbc.result.ResultSetImpl.getString(ResultSetImpl.java:892) 
at com.zaxxer.hikari.pool.HikariProxyResultSet.getString(HikariProxyResultSet.java) 
at com.playstation.sony.otg.service.impl.EventsServiceImpl.lambda$getExamples$2(EventsServiceImpl.java:162) 
at org.springframework.jdbc.core.RowMapperResultSetExtractor.extractData(RowMapperResultSetExtractor.java:93) 
at org.springframework.jdbc.core.RowMapperResultSetExtractor.extractData(RowMapperResultSetExtractor.java:60) 
at org.springframework.jdbc.core.JdbcTemplate$1.doInPreparedStatement(JdbcTemplate.java:708) 
at org.springframework.jdbc.core.JdbcTemplate.execute(JdbcTemplate.java:644) 
at org.springframework.jdbc.core.JdbcTemplate.query(JdbcTemplate.java:695) 
at org.springframework.jdbc.core.JdbcTemplate.query(JdbcTemplate.java:727) 
at org.springframework.jdbc.core.JdbcTemplate.query(JdbcTemplate.java:737) 
at org.springframework.jdbc.core.JdbcTemplate.query(JdbcTemplate.java:787) 
at com.playstation.sony.otg.service.impl.EventsServiceImpl.getExamples(EventsServiceImpl.java:158) 
at com.playstation.sony.otg.controller.AdminController.eventIdExamplesGet(AdminController.java:48) 
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) 
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
at java.lang.reflect.Method.invoke(Method.java:498) 
at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:221) 
at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:137) 
at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:110) 
at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:775) 
at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:705) 
at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:85) 
at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:959) 
at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:893) 
at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:967) 
at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:858) 
at javax.servlet.http.HttpServlet.service(HttpServlet.java:624) 
at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:843) 
at javax.servlet.http.HttpServlet.service(HttpServlet.java:731) 
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:303) 
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) 
at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52) 
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241) 
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) 
at com.playstation.sony.otg.logging.logging.LoggerFilter.doFilter(LoggerFilter.java:46) 
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241) 
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) 
at com.playstation.sony.otg.config.SimpleCORSFilter.doFilter(SimpleCORSFilter.java:22) 
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241) 
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) 
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:220) 
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:122) 
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:505) 
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:169) 
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:103) 
at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:956) 
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:116) 
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:436) 
at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1078) 
at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:625) 
at org.apache.tomcat.util.net.AprEndpoint$SocketProcessor.doRun(AprEndpoint.java:2517) 
at org.apache.tomcat.util.net.AprEndpoint$SocketProcessor.run(AprEndpoint.java:2506) 
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) 
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) 
at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) 
at java.lang.Thread.run(Thread.java:745) 

は、それは私が年間の休暇業界をしたので、私が作ったと戻って、任意のヘルプは感謝いくつかの非常にダム間違いかもしれません!

+0

MySqlのバージョンは何ですか? – user7294900

答えて

2

コメント

Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 10 
    at com.mysql.cj.mysqla.io.Buffer.readInteger(Buffer.java:284) 
    at com.mysql.cj.mysqla.result.BinaryBufferRow.getValue(BinaryBufferRow.java:227) 

を閉じたのと同じ例外を除いてMySQL Connector/J 6.0.5bugあります:

アンは、ArrayIndexOutOfBoundsExceptionがサーバー側 準備されたステートメントを使用したときにスローされるとNULLがあったが、 BLOB、TEXT、または ResultSetのJSONタイプの列

は、これは、サーバー側 準備された文を使用し、ResultSet内のBLOB、TEXT、または JSON型カラムにNULLが存在した場合にスローされたConnector/J 8.0.7

アンは、ArrayIndexOutOfBoundsExceptionで固定しました。 (Bug#25215008、Bug#84084)

+0

ありがとう!私はMysqlコネクタ6.0.6を使用しています。 8.0.7 [リンク](https://mvnrepository.com/artifact/mysql/mysql-connector-java/8.0.7-dmr)に切り替えた後、問題は解決しました。本番環境でそのバージョンを使用するのは安全ですか?または5.1.xにダウングレードする必要がありますか? – Whispererli

+0

5.1.Xはhttps://dev.mysql.com/downloads/connector/j/の最新GAリリースです – user7294900

+0

ありがとうございます! – Whispererli

関連する問題