KEMBAR78
Developing Web-Enabled Decision Support Systems | PDF | Visual Basic .Net | Microsoft Access
0% found this document useful (0 votes)
533 views22 pages

Developing Web-Enabled Decision Support Systems

Extracting knowledge

Uploaded by

npnbkck
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
533 views22 pages

Developing Web-Enabled Decision Support Systems

Extracting knowledge

Uploaded by

npnbkck
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 22

ch00_fm_4770

2/27/07

4:19 PM

Page i

Developing Web-Enabled
Decision Support Systems
Using Access, VB .NET, and ASP .NET

Abhijit A. Pol
Computer and Information Science and Engineering
University of Florida, Gainesville

Ravindra K. Ahuja
Industrial and Systems Engineering
University of Florida, Gainesville
and
Innovative Scheduling, Inc., Gainesville

Dynamic Ideas
Belmont, Massachusetts

ch00_fm_4770

2/27/07

4:19 PM

Page ii

Dynamic Ideas
43 Lantern Road
Belmont, Mass. 02478
U.S.A.
WWW information and orders: http://www.dynamic-ideas.com

Cover Design: Saumya Ahuja

2007 Dynamic Ideas


All rights reserved. No part of this book may be reproduced in any form by any electronic or
mechanical means (including photocopying, recording, or information storage and retrieval)
without permission in writing from the publisher.

Publishers Cataloging-In-Publication Data

ch00_fm_4770

2/27/07

4:19 PM

Page iii

Abhijit dedicates this book to his model-base: his father, Ashok; to his
knowledge-base: his mother, Anagha; and to his data-base: his brother
Amit.
Ravi dedicates this book to his favorite decision support network: Smita,
Saumya, and Shaman.
Together, we dedicate this book to Professor Don Hearn, who inspired
us to write books on decision support systems and remained a constant
source of encouragement throughout their evolution.

ch00_fm_4770

2/27/07

4:19 PM

Page iv

ch00_fm_4770

2/27/07

4:19 PM

Page v

Contents
PREFACE

PART I
CHAPTER 1
1.1
1.2
1.3
1.4
1.5
1.6
1.7

CHAPTER 2
2.1
2.2
2.3
2.4
2.5
2.6
2.7
2.8

CHAPTER 3
3.1
3.2
3.3
3.4
3.5
3.6

Principles of Good Database Design


Introduction

xv

1
3

Introduction
Defining a Decision Support System
Web-enabled Decision Support Systems
Decision Support Systems Applications
Textbook Overview
Summary
Exercises

000
000
000
000
000
000
000

Introduction to Databases

000

Introduction
Data, Information, and Metadata
File-Based Approach
Database Approach
Database Development Process
Database Models
Summary
Exercises

000
000
000
000
000
000
000
000

Entity Relationship Modeling

000

Introduction
The Entity-Relationship Model
Entity
Attributes
Relationships
Degree of a Relationship

000
000
000
000
000
000
v

ch00_fm_4770

vi

2/27/07

4:19 PM

Page vi

Contents

3.7
3.8
3.9
3.10
3.11
3.12
3.13
3.14
3.15
3.16
3.17
3.18
3.19
3.20
3.21
3.22

Cardinality of a Relationship
Unary Relationship
Binary Relationship
Ternary Relationships
Attributes of Relationships
Associative Entities
Weak Entity Types
Enhanced Entity-Relationship Modeling
Superclass, Subclass, and Relationships
Generalization and Specialization Process
Participation and Disjoint Constraints
Superclass/Subclass Hierarchy
Case Study: Conceptual Design for University Database
In-Class Assignment
Summary
Exercises

000
000
000
000
000
000
000
000
000
000
000
000
000
000
000
000

CHAPTER 4

Relational Data Modeling and Normalization

000

4.1
4.2
4.3
4.4
4.5
4.6
4.7
4.8
4.9
4.10
4.11
4.12
4.13
4.14
Part II

Introduction
The Relational Data Model
Relational Keys
Relational Data Integrity Constraints
Transforming E-R Diagrams into Relational Schemas
Case Study: Logical Design for a University Database
Introduction to Normalization
Data Redundancy
Database Anomalies
Functional Dependencies
Forms of Normalization
In-Class Assignment
Summary
Exercises
Database Development with Microsoft Access

000
000
000
000
000
000
000
000
000
000
000
000
000
000
000

Access Introduction: Touring Access

000

Introduction
The Architecture of Microsoft Access
Access Development Environment
Exploring Tables
Relationships
Exploring Queries
Getting Access Help
Summary
Exercises

000
000
000
000
000
000
000
000
000

CHAPTER 5
5.1
5.2
5.3
5.4
5.5
5.6
5.7
5.8
5.9

ch00_fm_4770

2/27/07

4:19 PM

Page vii

Contents

CHAPTER 6
6.1
6.2
6.3
6.4
6.5
6.6
6.7
6.8
6.9
6.10
6.11
6.12

CHAPTER 7
7.1
7.2
7.3
7.4
7.5
7.6
7.7
7.8

CHAPTER 8
8.1
8.2
8.3
8.4
8.5
8.6
8.7
8.8
8.9
8.10
8.11
8.12
8.13
8.14
8.15
8.16

CHAPTER 9
9.1
9.2

vii

Access Tables: Building Data Foundation

000

Introduction
Hands-On Tutorial: Creating Access Tables in the Datasheet View
Hands-On Tutorial: Creating Access Tables in the Design View
Field Data Types
Field Properties
The Lookup Wizard
Defining a Primary Key
Creating Access Tables by Using Import Wizard
Working with Table Properties
In-Class Assignment
Summary
Exercises

000
000
000
000
000
000
000
000
000
000
000
000

Relationships: Linking Access

000

Introduction
Defining Relationships in the Relationships Window
Hands-On Tutorial: Defining Relationships in Access
Working with Existing Relationships
Field Properties
In-Class Assignment
Summary
Exercises

000
000
000
000
000
000
000
000

Queries: Building Application Foundation

000

Introduction
Working with Select Queries
Queries with Multiple Tables (The Join Operation)
Working with Operators
Hands-On Tutorial: A Select Query with Join of Multiple Tables
Using Total Row (The GroupBy Operation)
Creating Calculated Fields
Parameter Queries
Crosstab Queries
Action Queries
Update Queries
Delete Queries
Append Queries
In-Class Assignment
Summary
Exercises

000
000
000
000
000
000
000
000
000
000
000
000
000
000
000
000

SQL: Creating & Processing RDBs

000

Introduction
Types of SQL Statements

000
000

ch00_fm_4770

viii

2/27/07

4:19 PM

Page viii

Contents

9.3
9.4
9.5
9.6
9.7
9.8
9.9
9.10
9.11

Part III
CHAPTER 10
10.1
10.2
10.3
10.4
10.5
10.6
10.7
10.8
10.9

CHAPTER 11
11.1
11.2
11.3
11.4
11.5
11.6
11.7
11.8
11.9
11.10
11.11
11.12
11.13
11.14

CHAPTER 12
12.1
12.2
12.3
12.4
12.5
12.6

The Data Definition Language (DDL)


The Data Manipulation Language (DML)
The SELECT Statement
The INSERT Statement
The DELETE Statement
The UPDATE Statement
Summary
In-Class Assignment
Exercises

000
000
000
000
000
000
000
000
000

Windows Application Development with VB .NET


Introduction to Visual Studio

000
000

Introduction
Exploring Visual Studio IDE
Visual Studio IDE Windows
Object-Naming Conventions
A Look at the VB .NETs Code Window
The Object Browser
In-Class Assignment
Summary
Exercises

000
000
000
000
000
000
000
000
000

Visual Basic .NET Programming Language

000

Introduction
Visual Basic Statements
InputBox and MessageBox
Visual Basic Data Types
Adding Windows Forms and Setting Start-up Form
Control Structures
Arithmetic, Logical, and String Operators
Arrays
Multi-Dimensional Arrays
Dynamic Arrays
Code Debugging
In-Class Assignment
Summary
Exercises

000
000
000
000
000
000
000
000
000
000
000
000
000
000

Objects and Procedures

000

Introduction
Procedures
Subroutine Procedures
Function Procedures
Visual Basic Modules
Visual Basic Classes

000
000
000
000
000
000

ch00_fm_4770

2/27/07

4:19 PM

Page ix

Contents

12.7
12.8
12.9
12.10
12.11

CHAPTER 13
13.1
13.2
13.3
13.4
13.5
13.6
13.7
13.8
13.9
13.10
13.11
13.12
13.13
13.14
13.15
13.16

CHAPTER 14
14.1
14.2
14.3
14.4
14.5
14.6
14.7
14.8
14.9
14.10
14.11
14.12
14.13
14.14
14.15

CHAPTER 15
15.1
15.2
15.3

Navigating Through Application Forms


Exception Handling
In-Class Assignment
Summary
Exercises

ix
000
000
000
000
000

Windows Forms and Controls


Introduction
The Controls
The Label and LinkLabel Controls
The TextBox Control: In Depth
The Button Control
The CheckBox Control
The ListBox Control: In Depth
The ComboBox Control
The CheckedListBox Control
The DateTimePicker Control
The TreeView Control
Arranging Controls on a Form
The Start-up Object
In-Class Assignment
Summary
Exercises

000
000
000
000
000
000
000
000
000
000
000
000
000
000
000
000

Database Connectivity with ADO .NET

000

Introduction
Database Applications Overview
Hands-On Tutorial: Creating a Simple Database Application
Auto-Created Objects in the Component Tray
Hands-On Tutorial: Displaying Data in Individual Windows Controls
Hands-On Tutorial: Binding Data to Existing Controls
Hands-On Tutorial: Displaying Related Data on a Windows Form
DataGridView Control
Hands-On Tutorial: Creating a Search Form
The Query Builder
Hands-On Tutorial: Creating a Look-up Table
Data Binding Properties of a ComboBox Control
In-Class Assignment
Summary
Exercises

000
000
000
000
000
000
000
000
000
000
000
000
000
000
000

Advance Topics in Database Connectivity

000

Introduction
ADO .NET Architecture
A Database Connection

000
000
000

ch00_fm_4770

2/27/07

4:19 PM

Page x

Contents

15.4
15.5
15.6
15.7
15.8
15.9
15.10
15.11
15.12
15.13

CHAPTER 16
16.1
16.2
16.3
16.4
16.5
16.6
16.7
16.8
16.9
16.10
16.11

Part IV
CHAPTER 17
17.1
17.2
17.3
17.4
17.5
17.6
17.7
17.8
17.9
17.10
17.11
17.12
17.13

Hands-On Tutorial: Displaying Data on a Form with Multiple


Parameters
Hands-On Tutorial: Displaying Data on a Form from Join
of Multiple Tables
Hands-On Tutorial: Displaying Data Using Existing MS Access Query
Hands-On Tutorial: Passing Data between Forms in a
Windows Application
DataSets
Inserts, Updates, and Deletes in a Windows Application
Hands-On Tutorial: Updating Changes to Multiple Tables
in the Database
In-Class Assignment
Summary
Exercises

000
000
000
000
000
000
000
000
000
000

Crystal Reports

000

Introduction
Crystal Report Primer: A Simple Student Report
Crystal Report Sections
Customizing Reports: Exploring the Design Environment
Properties of a CrystalReportViewer Control
Hands-On Tutorial: Creating a Pie-Chart to Display Faculty Salaries
Hands-On Tutorial: Creating a Crystal Report Based on Multiple Tables
Hands-On Tutorial: Creating Parameterized Crystal Reports
In Class Assignments
Summary
Exercises

000
000
000
000
000
000
000
000
000
000
000

Web Application Development with ASP .NET


Web Introduction and Essential HTML

000
000

Introduction
Internet, Web, and Related Terminologies
HyperText Markup Language (HTML)
Essential Text Formatting
HTML Hyperlinks
Page Backgrounds
Adding Graphics to Web Pages
Structuring Web Pages Using HTML Tables
Using Visual Studios Design View: WYSIWYG
Web Form and HTML Controls
In Class Assignments
Summary
Exercises

000
000
000
000
000
000
000
000
000
000
000
000
000

ch00_fm_4770

2/27/07

4:19 PM

Page xi

Contents

CHAPTER 18
18.1
18.2
18.3
18.4
18.5
18.6
18.7
18.8
18.9
18.10
18.11
18.12

CHAPTER 19
19.1
19.2
19.3
19.4
19.5
19.6
19.7
19.8
19.9
19.10
19.11
19.12
19.13
19.14
19.15

Part V
CASE STUDY 1
CS1.1
CS1.2
CS1.3
CS1.4
CS1.5
CS1.6
CS1.7

xi

Introduction to ASP .NET

000

Introduction
ASP.NET Primer: Sum of N Numbers
Hands-On Tutorial: Currency Conversion Example
Extending the Currency Conversion Example-The AutoPostBack Property
Using the Page_Load Event and IsPostBack Property
Working with the Page Directive
Validation Controls
Passing Parameters through URL
User-Defined Controls
In Class Assignments
Summary
Exercises

000
000
000
000
000
000
000
000
000
000
000
000

Database Connectivity in Web Applications

000

Introduction
Connecting to the Access Database Using the Server Explorer Window
Hands-On Tutorial: Displaying Data on a Web Page
Reconfiguring SQL Query in an AccessDataSource
Paging, Sorting, and Data Manipulation in a GridView Control
Hands-On Tutorial: Displaying Data on a Web Page from a Query
with a Join of Multiple Tables
Hands-On Tutorial: Displaying Data-Bind Images in a
GridView Control
Hands-On Tutorial: Adding Look-up and Filter Functionalities
to a Web Page
Hands-On Tutorial: Displaying Related Data in a
DetailsView Control
Hands-On Tutorial: Working with the Repeater Control
Web-based Crystal Reports
Programmatically Accessing the Database at Run-Time
In-Class Assignment
Summary
Exercises

000
000
000
000
000

Case Studies
Online Book Store

000
000

Introduction
Application Functionalities and Assumptions
The Master Page
The Index Page
The Shopping Cart Page
The Login Page
The Checkout Page

000
000
000
000
000
000
000

000
000
000
000
000
000
000
000
000

ch00_fm_4770

xii

2/27/07

4:19 PM

Page xii

Contents

CS1.14
CS1.15

CASE STUDY 2
CS2.1
CS2.2
CS2.3
CS2.4
CS2.5
CS2.6
CS2.7
CS2.8
CS2.9
CS2.10
CS2.11

CASE STUDY 3
CS3.1
CS3.2
CS3.3
CS3.4
CS3.5
CS3.6
CS3.7

CASE STUDY 4
CS4.1
CS4.2
CS4.3
CS4.4
CS4.5
CS4.6
CS4.7
CS4.8
CS4.9

CASE STUDY 5
CS5.1
CS5.2
CS5.3
CS5.4
CS5.5
CS5.6
CS5.7

Summary
Extensions

000
000

Portfolio Management and Optimization

000

Introduction
Application Functionalities and Assumptions
The Master Page
The Index Page
The Personal Information Page
The Stock Comparison Page
The Portal Page
Portfolio Operations
The Optimization Page
Summary
Extensions

000
000
000
000
000
000
000
000
000
000
000

Television Advertisement Allocation

000

Introduction
Application Functionalities
The Channel Information and Program Information Page
The Customer Preferences Form
The Advertisement Allocation Page
Summary
Extensions

000
000
000
000
000
000
000

Voyage Prophesy

000

Introduction
Application Functionalities
The Startup Form, User Controls, and MapPoint Reference
The Search Form
The Show Map Form
The DriveIt Form
The Direction Form
Summary
Extensions

000
000
000
000
000
000
000
000
000

ADO .NET and MS Excel

000

Introduction
Forecasting Methods: Background and Theory
Forecasting Methods: Application Functionalities and Assumptions
Setting up the Parameter Input Form and the Excel Sheet
The Code Behind the Parameter Input Form
Dynamic Production Problem (DPP) Application
DPP: Setting up the Parameter Input Form and the Excel Sheet

000
000
000
000
000
000
000

ch00_fm_4770

2/27/07

4:19 PM

Page xiii

Contents

CS5.8
CS5.9
CS5.10

xiii

DPP: The Code Behind the Parameter Input Form


Summary
Application Extensions

000
000
000

REFERENCES

000

ABOUT THE AUTHORS

000

INDEX

000

ch00_fm_4770

2/27/07

4:19 PM

Page xiv

ch00_fm_4770

2/27/07

4:19 PM

Page xv

Preface

OVERVIEW

Motivation

Book Contents

Required Background

Suggestions for Instruction

Website Contents

Acknowledgements

Motivation
Developing Web-Based Decision Support Systems is intended to be a textbook that describes database design and development, illustrates the programming topics (basic as well as advanced) in
Visual Basic .NET and database connectivity, demonstrates web-enabling using ASP .NET, and
applies these techniques to building decision support systems arising in several disciplines. This
book can also be used as a supplementary reference book for courses or as a self-study manual
by practitioners.
Information systems based on decision models are called Decision Support Systems (DSS).
A DSS uses the data residing in databases, models it, processes or analyzes it using problem-specific methodologies, and assists the user in the decision-making process through a graphical
user interface. Industrial Engineering and Operations Research (IE/OR) and business school
xv

ch00_fm_4770

xvi

2/27/07

4:19 PM

Page xvi

Preface

graduates are frequently being employed in positions that require developing DSS. We believe
that decision support systems will gain widespread popularity in the future, and knowing how
to develop such systems will make our students highly desirable in the workplace.
IE/OR departments and business schools teach their students decision models-based
courses that impart spreadsheet modeling, optimization, and simulation skills. Most of these departments require their students to take a computer-programming course, often in C++, Java,
or Visual Basic (VB). Several departments require their students to take a database course as
well. Thus, students acquire background in modeling, optimization, simulation, database, and
programming, but there are no courses that teach students how to integrate the technologies
learned in these different courses to build complete decision support systems. Students are given
many components, but they cannot assemble them into a complete package suitable for use by
a customer. Decision support systems combine these technologies, and teaching how to build
such systems is ideally suited to be an integral part of the IE/OR and business school curriculum.
Developing courses that teach our students how to build decision support systems has been
a demanding task so far, since it requires the availability of platforms that allow the integration
of various technologies (data, models, and programming). However, in the past decade, several
platforms that allow such integration have become available. One such platform is Microsofts
.NET technology.
The Visual Basic .NET (VB .NET) package of the .NET platform can be used in conjunction
with Microsoft Access databases to build Windows-based, single-user database applications. The
Microsoft Access database allows data storage, and VB .NETan easy-to-learn yet powerful object-oriented programming (OOP) languageprovides a mechanism for data analysis, implementing optimization and simulation models, and building graphical user interfaces. Further,
web programming has also become easier with the introduction of Active Server Pages .NET
(ASP .NET). This .NET package makes use of standard HyperText Markup Language or HTML
(the front-end) and VB .NET (the back-end) to deploy elegant and easy-to-build database-connected, web-enabled applications. Another powerful .NET package is Crystal Report .NET. The
Crystal Report package provides an ideal environment for creating reports and charts that can
effectively summarize data. Thus, we have developed a complete set of course material in the Access and .NET framework for a course on Web-Enabled Decision Support Systems. This textbook is a byproduct of this effort. One can alternatively build spreadsheet-based decision
support systems using the Microsoft Excel spreadsheet package, which is the subject of our parallel effort and which led to the companion book, Developing Spreadsheet-Based Decision Support Systems, by Michelle M.H. Seref, Ravindra K. Ahuja, and Wayne L. Winston.
The DSS development skills are important to all IE/OR and business school graduates for
several reasons. First, having these skills will allow them to develop simple tools that might increase their productivity. Second, many graduates will be involved in information systems development during their career, and having a better understanding of the underlying technology
will allow them to play a more useful role in the development process. Third, our graduates can
develop a prototype system using the techniques learned here to establish the system proof-ofconcept before it is turned over to the professional programmers. Fourth, several graduates are
often employed in departments that are service organizations catering to the modeling and optimization needs of other departments such as manufacturing, sales, marketing, accounting, and
purchasing. These departments often request decision tools to be built to meet their business
needs. The users in this department are not modeling experts, and the mathematical complexity of these models becomes an impediment to their use. If our graduates are well versed in the
DSS building process, they can build optimization and simulation models and package these
models within friendly interfaces so that the modeling complexity is hidden from the user. This
will make modeling and optimization approaches more popular in the workplace. Finally, with

ch00_fm_4770

2/27/07

4:19 PM

Page xvii

Preface

xvii

data mining becoming increasingly important, industries are realizing a critical need for persons
who understand data, models, algorithms, and IT, and our graduates can fulfill this need. Our
students possess modeling and algorithmic skills to analyze the data but lack information systems
development skills, and providing them these skills will make them ideally suited for this task.

Book Contents
Building a web-enabled, data-driven decision support system requires four skills: knowledge of
database design, database development, database programming language, and web programming. We also need to illustrate through some practical applications how to build such decision
support systems. Currently, there are no books available on the market that covers all of the five
areas. Our book is intended to meet this need. There are five parts of this text book: learning
database design; getting familiar with database development with Microsoft Access; learning
how to program with VB .NET and build Windows-based database applications; making them
web-enabled with ASP .NET; and learning how to develop DSS applications through several case
studies.

Part IPrinciples of Good Database Design


We start this part of the book with an introduction to decision support systems and an introduction to databases (Chapter 1 and 2). We then cover principles of good database design. The
database design process primarily involves two kinds of data modeling: Object-Based Modeling
and Record-Based Modeling. The entity-relationship (E-R) modelan object-based data
modeldescribes the data in the form of an E-R diagram, entities, attributes, and relationships
and is the subject of Chapter 3. The Relational data modela record-based data modelis
based on the mathematical concept of relations and uses tables (or relations) to represent data
and relationships and is the subject of Chapter 4.

Part IIDatabase Development using MS Access


This part of the book introduces the database development process using the Microsoft Access
package. In Chapter 5, we provide a tour of Accesss development environment. We introduce
the development window, various menus and toolbars, and the architecture of Access and its
main components. In Chapter 6, we give a detailed explanation of Access tables, the central element of relational databases. Access tables store data and provide an effective grid structure for
data organization. We also discuss how to design and modify Access tables in this chapter.
Chapter 7 is dedicated to relationships among Access tables. Once we have populated them
with data, we can query tables to retrieve useful information. We do this through Access queries,
which are the subject of Chapter 8. Chapter 9 introduces SQL, the standard language used to
write database queries. We have also written two comprehensive chapters on Access Forms and
Access Reports, which are available on the book website: www.dssbooks.com.

Part IIIDeveloping Windows Applications using VB .NET


With potential uses of a database application in mind, we present VB .NET as a database programming language in this part of the book. We first introduce, in Chapter 10, the Visual Studio environmentIntegrated Development Environment (IDE)that provides all the tools we

ch00_fm_4770

2/27/07

xviii

4:19 PM

Page xviii

Preface

need to develop a database application. In Chapter 11, we introduce VB .NET along with its programming language constructs: variables, data types, control structures, operators, and arrays.
Chapter 12 presents a discussion of the object-oriented support features of VB .NET, namely,
Classes, Modules, Procedures, Methods, and Properties. In Chapter 13, we formally introduce
Windows forms and controls. Forms and controls constitute the building blocks of a GUI. In
Chapter 14, we discuss database connectivity using ADO .NET. In Chapter 15, we illustrate
more advanced database connectivity topics. Finally, in Chapter 16, we introduce Crystal Reports, a powerful tool that can summarize data in the form of reports and graphs, and discuss
its integration with Windows forms.

Part IVDeveloping Web-based Applications using ASP .NET


The Internet era has taken information-sharing to new heights, allowing billions of users to
share information on the World Wide Web (WWW). This development has created the need for
web-enabled applications that are accessible to a large number of users over a network. Todays
information systems involving databases are pervasive, and a growing number of them are webenabled. In this part of the book, we illustrate the process of developing web applications. We
discuss Hyper Text Markup Language (HTML), a Web interface standard, in Chapter 17. We introduce a Web programming language, ASP .NET, in Chapter 18. We then introduce database
connectivity in Web applications using VB .NET and ADO .NET in Chapter 19 to build a complete Web-enabled DSS.

Part VDeveloping a Complete DSSCase Studies


This part presents five fully developed DSS applications arising in IE/OR, business, and general
engineering. These case studies walk through the complete process of developing a web-enabled
decision support system. Through these case studies, students will learn how IE/OR and business
techniques apply to real-life decision problems and how we can effectively use those techniques
to build DSS applications. Our case studies include Online Book Store, Portfolio Management
and Optimization, Television Advertisement Allocation, Voyage Prophesy, and ADO .NET and
MS Excel. Each case study also lists extensions that students can do as additional projects or
practice assignments. We have developed a few more case studies that are available on the book
website: www.dssbooks.com. The space limitation did not permit us to include these case studies in this printed form of the book.
This book explains all topics through classical examples selected from IE/OR, business
school, data management, and engineering curriculums. Each new concept or idea is illustrated
through examples or hands-on tutorials and reinforced through exercises at the end of the chapter. Each chapter contains an in-class assignment, several review questions, and many hands-on
exercises. We also have created an extensive list and description of student course projects (over
50 such projects), which will further enhance students learning experience. These projects are
available at the book website.

Required Background
The book does not require any prior experience with databases and can be used as an introductory text for novices in database design, development, and implementation. For readers familiar with the design process and the Access environment, this book provides a comprehensive
review of these topics.

ch00_fm_4770

2/27/07

4:19 PM

Page xix

Preface

xix

Prior experience in programming is not mandatory to use this book. We instruct readers on
how to create variables, define functions, use basic programming structures, and work with arrays using Visual Basic language. Readers will also learn how to create good graphical user interfaces in the Visual Studio environment. This material also includes several applications that
may be considered mini DSS applications. Therefore, even for an experienced programmer, it
is useful to review these chapters to strengthen the readers skills in using VB .NET and ASP
.NET in the context of developing a DSS.
We hope that after learning the database background and application development material in Parts IIV of the book, readers will be able to develop any of the case studies found in Part
V. The case studies construct prototypes of data-driven, web-enabled decision support systems
that are simple enough to be understood by undergraduates and complex enough to be reasonably accurate representatives of real-world problems. The case studies require that you have
picked up good database design, development, and programming skills from Parts IIV of the
book.

Suggestions for Instruction


This book is primarily intended as a textbook for undergraduate and graduate students in the
IE/OR and business school curriculums. This book can also be used as a reference book to supplement other textbooks in courses and as a self-study manual. DSS are great tools for consulting, and consultants can use the skills learned profitably in developing their consulting practice.
As a textbook, this book can be used in a variety of ways to teach different courses. It can be
used to offer courses for undergraduate and graduate students. In an undergraduate-level
course, instructors can cover topics at a slower pace. In a graduate-level course, instructors can
spend less time on some topics such as programming basics or HTML, and focus more on case
studies. Instructors can offer semester-long courses (covering all the material), or half-semester/quarter courses on either database design and development or Windows and Web application development.
The Web-enabled DSS course may be taught in different formats including or excluding
several different chapters from our text. We propose that the general structure of the course
begin by teaching database design and development to students to ensure that they are familiar
with the databases; then teach VB .NET programming, database connectivity, and ASP .NET to
show students how to work with Windows and Web-enabled database applications; the course
should then end with a full discussion of decision support systems and instructing students how
to combine their acquired database and programming skills to develop a DSS application. The
text has been designed to follow this general course structure.
From our experience, it seems most productive to hold this course in a computer laboratory
or require students to bring laptops to the class. We recommend that the instructor illustrate
concepts, hands-on examples, or tutorials on the computer screen while students are watching
them and trying to do them themselves on their computers. We suggest that the instructor end
each class by conducting one of the hands-on examples or tutorials as an illustration of all the
concepts taught in that class. We also recommend that there be a teaching assistant available to
help students as they are doing the hands-on examples on their personal computers, while the
instructor may illustrate the example simultaneously at the front of the class. We have found that
students learn much more in this manner as they experiment with Access, VB .NET, and ASP
.NET themselves along with the instructor, with the teaching assistant readily available to answer
questions or address their difficulties.

ch00_fm_4770

xx

2/27/07

4:19 PM

Page xx

Preface

In this suggested setting of a computer laboratory or class with laptops, we also suggest that
the course be taught in two-hour sessions instead of one-hour sessions. This allows students
enough time to set up their computers and instructors enough time to illustrate a full example
during the class. The course material can be adjusted to teach semester long courses or half-semester/quarter courses. The material can be covered in different rigors and at different paces,
and some of the material can be assigned for self-study.
We have discovered by teaching these courses over the years that students learn the most by
doing course projects. Lectures teach them the technology and how to use it, but unless they
apply it themselves to build complete systems, they do not assimilate the material. In addition,
the process of developing a full system from conception to completion and seeing the fruits of
their labor gives them tremendous satisfaction and confidence. Course projects may be done by
teams of students, in which case they promote teamworkan essential skill in any workplace.
We have developed over 50 course projects from different application areas in IE/OR, business,
and engineering curriculums. These projects are available at the book website. Course projects
can be assigned on an individual basis or in groups depending on the course size and course format. Students can select a project from our list, or they can create their own project as long as it
is sufficiently interesting and challenging. We require our students to present these projects before the entire class when completed. Many students have told us that doing these projects and
building complete decision support systems was the most educative experience for them in the
course. We cant recommend them more highly!

Website Contents
We have developed a website for this textbook that contains valuable resources for both students
and instructors. The URL of this website is: www.dssbooks.com
This website contains the following material:

Database files, VB .NET and ASP .NET source code, and application files for all the
Hands-On tutorials covered in all chapters
PowerPoint presentations for all book chapters
Source code and the complete application package including database files for all five
case studies discussed in Part V of the book
Additional case study chapters that could not be included in the book
Database files for Hands-On exercises for required chapters
Additional chapters on Access Forms and Reports that could not be included in the
book
A booklet containing about 50 student projects
Sample course schedules

A Solutions Manual of the book is also available and will be provided to instructors offering courses using this book as the principle textbook. The website provides the email addresses
for requesting the Solution Manual and giving your feedback to the book authors.

ch00_fm_4770

2/27/07

4:19 PM

Page xxi

Preface

xxi

Acknowledgments
There are many people whom we would like to thank for making significant contributions to
this book-writing project. First and foremost, we would like to thank Dr. Donald Hearn, Chair
of the Industrial and Systems Engineering Department at the University of Florida, who has
been the driving force in this book-writing initiative. He motivated us to teach courses that incorporate greater levels of information technology in the IE/OR curriculum at the University of
Florida. He also inspired us to write this book and provided constant encouragement throughout its evolution from a concept to a reality. We are truly thankful to him for his encouragement
and support.
Next, we would like to offer many thanks to Sandra Duni Eksioglu. Sandra received her
doctorate in Industrial and Systems Engineering from the University of Florida and has been
working with us since the inception of the project. She has developed several exercises, their solutions, and team projects for the book. Sandra has taken a lead role in organizing all the team
projects into a booklet and in preparing the solutions manual for the book. Her hard work and
dedication is much appreciated.
Several students of the Industrial and Systems Engineering, Computer Science, and English
Departments at the University of Florida helped us in the development of the book at different
stages. In particular, we would like to thank Margaret Reece and Padmavati Sridhar for the contributions they made in developing several exercises and their solutions for the book; and Krishna Jha, and Burak Eksioglu for developing several team projects. Our special thanks to the
programming junta of Rakesh Desai, Siddharth Gaitonde, Kunal Gandhi, Tapasvi Moturu, and
Mohammad Jaradat for the contributions they made in developing case studies and examples
for the book. Ruben Galbraith assisted us in preparing the PowerPoint presentations for the
book chapters, and we appreciate his help. We extend our sincere thanks to Dean Swinford,
Tamara Johnston, Carolyn Houston, and Krystal Harriot for their copy editing of the text. We
would also like to thank students of the DSS courses offered at the University of Florida who
served as guinea pigs to test early versions of book chapters and gave valuable feedback. We are
indeed indebted for their feedback. Several students who assisted us in the book-writing project
were supported by the National Science Foundation Course Curriculum Development Grant
0341203.
Finally, we thank our families for their constant support and encouragement.
Abhijit A. Pol Ravindra
K. Ahuja@cn1:chapter

ch00_fm_4770

2/27/07

4:19 PM

Page xxii

You might also like