私は1年以上ウェブアプリを構築してきました。PHPやMYSQLなどを学び、最初に構築を開始しました。これは、生のPHPでコーディングされた非常にシンプルな予算作成アプリから、Codeigniterで毎日実行する完全なパーソナルファイナンストラッカーに成長しました。その間に他にもいくつかの小さなWebアプリを作成しました。その結果、このプロジェクトを最初に開始したときよりも1年経験があり、基本的な設計の結果として開発が苦しみ始めていると思います。 1日目に行った決定。
codeigniterで動作するようにコードが書き直されましたが、データベース構造は同じであり、DBスキーマの問題を回避するために必要以上のコードを記述しなければならないと感じています。
私の質問は次のとおりです。
- データベースを効果的に設計する方法を学ぶための良いリソースはありますか?本、コースなど。
- このプロジェクトを始めたとき、私は非常に「コーディングしたとおりに設計」しましたが、おそらくより賢明な方法は、1行のコードを記述する前に、フローとロジックが何であるかを確認できるように、すべてを関数レベルで設計することだと思います。 。このタイプの開発には特定の名前がありますか、それとも単なる標準的な方法ですか?(私はWeb開発の正式なトレーニングを受けていないので、誰もがすでに知っていることに遭遇しているだけかもしれないと感じています)
- ロジックと関数を設計してからデータベースを設計する必要がありますか、それともデータベースから始めてロジックと関数を設計する必要がありますか?