質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Amazon RDS

Amazon RDSは、米アマゾン社が提供しているRDBMSサービス。クラウド上でのリレーショナルデータベースの構築および運用が可能です。MySQL/PostgreSQL/Oracle/SQL Serverのインストールを容易にすることができます。

DLL

DLL(Dynamic Link Library)とは、他のモジュールからも使用する事が出来る、関数とデータが格納されているモジュールのことです。

Windows Forms

Windows Forms(WinForms)はMicrosoft .NET フレームワークに含まれる視覚的なアプリケーションのプログラミングインターフェイス(API)です。WinFormsは管理されているコードの既存のWindowsのAPIをラップすることで元のMicrosoft Windowsのインターフェイスのエレメントにアクセスすることができます。

Amazon EC2

Amazon EC2は“Amazon Elastic Compute Cloud”の略称です。Amazon Web Services(AWS)の一部であり、仮想化されたWebサーバーのコンピュータリソースをレンタルできるサービスです。

Q&A

解決済

1回答

1482閲覧

Cdbcライブラリを使用したクラスライブラリを呼び出すプロジェクトでWindowsフォームデザイナが開けない

pnbmg0044

総合スコア16

Amazon RDS

Amazon RDSは、米アマゾン社が提供しているRDBMSサービス。クラウド上でのリレーショナルデータベースの構築および運用が可能です。MySQL/PostgreSQL/Oracle/SQL Serverのインストールを容易にすることができます。

DLL

DLL(Dynamic Link Library)とは、他のモジュールからも使用する事が出来る、関数とデータが格納されているモジュールのことです。

Windows Forms

Windows Forms(WinForms)はMicrosoft .NET フレームワークに含まれる視覚的なアプリケーションのプログラミングインターフェイス(API)です。WinFormsは管理されているコードの既存のWindowsのAPIをラップすることで元のMicrosoft Windowsのインターフェイスのエレメントにアクセスすることができます。

Amazon EC2

Amazon EC2は“Amazon Elastic Compute Cloud”の略称です。Amazon Web Services(AWS)の一部であり、仮想化されたWebサーバーのコンピュータリソースをレンタルできるサービスです。

0グッド

0クリップ

投稿2021/04/22 05:30

概要と質問

概要
現在、Cdbcライブラリを使用したクラスライブラリを呼び出すプログラムを作成しています。
しかしながら、Windowsフォームを編集するため、デザイナを開こうとするとエラーが発生し、編集することが出来ません。

質問
解決方法が分かりませんので、解決策やアドバイスがあれば教えて頂きたいです。

イメージ説明

図の説明

メインプロジェクト
WindowsFormデザイナを表示したいプロジェクト
Windowsフォームファイルは、共通フォームライブラリの部品を継承して使用しています

共通フォームライブラリ(DLLファイル)
各プロジェクトのWindowsFormで使用するテキストボックス等の共通部品を定義しているライブラリ
一部、設定情報をDBから取得する必要があり、DB接続ライブラリを使用します

DB接続ライブラリ(DLLファイル)
CDBCクライアントをインストールしており、AWSのCDBC Serviceにアクセスし、DB接続を行うライブラリ
SQL文を受け取り、DBからデータを返す処理などをしています

メインプロジェクトの画面表示までのフロー
①メインプロジェクトのメインフォームをロード
②共通フォームライブラリを呼び出す
③共通フォームライブラリはDB接続ライブラリを呼び出し、SQL文などを実行
④DB接続ライブラリが共通フォームライブラリに対し結果を返す
⑤共通フォームライブラリは結果をもとにラベルやテキストボックスボックス等に当てはめる
⑥共通フォームライブラリがメインプロジェクトに対し、テキストボックス等の共通部品を返す

※データの登録などは、直接メインプロジェクトからDB接続ライブラリを呼び出します。

現在

  • メインプロジェクトをデバッグまたはリリースビルドをしてexeファイル化し、実行すると、DB接続、DBからデータ取得も含め、正常に動作します。
  • VisualStudio上で、メインプロジェクトのWindowsフォームファイルを開こうとすると、

 ServiceModelクライアント構成セクションで、コントラクト’CdbcService.ICdbcService’を参照する既定のエンドポイント要素が見つかりませんでした。
この原因としては、ご使用のアプリケーションの構成ファイルが見付からなかったこと、またはこのコンストラクトに合致するエンドポイント要素がクライアント要素内で見つからなかったことが考えられます。

とのエラーが発生する

補足

  • エラーが発生する処理は、DB接続ライブラリ内のDataAdapter.Fill メソッドです。

以下ソースを示します

c#

1CdbcDataAdapter dataAdpt = new CdbcDataAdapter(); 2dataAdpt.SelectCommand = new CdbcCommand(sql, CdbcConnection); 3DataSet ds = new DataSet(); 4dataAdpt.Fill(ds);

※sql, CdbcConnectionは仮の名称です。

  • CdbcConnectionの状態はOpenになっています。
  • CdbcConnectionのConnectionString, UserId, ApplicationId等は正常に格納されていることを確認しました。
  • メインプロジェクトをデバッグモードで実行またはリリースビルドをしてexeファイル化し、実行する場合、app.configファイルがないとエラーが発生します。

試したこと

  • メインプロジェクトにCDBCクライアントをインストール、app.configファイルにDB接続ライブラリのapp.configファイルのエンドポイント要素をコピーしました。

 → Windowsフォームファイルは開けませんでした

  • 共通フォームライブラリにCDBCクライアントをインストール、app.configファイルにDB接続ライブラリのapp.configファイルのエンドポイント要素をコピーしました。

 → Windowsフォームファイルは開けませんでした

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

フォームデザイナはDB接続等を実行できないので、デザイナから呼ばれる可能性のあるメソッド・イベントで、DesignModeプロパティを判定してDB接続処理を行わないようにする必要があると思います。
(コンストラクタやLoadイベント等)
フォームデザイナを開いた際に実行された場合、DesignMode=Trueに設定されます。

投稿2021/04/22 06:46

編集2021/04/22 06:50
退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

pnbmg0044

2021/04/26 23:45

共通フォームライブラリにて、ControlExtensions.IsDesignMode(this)で、デザインモード判定を行い、trueの時は、DB接続・取得処理を行わないようにしてみました。 結果としては、メインプロジェクトのWindowsフォームファイルを開こうとすると、フリーズしたようになってしまうため、既存ライブラリの原因と考え、引き続き調査を行います。 ご協力ありがとうございました。
退会済みユーザー

退会済みユーザー

2021/04/27 01:03 編集

まだデザインモードで実行するとまずい処理が実行されているのかもしれませんね。 デザイン時デバッグの方法がMS公式に載っているので、紹介しておきます。 チュートリアル: カスタム Windows フォーム コントロールのデザイン時のデバッグ https://docs.microsoft.com/ja-jp/dotnet/desktop/winforms/controls/walkthrough-debugging-custom-windows-forms-controls-at-design-time?view=netframeworkdesktop-4.8
pnbmg0044

2021/04/27 06:13

ご丁寧にありがとうございます。 参考にさせて頂きます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問