- •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
552 Project 4 CREATING AN AIRLINE RESERVATION PORTAL
In the preceding chapters, you learned to create the SkyShark Airlines Web application and test it. After an application is successfully created, a network administrator needs to perform regular maintenance tasks to ensure that the
application operates optimally.
Two common tasks that need to be performed by network administrators to ensure that the application operates optimally are database management and Web server management. In this chapter, I explain how these tasks are performed. You need to perform these tasks regularly to ensure that the SkyShark Airlines is operational at all times.
Managing the Databases
Database management tasks are performed using SQL Server Enterprise Manager. The database management tasks that a network administrator needs to perform for the SkyShark Airlines application are summarized in the following list:
Manage user accounts
Move data from the dtReservations and dtPassengerDetails tables
Back up the SkyShark database
Export data from the dtDepartedFlights and dtCancellations tables
Review database logs on a timely basis
Schedule database maintenance tasks
In the list of preceding tasks, the SkyShark Airlines application can be used to perform the first two tasks. However, SQL Ser ver Enterprise Manager can help you perform the remaining tasks easily. Therefore, in this section, you will learn to use Enterprise Manager to perform database administration tasks.
ADMINISTERING THE APPLICATION |
Chapter 24 |
553 |
|
|
|
|
|
Backing Up the SkyShark Airlines Databases
To back up the SkyShark Airlines database, you first need to launch Enterprise Manager. To launch Enterprise Manager in SQL Server 2000, perform the steps given as follows:
1.Click on the Start menu. The Start menu will appear.
2.On the Start menu, point to Programs and then point to Microsoft SQL Server.
3.From the Microsoft SQL Server submenu, select Enterprise Manager. The SQL Server Enterprise Manager window will open.
After you open the SQL Server Enterprise Manager window, navigate to the SkyShark database by performing the following steps:
1.Under Console Root, double-click on Microsoft SQL Servers. The list of SQL Server groups registered on the SQL Server will appear.
2.Click on the + (plus) sign next to the SQL Server groups and then click on the + sign next to the server on which you had created the database.
3.Next, click on the + sign next to the Databases folder. The SkyShark Airlines database will appear in the list of databases, as shown in Figure 24-1.
FIGURE 24-1 Path to the SkyShark database
554 Project 4 CREATING AN AIRLINE RESERVATION PORTAL
After you navigate to the database, follow these steps to make a backup of the database:
1.Right-click on the name of the database and point to All Tasks.
2.From the All Tasks submenu, select Backup Database. The SQL Ser ver Backup - SkyShark dialog box will appear, which is shown in Figure 24-2.
FIGURE 24-2 Backing up a database
3.Before you can back up a database, you need to specify a device to which you want to back up. For example, you can back up a database to a Tape drive or a location on your computer. To specify a new backup device, click on Add. The Select Backup Destination dialog box will appear.
4.In the Select Backup Destination dialog box, you can either specify a backup device or specify the name of the file to which you want to backup the database. To back up the database in a directory, specify the location and name of the file as C:\Program Files\Microsoft SQL Server\MSSQL\BACKUP\SkyShark_Backup in the File name text box.
ADMINISTERING THE APPLICATION |
Chapter 24 |
555 |
|
|
|
|
|
TIP
The default location of the backup folder is C:\Program Files\Microsoft SQL Server \MSSQL\BACKUP\.
5.Click on OK to close the Select Backup Destination dialog box. The file name that you specified in Step 5 will appear in the Backup to list.
6.Click on the Options tab of the SQL Server Backup - SkyShark dialog box.
7.On the Options tab, check the Verify backup upon completion option.
8.Click on OK. The SQL Ser ver Backup - SkyShark dialog box will close, and SQL Ser ver will start backing up your database.
SQL Server will display the Backup Progress dialog box when the backup is in progress. Upon successfully completing the backup, it will display a dialog box to indicate that the backup was completed successfully.
Instead of backing up your databases manually each time, you can also create a schedule to back up databases on a regular basis. I will discuss the procedure to periodically back up databases in the “Scheduling Database Maintenance Tasks” section of this chapter.
Exporting Data from Databases
The dtDepartedFlights and dtPassengerDetails tables are used for storing data pertaining to flights that have departed and the names of passengers on these flights respectively. Data in these tables will tend to become redundant over time. For example, you might not need to maintain a list of passengers who have flown a particular flight that departed a month ago. Therefore, you can archive this data into another data store and delete it from the database.
To move data from one database to another, you can use the SQL Server DTS (Data Transformation Services) tasks. To use a DTS task for exporting data from the dtDepartedFlights table, follow these steps:
1.Double-click on SkyShark in SQL Server Enterprise Manager to view a list of objects in the database.
556Project 4 CREATING AN AIRLINE RESERVATION PORTAL
2.Under SkyShark, right-click on Tables and point the mouse over All Tasks. From the All Tasks submenu, select Export Data.The DTS Import/Export Wizard will be launched.
3.On the Welcome screen of the DTS Import/Export Wizard, click on Next.The Choose a Data Source screen of the wizard will appear. Notice that the name of the SkyShark database is already selected in the Database list.
4.Click on Next. The Choose a destination screen of the wizard will appear. This screen is shown in Figure 24-3.
FIGURE 24-3 The Choose a destination screen of the DTS Import/Export Wizard
5.Select the database to which you want to back up data. For example, I have selected the SkyShark_Archive database. Click on Next to continue. The Select Table Copy or Query screen will appear.
6.On the Select Table Copy or Query screen, retain the default option to copy a table and click on Next. The Select Source Tables and Views screen will appear as shown in Figure 24-4.