基本設計とは?必要性と作り方などをご紹介
基本設計とは情報システムを作る工程の一つで、情報システム全体を機能単位に分割して、それぞれの機能がどういうものか、どういうことができるものか、機能同士がどうつながるのか決めていく作業です。 この記事では、基本的な設計、プロセス、およびその作成方法について簡単に学習します。
2021年05月20日
基本設計とは情報システムを作る工程の一つで、情報システム全体を機能単位に分割して、それぞれの機能がどういうものか、どういうことができるものか、機能同士がどうつながるのか決めていく作業です。 この記事では、基本的な設計、プロセス、およびその作成方法について簡単に学習します。
基本設計とは情報システムを作る工程の一つで、情報システム全体を機能単位に分割して、それぞれの機能がどういうものか、どういうことができるものか、機能同士がどうつながるのか決めていく作業です。基本設計を行うタイミングは、要件定義の後、詳細設計の前になります。
今回記事では、基本設計、とはどういうものかを、プロセス、およびその作成方法について簡単に学習します。
1. 基本設計とは

基本設計とは、製品の基本的な設計。また、製品開発において基本的な設計を策定する工程。構成や仕様、機能などの概要をまとめたものを意味する場合と、中枢や基盤の設計を意味する場合があります。
システム開発の基本設計、情報システムやソフトウェアの受託開発の場合は、要件定義と詳細設計の中間で、対象物の機能や構成などの大枠や基本的な仕様を決める工程を意味します。
顧客が必要としている事項をまとめた要件定義書などを元に、どのようなシステムを開発すればこれを満たすことが出来るかを検討し、機器やソフトウェアの構成、実装すべき機能、画面や帳票など操作や入出力に関する事項、生成・保管されるデータの概要など、システムの基礎的な仕様をまとめます。
成果物として基本設計書などの文書や図版などが一式作成されることが多く、これを元に各部の詳細や実装方式などを策定する詳細設計などを行います。
2. 基本設計の必要性

基本設計にはアイデアと現実の間の架け橋です。 ブループリントは、オペレーターがジョブまたは構造の構造を実行するために必要な手順を知るのに役立ちます。 タスクを実行する前に、基本的な設計を行う必要があります。それは、ほぼプロジェクトの設計、つまりアクションです。
システムを家と比較すると、基本設計は基礎を構築する段階であり、レイアウトを作成します。基礎は確実であり、新しい家は将来しっかりと持続可能な方法で構築できます。
初期の基本設計は、方向性を形成し、詳細な設計手順と実際のアプリケーションのためにタスクと物事を一般化するのに役立ちます。
3. 基本設計に必要な視点とは?
要件定義を経て、基本設計フェーズに入っていきます。ここではどういった視点を持つべきなのでしょうか。
3.1. 要件定義との整合性
基本設計で決めた事柄は、その後の全フェーズに絡んできます。
完成品が要件定義の内容とかけ離れていては本末転倒となってしまうでしょう。
詳細設計に入る前の基本設計で、「要件定義の項目を満たしているか」を注意深くチェックする必要があります。
3.2. 実現可能なシステムとなっているか?
要件定義でヒアリングした内容を設計書に落とし込んでいくのが基本設計フェーズです。
クライアントにとっての「理想」を明確にできても、実際のシステム開発でそれを「現実」にできなくては意味がありません。
クライアントの希望はできる限り盛り込むべきですが、システムとして実現できるかどうかの線引きはしっかりと行うべきでしょう。
仕様書を作成する段階から、この点について意識しておくことが大切です。
3.3. クライアントにとって分かりやすくなっているか?
基本設計はシステム開発の根幹を固めていく作業であるため、クライアント側も気になるところです。
開発工程がかなり進んだ後で「自分たちの希望とかけ離れている」と指摘した場合、修正にはかなりの手間が掛かってしまいます。
開発側だけでなく、顧客側にも大きな損害が出てしまうことでしょう。
基本設計フェーズの段階でも、クライアントと綿密な意思疎通を図っていくことが大切です。
4. 基本設計の主な項目

基本設計は、実際にシステムの仕様を決定する段階です。要件定義で決定したシステムの機能要件や非機能要件、制約条件、外部とのやり取りなどをより具体的な仕様にすることで、実際にプログラム可能な形にします。基本設計は五つの主な項目に分かれています。
4.1. 要件定義
要件定義のフェーズでは、発注元であるクライアントの希望をまとめていきます。
「どういう機能を持った新システムを求めているのか」をヒアリングするため、コミュニケーション能力が大事になってくるのが特徴です。
4.2. 基本設計
要件定義で決まった内容を振り返りつつ、開発するシステムの全体像・概要についてまとめていくフェーズです。
顧客の目で見える部分の工程を設定していくことから、「外部設計」とも呼ばれます。
「プログラムをどのように配置するかを検討する段階」と捉えても良いでしょう。
4.3. 詳細設計
基本設計では、システムをモジュール単位で分割し、各モジュールや使用するデータベースの設計を行います。具体的には、データの入出力、データベース同士のデータの受け渡し、ユーザーによる操作、帳票の出力などです。
また、画面のレイアウト、操作方法、帳票類の書式など、システムの使いやすさやユーザー満足度につながるインターフェース部分の仕様を決めるのも機能設計の役割です。
4.4. プログラム実装・単体テスト
基本設計・詳細設計で生まれた設計書(ドキュメント)をもとに、エンジニアがプログラム作成を行なっていきます。
上の設計フェーズで生産された設計書通りに実装されていくため、設計書の質はとても重要です。
全ての完成を待ってからのテストだと細かい修正に対応できないため、実装と並行して「単体テスト」も適宜行われます。
4.5. 結合テスト
単体テストがクリアできたら、設計書通りにプログラムが組まれているかを検証します。
不備のあった箇所は適宜修正していくことになります。
結合テストの後に「受入テスト」を行い、問題点がなければクライアントに納品して完了です。
5. 基本設計の作り方
5.1. 業務フローの明確化
クライアント(ユーザー)が実際に行う業務内容を想定し、その流れを図で表現していきます。
縦軸に管轄部署・横軸に時間を設け、1つずつ流れに沿って記述していきます。
例えば商品発注システムのフローを説明する場合、「申込情報を取得」→「得た情報を入力」→「内容の確認」→「発注」といった具合です。
業務フローはシンプル・明確であることが望ましいとされています。複雑化しすぎるとクライアントが理解しにくいだけでなく、システムとしての実現も難易度は高くなってしまいます。
5.2. システム構成図を作る
システムの構造がパーツで構成され、それらが互いにどのように関連しているかを説明します。
まず、システムにおける、ハードウェア・ソフトウェア・ネットワークなどの構成図をそれぞれ作成する必要があります。
ソフトウェア構成では使用OSやミドルウェアの詳細等、ハードウェア構成ではルータやスイッチ等を明確に記述していきます。
5.3. 機能一覧表の作成
機能一覧とは、システム化の対象を明確に表す資料です。プロジェクトの初期段階では機能の洗い出しが完璧にはできませんが、全体ボリュームを把握する必要があるので、作成する必要があります。
満たすべき機能要件を一覧化することで、開発担当のエンジニアが作業内容を把握しやすくなります。
見積範囲の明確化や、契約時には開発範囲の明確化にも利用できます。また、機能ごとの進捗管理を行う場合な活用されますどにも。
5.4. 非機能要件もまとめる
クライアントの業務内容に直接は影響しない非機能要件についても、基本設計書でまとめていきます。
そのシステムを継続的に使用することになる側にとっては、セキュリティ面・スピード面なども大切な要素です。
6. 基本設計書の必要なポイント
6.1. ドキュメントは作りすぎない
基本設計によって「基本設計書」が作られますが、ドキュメントを生産し過ぎてしまうことにも注意が必要です。全ての書類がしっかりとメンテナンスされているなら問題ありませんが、誤った情報が含まれていると開発フローに支障を来します。
そのため、求められるのはドキュメントの質であり、量ではありません。どの程度生産するかはクライアントとの折衝で判断していくべきでしょう。
6.2. 図表や数式表現をうまく使う
基本設計書は、顧客・エンジニア問わず多くの関係者が目にすることになるドキュメントです。文章ばかりだと理解に苦労するほか、仕様に誤解が生じてしまうことも考えられます。
開発を担うエンジニアにとっては、テキストよりも数式表現を使ったほうが作業する上でも負担が減るでしょう。
6.3. 設計する側にも技術力は求められる
基本設計書は、後工程のエンジニアが実装を行なう際に欠かせない書類です。なので、技術者がそれを利用するという前提で作成していくことになります。設計側にもある程度の技術力は必要です。上流工程を担うのは主にSEですが、SEも社内研修でIT技術の習得を行なう場合が殆どです。要件定義をメインに行うエンジニアはある意味「コンサル 」といえるものの、エンジニア要素もやはり関係してくることになります。
7. さいごに
基本設計は、情報システムのあるべき姿をベンダの言葉で作り上げてまとめる、とても大事な工程です。基本設計がお客様と合意されれば、お客様はそれが実現されるものと期待しながら、情報システムが出来上がるのを待ちます。基本設計は、お客様とベンダとの間での最後の約束ごとだと言ってもいいでしょう。
基本設計が上手くいくかは、基本設計を行う担当者の実力とスキルと意識の持ち方次第です。方法論はそれを補うものでしかありません。基本設計のレビューを行うチームやプロジェクトやベンダの総合力も問われます。また、基本設計ができる要員がいるかどうかが、情報システム構築の成否を分けるのです。
現在、私たちハチネット企業のエンジニアは、高い技術を持つだけでなく、お客様と日本語で直接にコミュニケーションをとることができます。そのため、書類面やお客様の希望で100%日本語をドキュメントの処理ができます。
私たちハチネットは、常に品質製品と顧客の満足度を重視している。ハチネットのサービスを選択すれば、製品が実装されてから納品されるまで安心できると信じます。
オフショア開発をご検討されている方々はぜひ一度ご相談ください。
※以下通り弊社の連絡先
アカウントマネージャー: クアン(日本語・英語対応可)
電話番号: (+84)2462 900 388
お電話でのご相談/お申し込み等、お気軽にご連絡くださいませ。
- オフショア開発
- エンジニア人材派遣
- ラボ開発
- ソフトウェアテスト
電話番号: (+84)2462 900 388
メール: contact@hachinet.com
お電話でのご相談/お申し込み等、お気軽にご連絡くださいませ。
無料見積もりはこちらから
Tags
ご質問がある場合、またはハチネットに協力する場合
こちらに情報を残してください。折り返しご連絡いたします。
関連記事
Spring MVCの内部構造を分解する──リクエスト処理はどの順で、誰が何をしているのか
Spring MVCを使っていると、Controllerを書くこと自体は難しくありません。しかし、例外処理や独自拡張、想定外の挙動に直面したとき、内部構造を理解していないと原因を追えなくなります。この記事では、Springとは何かを前提知識として最小限に整理し、Spring MVCがHTTPリクエストをどの順序で処理しているのかを、構成要素・処理責務・コードレベルの観点から解説します。
Springを内部構造から理解するための基礎知識と主要アノテーション詳解
Springとは何かを理解する際に重要なのは、「どの処理がSpringに委ねられ、どの処理がアプリケーション側の責務なのか」を切り分けて把握することです。本記事ではSpringを単なる便利なフレームワークとして扱うのではなく、IoCコンテナの内部構造、Bean管理、アノテーションがどのタイミングで解釈されるのかを技術的に掘り下げます。
Spring Bootとは?Springとの違いを「学ぶ順番」で理解すると一気に腑に落ちる
SpringとSpring Bootの違いが分からないという悩みは、知識不足ではなく学び方の問題であることがほとんどです。特に初心者ほど、「どちらから学ぶべきか」を誤ることで、理解が止まります。この記事では、学習者の視点からSpringとSpring Bootの違いを整理し、なぜ混乱が起きるのかを明確にします。
Spring Frameworkは何を楽にしているのか?Core・DI・Containerの関係を5分で腑に落とす
Spring Frameworkを学ぶと、多くの人が「できることの多さ」に圧倒されます。しかし現場でSpringが評価されている理由は、機能の多さではなく、設計の迷いを減らしてくれる点にあります。本記事ではSpringとは何かを表面的に説明するのではなく、Spring Core・DI・Containerがそれぞれ何を決め、何を自動化しているのかを順を追って解説します。
DI(依存性注入)とは何か?Spring開発で「3年後に手が出せなくなるコード」を生まないための設計原則
DI(依存性注入)は「疎結合にするため」「テストしやすくするため」と説明されがちですが、現場ではそれよりも単純な理由で必要になります。それは、時間が経ったコードを安全に直せるかどうかです。本記事では、DIを導入しなかったSpringアプリケーションがどこで詰まり、DIがその地点をどう回避しているのかを、構造と判断基準に絞って解説します。
Springとは何か?なぜSpringは現代Java開発の“背骨”になったのか
Springは「便利だから使われている」のではありません。Springが広く使われるようになった理由は、Javaという言語が大規模化・長期運用・人の入れ替わりという現実に直面したとき、従来の設計では耐えられなくなったからです。本記事では、機能紹介や用語解説に終始せず、SpringがJavaの構造そのものをどう変えたのかを、設計・保守・時間軸という観点から具体的に掘り下げます。
Webサイトは「どこで・どう処理され・何を返す」のか?構造から理解するWeb開発の本質
Webサイトはクリックすれば反応し、情報が表示されるものとして認識されていますが、その動きは自動的に起きているわけではありません。web 開発とは、ユーザーの操作を起点に、どこで処理を行い、どの情報を使い、どの形式で返すかを設計する仕事です。本記事では、サーバー・ドメイン・データベースを軸に、Webが成立する構造を処理レベルで分解し、仕組みそのものを理解できるよう掘り下げていきます。
HTML・CSS・JavaScriptから読み解くWeb開発の基本構造と考え方
Web開発という言葉は広く使われていますが、「結局Web開発とは何をしているのか」を自分の言葉で説明できる人は意外と多くありません。HTML・CSS・JavaScriptを学んでいても、それぞれがどのような思想で分かれており、なぜこの三つがWebの基盤として使われ続けているのかまで理解できていないケースも少なくないのが実情です。本記事では、Web開発を単なる技術の集合としてではなく、「Webが成り立つ構造そのもの」として捉え直し、HTML・CSS・JavaScriptの役割を設計思想の観点から整理していきます。
開発とは何か?Web開発プロセス完全ガイド|企画・設計から運用改善までをわかりやすく解説
インターネットがビジネスや日常生活の基盤となった現在、「開発とは何か」「Web開発はどのような流れで進むのか」を正しく理解することは非常に重要です。しかし、企画や設計、実装といった工程が断片的に語られることは多く、全体像を体系的に把握できていない方も少なくありません。本記事では、ITに詳しくない方でも理解できるように、開発の基本的な考え方からWeb開発プロセスの全体像、そして公開後の運用・改善までを一連の流れとしてわかりやすく解説します。



