[Seasar-user:15681] Re: [DBFlute]ReplaceSchemaがシノニムをDROP TABLEしようとする。
西山 はじめ
[E-MAIL ADDRESS DELETED]
2008年 9月 5日 (金) 21:52:28 JST
お世話になっております。
西山です。
> ちなみに外だしSQLでよければ、
> どこかのテーブルのBehaviorを間借りして、
> 「SQL文の中身」を該当のシノニムのものにすれば
> Sql2EntityでEntityを自動生成して(もしくは自作して)、
> 普通にシノニムにアクセスすることは可能なはずです。
実は、insert、updateもあります。
外だしSQLは、SELECT以外は対応していなかったですよね。
(一応、試みてみましたが「SELECT句が見つかりません」となりま
した)
A.DBFluteのプロジェクトを複数DB対応にする。
B.SYNONYMを利用して、同じDB内でアクセスする。
C.別プロジェクトに切り分ける。
以上の案を検討した結果、SYNONYM対応されているのならば、同じ
DB上で扱えるBがいいのではないかと思った次第です。
C.は、Webで扱う関係上複雑になると思ったので却下しました。
> また、今後こういう機能も検討します。
> https://www.seasar.org/issues/browse/DBFLUTE-322
本当に例外中の例外だと思いますが、あると心強いです。
ご検討のほどよろしくお願いいたします。
AとBはどちらも一長一短だと思いますが、あくまで一ユーザーの感
想としましては、Bです。
理由:FK、PKなどの追加設定は全てdfpropに統一して保存すること
ができる。
設定がばらけると、見逃してしまいやすかったです。
>> エレメント・タイプ "table" のコンテンツが不完全です、
>> " (column+,(foreign-key|index|unique|id-method-parameter)*)"
>> と一致しなければなりません。 project-schema-artap.xml
>> artap/mydbflute/dbflute-0.7.8/schema 行 4
>
> こちら、もしかしたら、
> カラム情報が空っぽのために発生しているかもしれません。
> (カラム情報が一つでもあれば発生しないかも)
確かに空だと発生しませんでした。
本来あり得ない構造だからってことですね。
お手数おかけしました。
お忙しい中ありがとうございました。
[2008/09/05 21:22] kubo さんは書きました。:
> 久保です。
>
>>>> 取り急ぎ、こちらの件だけ対応してました。
>>>> http://dbflute.sandbox.seasar.org/download/dbflute/dbflute-0.8.0.zip
>>>> (SNAPSHOTとなります)
>>>> でSYNONYMはDropできます。
>>> でよろしくお願いします。
>> 確認できました。ありがとうございます。
>
> ご報告ありがとうございます!
>
>> Oracle 9iは9iでも、パッチが全くあたっていないバージョン (9.2.0.1)を使用せざるを得ない状態です。(今年度後半にはサー
>> バー入れ替えがある予定なので、その時にOracleバージョンアップ も提案する予定です)
>>
>> 少し急ぎで実装する必要がある所なので、当面はS2JDBCでしのごう と思います。
>
> 了解です。急ぎということで回避お願いします。
>
> ちなみに外だしSQLでよければ、
> どこかのテーブルのBehaviorを間借りして、
> 「SQL文の中身」を該当のシノニムのものにすれば
> Sql2EntityでEntityを自動生成して(もしくは自作して)、
> 普通にシノニムにアクセスすることは可能なはずです。
>
> また、今後こういう機能も検討します。
> https://www.seasar.org/issues/browse/DBFLUTE-322
>
>> エレメント・タイプ "table" のコンテンツが不完全です、
>> " (column+,(foreign-key|index|unique|id-method-parameter)*)"
>> と一致しなければなりません。 project-schema-artap.xml
>> artap/mydbflute/dbflute-0.7.8/schema 行 4
>
> こちら、もしかしたら、
> カラム情報が空っぽのために発生しているかもしれません。
> (カラム情報が一つでもあれば発生しないかも)
>
> 2008/9/5 西山 はじめ <[E-MAIL ADDRESS DELETED]>:
>> お世話になっております。
>> 西山です。
>>
>>> 「Drop Table シノニム」で落ちてしまう件は、
>>>
>>>> 取り急ぎ、こちらの件だけ対応してました。
>>>> http://dbflute.sandbox.seasar.org/download/dbflute/dbflute-0.8.0.zip
>>>> (SNAPSHOTとなります)
>>>> でSYNONYMはDropできます。
>>> でよろしくお願いします。
>> 確認できました。ありがとうございます。
>>
>>> #
>>> # どうしてもクリアしなければならない問題は
>>> # カラム情報が取得できてないところですね。。。
>>> #
>> Oracle 9iは9iでも、パッチが全くあたっていないバージョン (9.2.0.1)を使用せざるを得ない状態です。(今年度後半にはサー
>> バー入れ替えがある予定なので、その時にOracleバージョンアップ も提案する予定です)
>>
>> 少し急ぎで実装する必要がある所なので、当面はS2JDBCでしのごう と思います。
>>
>>
>> [2008/09/05 20:10] kubo さんは書きました。:
>>> 久保です。
>>>
>>> 西山さん、ありがとうございます。
>>> 情報提供ありがとうございます!
>>>
>>> 「Drop Table シノニム」で落ちてしまう件は、
>>>
>>>> 取り急ぎ、こちらの件だけ対応してました。
>>>> http://dbflute.sandbox.seasar.org/download/dbflute/dbflute-0.8.0.zip
>>>> (SNAPSHOTとなります)
>>>> でSYNONYMはDropできます。
>>> でよろしくお願いします。
>>>
>>>
>>>>> 主キーや外部キーが取得できないと聞いておりましたが、
>>>>> http://d.hatena.ne.jp/jflute/20080822/1219377402
>>>>> 主キーや外部キー意外のカラム情報も全く取得できない
>>>>> 状態でしょうか?
>>>> カラム情報が全く取得できていません。
>>>> project-schema.xmlの、スキーマの中が空です。
>>> そうですか。こちらでは再現ができていないのですが、
>>> Oracleのバージョン違いの問題かもしれませんね・・・
>>>
>>>
>>>> エレメント・タイプ "table" のコンテンツが不完全です、"
>>>> (column+,(foreign-key|index|unique|id-method-parameter)*)" と一致しなければなりません。
>>>> project-schema-artap.xml artap/mydbflute/dbflute-0.7.8/schema
>>>> 行 4
>>>> XML 問題
>>>>
>>>> Pleiadesを使用していますので、日本語化されています。
>>> ありがとうございます。
>>>
>>>
>>>> A.
>>>> ほとんどはテーブルですが、別DBのデータを更新する必要があり、 一部のテーブルだけ、DBリンク+シノニムでアクセスしようと思い ました。
>>>>
>>>> B.
>>>> 混ざります。可能ならば、シノニムと普通のテーブルのFKも張ろう と考えております。
>>>>
>>> 了解しました。ありがとうございます。
>>> additionalPrimaryKeyMapとadditionalForeignKeyMapで
>>> 対応できるかと思います。
>>>
>>> #
>>> # どうしてもクリアしなければならない問題は
>>> # カラム情報が取得できてないところですね。。。
>>> #
>>>
>>> 2008/9/5 西山 はじめ <[E-MAIL ADDRESS DELETED]>:
>>>> お世話になっております。
>>>> 西山です。
>>>>
>>>> インラインで失礼します。
>>>>
>>>>>> シノニムを、「DROP TABLE シノニム名」が実行され処理がそこで
>>>>>> ストップしてしまいます。
>>>>> 具体的に発生する例外を教えて頂けますでしょうか?
>>>> 長いので添付にいたします。
>>>>
>>>>>> 実行環境ではシノニムのカラム情報が取得できていないらしく、
>>>>>> project-schema.xml、
>>>>>> bsentity.Bs~クラスに、カラム情報が全くありませんでした。
>>>>> 主キーや外部キーが取得できないと聞いておりましたが、
>>>>> http://d.hatena.ne.jp/jflute/20080822/1219377402
>>>>> 主キーや外部キー意外のカラム情報も全く取得できない
>>>>> 状態でしょうか?
>>>> カラム情報が全く取得できていません。
>>>> project-schema.xmlの、スキーマの中が空です。
>>>>
>>>>>> あと、些細なことですがproject-schema.xmlに type="SYNONYM"が
>>>>>> あると、DTDと内容が合わなくなり、Eclipse上でエラーとなりました。
>>>>> なるほど、これは想定しませんでした。
>>>>> DTD(どう直せば良いか...)確認します。
>>>>>
>>>> エレメント・タイプ "table" のコンテンツが不完全です、"
>>>> (column+,(foreign-key|index|unique|id-method-parameter)*)" と一致しなければなりません。
>>>> project-schema-artap.xml artap/mydbflute/dbflute-0.7.8/schema
>>>> 行 4
>>>> XML 問題
>>>>
>>>> Pleiadesを使用していますので、日本語化されています。
>>>>
>>>>> また、シノニムの利用ですが、
>>>>> 具体的にどのような用途で利用されているか
>>>>> 参考までに教えてもらってもよろしいでしょうか?
>>>>>
>>>>> A. DBアクセスは全てシノニム経由を想定している?
>>>>> B. テーブルアクセスとシノニムアクセスを混ざる?
>>>>> など
>>>> A.
>>>> ほとんどはテーブルですが、別DBのデータを更新する必要があり、 一部のテーブルだけ、DBリンク+シノニムでアクセスしようと思い ました。
>>>>
>>>> B.
>>>> 混ざります。可能ならば、シノニムと普通のテーブルのFKも張ろう と考えております。
>>>>
>>>>
>>>>> 2008/9/5 西山 はじめ <[E-MAIL ADDRESS DELETED]>:
>>>>>> お世話になっております。
>>>>>> 西山です。
>>>>>>
>>>>>> 申し訳ありません。追加です。
>>>>>> 実行環境ではシノニムのカラム情報が取得できていないらしく、
>>>>>> project-schema.xml、
>>>>>> bsentity.Bs~クラスに、カラム情報が全くありませんでした。
>>>>>>
>>>>>> 以上よろしくお願いいたします。
>>>>>>
>>>>>> あと、些細なことですがproject-schema.xmlに type="SYNONYM"が
>>>>>> あると、DTDと内容が合わなくなり、Eclipse上でエラーとなりました。
>>>>>>
>>>>>> [2008/09/05 15:45] 西山 はじめ さんは書きました。:
>>>>>>> お世話になっております。
>>>>>>> 西山と申します。
>>>>>>>
>>>>>>> databaseInfoMapに
>>>>>>> ; propertiesMap= map:{includeSynonyms=true}
>>>>>>> build.propertiesに
>>>>>>> torque.database.type.list = list:{TABLE;VIEW;SYNONYM}
>>>>>>> を設定して、replace-shema.batを実行したところ、
>>>>>>> シノニムを、「DROP TABLE シノニム名」が実行され処理がそこで
>>>>>>> ストップしてしまいます。
>>>>>>>
>>>>>>> jdbc.bat、generate.batではエラーとなりません。
>>>>>>>
>>>>>>> 仕様バージョン・環境は以下のとおりです。
>>>>>>> DBFlute 0.7.9
>>>>>>> Oracle 9.2.0.1
>>>>>>>
>>>>>>> 以上よろしくお願いいたします。
>>>>>>>
>>>>>> --
>>>>>> ++++++++++++++++++++++++++++++++++++++++++++++++++++++++
>>>>>> 株式会社フジミック システム開発センター ソフト開発2部
>>>>>> 西山 創
>>>>>> [E-mail]:[E-MAIL ADDRESS DELETED]
>>>>>>
>>>>>> 〒140-0002 品川区東品川3-32-42 フジテレビ別館7F
>>>>>> [TEL]:03-5495-1060
>>>>>> ++++++++++++++++++++++++++++++++++++++++++++++++++++++++
>>>>>>
>>>>>> _______________________________________________
>>>>>> Seasar-user mailing list
>>>>>> [E-MAIL ADDRESS DELETED]
>>>>>> https://ml.seasar.org/mailman/listinfo/seasar-user
>>>>>>
>>>>>
>>>> --
>>>> ++++++++++++++++++++++++++++++++++++++++++++++++++++++++
>>>> 株式会社フジミック システム開発センター ソフト開発2部
>>>> 西山 創
>>>> [E-mail]:[E-MAIL ADDRESS DELETED]
>>>>
>>>> 〒140-0002 品川区東品川3-32-42 フジテレビ別館7F
>>>> [TEL]:03-5495-1060
>>>> ++++++++++++++++++++++++++++++++++++++++++++++++++++++++
>>>>
>>>> 2008-09-05 18:57:17,131 [main] INFO
>>>> (DfTableHandler#logDatabaseTypes():141)
>>>> - $ DatabaseTypes are 'TABLE - VIEW - SYNONYM'
>>>> 2008-09-05 18:57:17,381 [main] INFO
>>>> (DfSchemaInitializerJdbc#callbackDropTableByJdbc():236) - drop table
>>>> ATM01
>>>> 2008-09-05 18:57:17,396 [main] ERROR (DfAbstractTask#execute():88) -
>>>> execute() threw the exception!
>>>> java.lang.RuntimeException: java.sql.SQLException: ORA-00942:
>>>> �\�������r���[���������������B
>>>>
>>>> at
>>>>
>>>> org.seasar.dbflute.helper.jdbc.schemainitializer.DfSchemaInitializerJdbc.callbackDropTableByJdbc(DfSchemaInitializerJdbc.java:257)
>>>> at
>>>>
>>>> org.seasar.dbflute.helper.jdbc.schemainitializer.DfSchemaInitializerJdbc.dropTable(DfSchemaInitializerJdbc.java:211)
>>>> at
>>>>
>>>> org.seasar.dbflute.helper.jdbc.schemainitializer.DfSchemaInitializerJdbc.initializeSchema(DfSchemaInitializerJdbc.java:83)
>>>> at
>>>>
>>>> org.seasar.dbflute.task.replaceschema.DfCreateSchemaTask.initializeSchema(DfCreateSchemaTask.java:74)
>>>> at
>>>>
>>>> org.seasar.dbflute.task.replaceschema.DfCreateSchemaTask.doExecute(DfCreateSchemaTask.java:51)
>>>> at
>>>> org.seasar.dbflute.task.bs.DfAbstractTask.execute(DfAbstractTask.java:83)
>>>> at
>>>> org.apache.tools.ant.UnknownElement.execute(UnknownElement.java:288)
>>>> at sun.reflect.GeneratedMethodAccessor5.invoke(Unknown Source)
>>>> at
>>>>
>>>> sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
>>>> at java.lang.reflect.Method.invoke(Method.java:597)
>>>> at
>>>>
>>>> org.apache.tools.ant.dispatch.DispatchUtils.execute(DispatchUtils.java:105)
>>>> at org.apache.tools.ant.Task.perform(Task.java:348)
>>>> at org.apache.tools.ant.Target.execute(Target.java:357)
>>>> at org.apache.tools.ant.Target.performTasks(Target.java:385)
>>>> at
>>>> org.apache.tools.ant.Project.executeSortedTargets(Project.java:1329)
>>>> at org.apache.tools.ant.Project.executeTarget(Project.java:1298)
>>>> at
>>>>
>>>> org.apache.tools.ant.helper.DefaultExecutor.executeTargets(DefaultExecutor.java:41)
>>>> at org.apache.tools.ant.Project.executeTargets(Project.java:1181)
>>>> at org.apache.tools.ant.Main.runBuild(Main.java:698)
>>>> at org.apache.tools.ant.Main.startAnt(Main.java:199)
>>>> at org.apache.tools.ant.launch.Launcher.run(Launcher.java:257)
>>>> at org.apache.tools.ant.launch.Launcher.main(Launcher.java:104)
>>>> Caused by: java.sql.SQLException: ORA-00942:
>>>> �\�������r���[���������������B
>>>>
>>>> at
>>>>
>>>> oracle.jdbc.driver.SQLStateMapping.newSQLException(SQLStateMapping.java:74)
>>>> at
>>>> oracle.jdbc.driver.DatabaseError.newSQLException(DatabaseError.java:110)
>>>> at
>>>>
>>>> oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:171)
>>>> at oracle.jdbc.driver.T4CTTIoer.processError(T4CTTIoer.java:455)
>>>> at oracle.jdbc.driver.T4CTTIoer.processError(T4CTTIoer.java:413)
>>>> at oracle.jdbc.driver.T4C8Oall.receive(T4C8Oall.java:1030)
>>>> at oracle.jdbc.driver.T4CStatement.doOall8(T4CStatement.java:183)
>>>> at
>>>> oracle.jdbc.driver.T4CStatement.executeForRows(T4CStatement.java:936)
>>>> at
>>>>
>>>> oracle.jdbc.driver.OracleStatement.doExecuteWithTimeout(OracleStatement.java:1222)
>>>> at
>>>>
>>>> oracle.jdbc.driver.OracleStatement.executeInternal(OracleStatement.java:1770)
>>>> at
>>>> oracle.jdbc.driver.OracleStatement.execute(OracleStatement.java:1739)
>>>> at
>>>>
>>>> oracle.jdbc.driver.OracleStatementWrapper.execute(OracleStatementWrapper.java:298)
>>>> at
>>>>
>>>> org.seasar.dbflute.helper.jdbc.schemainitializer.DfSchemaInitializerJdbc.callbackDropTableByJdbc(DfSchemaInitializerJdbc.java:238)
>>>> ... 21 more
>>>>
>>>> _______________________________________________
>>>> Seasar-user mailing list
>>>> [E-MAIL ADDRESS DELETED]
>>>> https://ml.seasar.org/mailman/listinfo/seasar-user
>>>>
>>>>
>>>
>>>
>>
>> --
>> ++++++++++++++++++++++++++++++++++++++++++++++++++++++++
>> 株式会社フジミック システム開発センター ソフト開発2部
>> 西山 創
>> [E-mail]:[E-MAIL ADDRESS DELETED]
>>
>> 〒140-0002 品川区東品川3-32-42 フジテレビ別館7F
>> [TEL]:03-5495-1060
>> ++++++++++++++++++++++++++++++++++++++++++++++++++++++++
>>
>> _______________________________________________
>> Seasar-user mailing list
>> [E-MAIL ADDRESS DELETED]
>> https://ml.seasar.org/mailman/listinfo/seasar-user
>>
>
>
>
--
++++++++++++++++++++++++++++++++++++++++++++++++++++++++
株式会社フジミック システム開発センター ソフト開発2部
西山 創
[E-mail]:[E-MAIL ADDRESS DELETED]
〒140-0002 品川区東品川3-32-42 フジテレビ別館7F
[TEL]:03-5495-1060
++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Seasar-user メーリングリストの案内