- •About the Authors
- •Contents at a Glance
- •Contents
- •Introduction
- •Goal of the Book
- •How to Use this Book
- •Introduction to the .NET Framework
- •Common Language Runtime (CLR)
- •Class Library
- •Assembly
- •Versioning
- •Exceptions
- •Threads
- •Delegates
- •Summary
- •Introduction to C#
- •Variables
- •Initializing Variables
- •Variable Modifiers
- •Variable Data Types
- •Types of Variables
- •Variable Scope
- •Types of Data Type Casting
- •Arrays
- •Strings
- •Initializing Strings
- •Working with Strings
- •Statements and Expressions
- •Types of Statements
- •Expressions
- •Summary
- •Classes
- •Declaring Classes
- •Inheritance
- •Constructors
- •Destructors
- •Methods
- •Declaring a Method
- •Calling a Method
- •Passing Parameters to Methods
- •Method Modifiers
- •Overloading a Method
- •Namespaces
- •Declaring Namespaces
- •Aliases
- •Structs
- •Enumerations
- •Interfaces
- •Writing, Compiling, and Executing
- •Writing a C# Program
- •Compiling a C# Program
- •Executing a C# Program
- •Summary
- •Arrays
- •Single-Dimensional Arrays
- •Multidimensional Arrays
- •Methods in Arrays
- •Collections
- •Creating Collections
- •Working with Collections
- •Indexers
- •Boxing and Unboxing
- •Preprocessor Directives
- •Summary
- •Attributes
- •Declaring Attributes
- •Attribute Class
- •Attribute Parameters
- •Default Attributes
- •Properties
- •Declaring Properties
- •Accessors
- •Types of Properties
- •Summary
- •Introduction to Threads
- •Creating Threads
- •Aborting Threads
- •Joining Threads
- •Suspending Threads
- •Making Threads Sleep
- •Thread States
- •Thread Priorities
- •Synchronization
- •Summary
- •Case Study
- •Project Life Cycle
- •Analyzing Requirements
- •High-Level Design
- •Primary and Foreign Keys
- •Referential Integrity
- •Normalization
- •Designing a Database
- •Low-Level Design
- •Construction
- •Integration and Testing
- •User Acceptance Testing
- •Implementation
- •Operations and Maintenance
- •Summary
- •Creating a New Project
- •Console Application
- •Windows Applications
- •Creating a Windows Application for the Customer Maintenance Project
- •Creating an Interface for Form1
- •Creating an Interface for WorkerForm
- •Creating an Interface for CustomerForm
- •Creating an Interface for ReportsForm
- •Creating an Interface for JobDetailsForm
- •Summary
- •Performing Validations
- •Identifying the Validation Mechanism
- •Using the ErrorProvider Control
- •Handling Exceptions
- •Using the try and catch Statements
- •Using the Debug and Trace Classes
- •Using the Debugging Features of Visual Studio .NET
- •Using the Task List
- •Summary
- •Creating Form1
- •Connecting WorkerForm to the Workers Table
- •Connecting CustomerForm to the tblCustomer Table
- •Connecting the JobDetails Form
- •to the tblJobDetails Table
- •Summary
- •Introduction to the Crystal Reports Designer Tool
- •Creating the Reports Form
- •Creating Crystal Reports
- •Creating the Windows Forms Viewer Control
- •Creating the Monthly Worker Report
- •Summary
- •Introduction to Deploying a Windows Application
- •Deployment Projects Available in Visual Studio .NET
- •Deployment Project Editors
- •Summary
- •Case Study
- •Project Life Cycle
- •Analyzing Requirements
- •High-Level Design
- •Low-Level Design
- •Summary
- •Populating the TreeView Control
- •Displaying Employee Codes in the TreeView Control
- •Event Handling
- •Displaying Employee Details in the ListView Control
- •Summary
- •Case Study
- •Project Life Cycle
- •Analyzing Requirements
- •High-Level Design
- •Low-Level Design
- •Summary
- •Adding the Programming Logic to the Application
- •Adding Code to the Form Load() Method
- •Adding Code to the OK Button
- •Adding Code to the Exit Button
- •Summary
- •The Created Event
- •Adding Code to the Created Event
- •Overview of XML
- •The XmlReader Class
- •The XmlWriter Class
- •Displaying Data in an XML Document
- •Displaying an Error Message in the Event Log
- •Displaying Event Entries from Event Viewer
- •Displaying Data from the Summary.xml Document in a Message Box
- •Summary
- •Airline Profile
- •Role of a Business Manager
- •Role of a Network Administrator
- •Role of a Line-of-Business Executive
- •Project Requirements
- •Creation and Deletion of User Accounts
- •Addition of Flight Details
- •Reservations
- •Cancellations
- •Query of Status
- •Confirmation of Tickets
- •Creation of Reports
- •Launch of Frequent Flier Programs
- •Summarizing the Tasks
- •Project Design
- •Database Design
- •Web Forms Design
- •Enabling Security with the Directory Structure
- •Summary
- •Getting Started with ASP.NET
- •Prerequisites for ASP.NET Applications
- •New Features in ASP.NET
- •Types of ASP.NET Applications
- •Exploring ASP.NET Web Applications
- •Introducing Web Forms
- •Web Form Server Controls
- •Configuring ASP.NET Applications
- •Configuring Security for ASP.NET Applications
- •Deploying ASP.NET Applications
- •Creating a Sample ASP.NET Application
- •Creating a New Project
- •Adding Controls to the Project
- •Coding the Application
- •Summary
- •Creating the Database Schema
- •Creating Database Tables
- •Managing Primary Keys and Relationships
- •Viewing the Database Schema
- •Designing Application Forms
- •Standardizing the Interface of the Application
- •Common Forms in the Application
- •Forms for Network Administrators
- •Forms for Business Managers
- •Forms for Line-of-Business Executives
- •Summary
- •The Default.aspx Form
- •The Logoff.aspx Form
- •The ManageUsers.aspx Form
- •The ManageDatabases.aspx Form
- •The ChangePassword.aspx Form
- •Restricting Access to Web Forms
- •The AddFl.aspx Form
- •The RequestID.aspx Form
- •The Reports.aspx Form
- •The FreqFl.aspx Form
- •Coding the Forms for LOB Executives
- •The CreateRes.aspx Form
- •The CancelRes.aspx Form
- •The QueryStat.aspx Form
- •The ConfirmRes.aspx Form
- •Summary
- •Designing the Form
- •The View New Flights Option
- •The View Ticket Status Option
- •The View Flight Status Option
- •The Confirm Reservation Option
- •Testing the Application
- •Summary
- •Locating Errors in Programs
- •Watch Window
- •Locals Window
- •Call Stack Window
- •Autos Window
- •Command Window
- •Testing the Application
- •Summary
- •Managing the Databases
- •Backing Up the SkyShark Airlines Databases
- •Exporting Data from Databases
- •Examining Database Logs
- •Scheduling Database Maintenance Tasks
- •Managing Internet Information Server
- •Configuring IIS Error Pages
- •Managing Web Server Log Files
- •Summary
- •Authentication Mechanisms
- •Securing a Web Site with IIS and ASP.NET
- •Configuring IIS Authentication
- •Configuring Authentication in ASP.NET
- •Securing SQL Server
- •Summary
- •Deployment Scenarios
- •Deployment Editors
- •Creating a Deployment Project
- •Adding the Output of SkySharkDeploy to the Deployment Project
- •Deploying the Project to a Web Server on Another Computer
- •Summary
- •Organization Profile
- •Project Requirements
- •Querying for Information about All Books
- •Querying for Information about Books Based on Criteria
- •Ordering a Book on the Web Site
- •Project Design
- •Database Design
- •Database Schema
- •Web Forms Design
- •Flowcharts for the Web Forms Modules
- •Summary
- •Introduction to ASP.NET Web Services
- •Web Service Architecture
- •Working of a Web Service
- •Technologies Used in Web Services
- •XML in a Web Service
- •WSDL in a Web Service
- •SOAP in a Web Service
- •UDDI in a Web Service
- •Web Services in the .NET Framework
- •The Default Code Generated for a Web Service
- •Testing the SampleWebService Web Service
- •Summary
- •Creating the SearchAll() Web Method
- •Creating the SrchISBN() Web Method
- •Creating the AcceptDetails() Web Method
- •Creating the GenerateOrder() Web Method
- •Testing the Web Service
- •Securing a Web Service
- •Summary
- •Creating the Web Forms for the Bookers Paradise Web Site
- •Adding Code to the Web Forms
- •Summary
- •Case Study
- •Project Life Cycle
- •Analyzing Requirements
- •High-Level Design
- •Low-Level Design
- •Summary
- •Overview of Mobile Applications
- •The Microsoft Mobile Internet Toolkit
- •Overview of WAP
- •The WAP Architecture
- •Overview of WML
- •The Mobile Web Form
- •The Design of the MobileTimeRetriever Application
- •Creating the Interface for the Mobile Web Forms
- •Adding Code to the MobileTimeRetriever Application
- •Summary
- •Creating the Forms Required for the MobileCallStatus Application
- •Creating the frmLogon Form
- •Creating the frmSelectOption Form
- •Creating the frmPending Form
- •Creating the frmUnattended Form
- •Adding Code to the Submit Button in the frmLogon Form
- •Adding Code to the Query Button in the frmSelectOption Form
- •Adding Code to the Mark checked as complete Button in the frmPending Form
- •Adding Code to the Back Button in the frmPending Form
- •Adding Code to the Accept checked call(s) Button in the frmUnattended Form
- •Adding Code to the Back Button in the frmUnattended Form
- •Summary
- •What Is COM?
- •Windows DNA
- •Microsoft Transaction Server (MTS)
- •.NET Interoperability
- •COM Interoperability
- •Messaging
- •Benefits of Message Queues
- •Limitations
- •Key Messaging Terms
- •Summary
- •Pointers
- •Declaring Pointers
- •Types of Code
- •Implementing Pointers
- •Using Pointers with Managed Code
- •Working with Pointers
- •Compiling Unsafe Code
- •Summary
- •Introduction to the Languages of Visual Studio .NET
- •Visual C# .NET
- •Visual Basic .NET
- •Visual C++ .NET
- •Overview of Visual Basic .NET
- •Abstraction
- •Encapsulation
- •Inheritance
- •Polymorphism
- •Components of Visual Basic .NET
- •Variables
- •Constants
- •Operators
- •Arrays
- •Collections
- •Procedures
- •Arguments
- •Functions
- •Adding Code to the Submit Button
- •Adding Code to the Exit Button
- •Summary
- •Introduction to Visual Studio .NET IDE
- •Menu Bar
- •Toolbars
- •Visual Studio .NET IDE Windows
- •Toolbox
- •The Task List Window
- •Managing Windows
- •Customizing Visual Studio .NET IDE
- •The Options Dialog Box
- •The Customize Dialog Box
- •Summary
- •Index
PROJECT CASE STUDY |
Chapter 7 |
123 |
|
|
|
Create database Customers
The statement to create a table is slightly different from the Select statement. Consider a situation where you want to create a table named Customers with five
columns: cust_no, cust_name, cust_addr, cust_phone, and cust_email. To create
the table Customers, you need to use the following SQL statement:
Create table Customers (cust_no char(4), cust_name char(25), cust_addr varchar(50), cust_phone char(12), cust_email char(20))
The first step toward creating a database is to create the design of a database. The following section discusses the fundamentals of a database design.
Primary and Foreign Keys
To access data stored in a table, you need a way to identify each row stored in the table. For example, consider that George Thomas has changed his e-mail address to georget@aol.com and you need to update the same in the Students table. You can execute the following SQL statement to update the information:
Update Students set EmailAddress = ‘georget@aol.com’ where FirstName = ‘George’ and LastName = ‘Thomas’
In this case, the FirstName and LastName columns identify the rows uniquely in the Students table. However, this is not the best way to identify a row because more than one person could have the same combination of the first name and the last name. Therefore, the identifier must uniquely identify all data in the table. In the case of the Students table, you can create another column, StudentID, that will be unique for every row. Such a unique identifier is called a primary key.
Consider the Customers table discussed earlier. It has five columns: cust_no,
cust_name, cust_addr, cust_phone, and cust_email. In this table, cust_no is the best
column to be set as the primary key. This is because this key is unique for each
124 Project 1 CREATING A CUSTOMER MAINTENANCE PROJECT
record and can, therefore, identify each row uniquely. You can make a column a primary key when creating the table in the following manner:
Create table Customers (cust_no char(4) primary key, cust_name char(25),
cust_addr varchar(50), cust_phone char(12), cust_email char(20))
A foreign key is a column or a combination of columns that creates a link between two tables. Adding the primary key column of one table to another table creates a relationship between the tables. This primary key column becomes the foreign key in the other table.
Consider the Orders table with the columns order_no, order_price, order_quan-
tity, and order_date. To process an order, a customer who ordered the goods must be tracked. To do this, you need to add the cust_no column to the Orders table. The cust_no column,which is the primary key in the Customers table, becomes the foreign key in the Orders table. You can create a foreign key at the time of creating the table in the following manner:
Create table Orders
(order_no char(4) primary key, order_price int,
order_quantity int, order_date datetime, cust_no char(4) not null
references Customers (cust_no))
Referential Integrity
You learned that foreign keys are used to establish relationships. However, you may be wondering why you need to establish these relationships. To appreciate the need for creating relationships between tables, consider the following scenario. Table 7-8 displays the records in the Orders table and Table 7-9 displays the records in the Customers table.
|
|
|
PROJECT CASE STUDY |
Chapter 7 |
125 |
||||
Table 7-8 The Orders Table |
|
|
|
|
|
|
|
||
|
|
|
|
|
|
|
|||
|
|
|
|
|
|
||||
cust_no |
cust_name |
cust_addr |
cust_phone cust_email |
|
|||||
|
|
|
|
|
|
|
|||
C001 |
Lee, Lynn & |
#106, Crosswood St., |
901-458-4233 |
lee@lla.com |
|
||||
|
Associates |
Memphis, TN |
|
|
|
|
|
|
|
C023 |
Korex copiers |
#286 Central Avenue, |
901-362-7615 |
webmaster@korex.com |
|
||||
|
|
Memphis, TN |
|
|
|
|
|
|
|
C035 |
Sellmart |
#2136 S White Station |
901-497-5256 |
liz@sellmart.com |
|
||||
|
|
Memphis, TN |
|
|
|
|
|
|
|
C017 |
Plasco & Sons |
#1176 South Central |
901-362-2661 |
bcroft@aol.com |
|
||||
|
|
Avenue, Memphis, TN |
|
|
|
|
|
|
|
C034 |
Plex Cables, Inc. |
#1054 Poplar Avenue, |
901-497-0763 |
sales@plexcables.com |
|
||||
|
|
Memphis, TN |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
||
Table 7-9 The Customers Table |
|
|
|
|
|
|
|
||
|
|
|
|
|
|
|
|||
order_no |
order_price |
order_quantity |
order_date |
cust_no |
|
||||
|
|
|
|
|
|
|
|
|
|
O762 |
625 |
|
2 |
|
1-12-2002 |
C023 |
|
||
O023 |
2175 |
|
4 |
|
3-3-2002 |
C035 |
|
||
O136 |
175 |
|
1 |
|
2-2-2002 |
C001 |
|
||
O174 |
550 |
|
2 |
|
3-22-2002 |
C017 |
|
||
O382 |
1050 |
|
4 |
|
1-22-2002 |
C023 |
|
||
|
|
|
|
|
|
|
|
|
|
Now, if the record for the customer with cust_no C017 is deleted, there will be an order, O174, that will not have a valid cust_no. In order to avoid such a condition, you need to establish relationships. When any two tables are related, you cannot delete a record in one table if there is a related record for it in the other table.This is known as referential integrity.
Referential integrity provides the following benefits. It prevents users from:
Adding records to a related table if there is no associated record in the primary table
126Project 1 CREATING A CUSTOMER MAINTENANCE PROJECT
Changing values in a primary table when there are related records in the related table
Deleting records from a primary table if there are related records in the related table
Normalization
Normalization refers to the process of reducing data redundancy. It usually involves splitting data into two or more tables until repeating groups of data are placed in separate tables. The first step in building a database is to examine the data and then break it down into a row and column format.To appreciate the need for normalization, consider the following example.
Consider Table 7-10, which displays the records in the Product_Orders table.
Table 7-10 The Product_Orders Table
Ord_Id |
Ord_Date |
Ord_Qty |
Ord_Amt |
Prod_Id |
Prod_Name |
Prod_rate |
0014 |
03-13-02 |
3 |
$24 |
P012 |
Soft toys |
$8 |
0045 |
03-10-01 |
2 |
$12 |
P003 |
Candle stand |
$6 |
0033 |
02-17-02 |
4 |
$32 |
P012 |
Soft toys |
$8 |
0021 |
01-25-01 |
1 |
$11 |
P007 |
Pen |
$11 |
|
|
|
|
|
|
|
Consider a situation where you need to reduce the rate of soft toys to $6 because you have a large stock of soft toys.However, in reducing the rate, you had to make changes in two rows. Imagine the effort required to make changes in a table with a large number of records. So, you decided to split this table into two tables, Orders and Products. Whereas the Orders table has the orders that were booked by customers, the Products table has the list of products sold by the company.
This type of problem, where the same information needs to be changed in more than one record, is referred to as an update anomaly.
The order with Ord_Id 0045 was cancelled. So, you decide to delete that record. However, you realized that the details of Candle stand would also be lost. The solution to this problem is to split the table into two, Orders and Products. This type of problem is referred to as a deletion anomaly.