EclipseからMySQL接続
環境
手順
パースペクティブ「データベース開発」を開く
データベース接続ビューから以下の接続設定を作成。
ドライバーの定義
プロパティー
プロパティー | 値 |
---|---|
データベース | LOCAL_MySQL8.0 |
URL | jdbc:mysql://localhost:3306?characterEncoding=UTF-8&serverTimezone=JST |
ユーザー名 | root |
パスワード | ●●● |
引っかかった点
URLをjdbc:mysql://localhost:3306にして接続しようとしたところ以下のエラーが発生。
新規 汎用 JDBC への SQL モデル接続 接続の作成中にエラーが発生しました。(エラー: The server time zone value ' (W)' is unrecognized or represents more than one time zone. You must configure either the server or JDBC driver (via the serverTimezone configuration property) to use a more specifc time zone value if you want to utilize time zone support.)
試したこと
my.cnfにデフォルトタイムゾーンを追加
[mysqld] default-time-zone = +9:00
⇒変化なし
タイムゾーンテーブルにレコード追加
>mysql -u root mysql -p < C:\tmp\timezone_posix.sql
⇒変化なし
URLにタイムゾーン設定を追加
⇒接続成功!
課題
参考サイト
HamcrestでSecurityException
環境
現象
JUnit 4ライブラリーに加えてhamcrest-library-1.3.jarをビルドパスに加えて1org.hamcrest.Matchersを使おうとしたところ、以下の例外が発生した。
java.lang.SecurityException: class "org.hamcrest.Matchers"'s signer information does not match signer information of other classes in the same package at java.base/java.lang.ClassLoader.checkCerts(Unknown Source) at java.base/java.lang.ClassLoader.preDefineClass(Unknown Source) at java.base/java.lang.ClassLoader.defineClass(Unknown Source) at java.base/java.security.SecureClassLoader.defineClass(Unknown Source) at java.base/jdk.internal.loader.BuiltinClassLoader.defineClass(Unknown Source) at java.base/jdk.internal.loader.BuiltinClassLoader.findClassOnClassPathOrNull(Unknown Source) at java.base/jdk.internal.loader.BuiltinClassLoader.loadClassOrNull(Unknown Source) at java.base/jdk.internal.loader.BuiltinClassLoader.loadClass(Unknown Source) at java.base/jdk.internal.loader.ClassLoaders$AppClassLoader.loadClass(Unknown Source) at java.base/java.lang.ClassLoader.loadClass(Unknown Source) at kurukuruz.test.UnitTest.test(UnitTest.java:12) at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) at java.base/java.lang.reflect.Method.invoke(Unknown Source) at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50) at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12) at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47) at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17) at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325) at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:78) at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:57) at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290) at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71) at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288) at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58) at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268) at org.junit.runners.ParentRunner.run(ParentRunner.java:363) at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:86) at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38) at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:538) at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:760) at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:460) at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:206)
Google翻訳
クラス "org.hamcrest.Matchers"の署名者情報が、同じパッケージ内の他のクラスの署名者情報と一致しません
原因
- JUnit 4ライブラリーのorg.hamcrest.core_1.3.0v~.jar
- hamcrest-library-1.3.jar
の間で署名者情報が一致しないことが原因らしい。
対策
hamcrest-core-1.3.jarをダウンロードしてビルドパスに追加し、順序をJUnitライブラリーより上にする。
hamcrest-library-1.3.jarの順序はどこでもOK。
その他
ダメだった方法
参考サイトでorg.hamcrest.core_1.3.0v~.jarの名前を変えて無効化するというような意見もあったが、JUnitライブラリーがビルドエラーを起こしたので却下した。
Mavenを使っている場合
hamcrest-libraryをpom.xmlに追加し2、Maven依存関係の順序をJUnitライブラリーより上にする。
⇒SecurityException発生……。
JUnitライブラリーをビルドパスから除去して、JUnitもpom.xmlに追加する。
⇒成功!