- •Preface
- •Who Should Read This Book
- •Organization and Presentation
- •Contacting the Authors
- •Acknowledgments
- •Contents
- •Introduction
- •Why Microsoft .NET?
- •The Microsoft .NET Architecture
- •Internet Standards
- •The Evolution of ASP
- •The Benefits of ASP.NET
- •What Is .NET?
- •.NET Experiences
- •.NET Clients
- •.NET Services
- •.NET Servers
- •Review
- •Quiz Yourself
- •Installation Requirements
- •Installing ASP.NET and ADO.NET
- •Installing the .NET Framework SDK
- •Testing Your Installation
- •Support for .NET
- •Review
- •Quiz Yourself
- •Designing a Database
- •Normalization of Data
- •Security Considerations
- •Review
- •Quiz Yourself
- •Creating a Database
- •Creating SQL Server Tables
- •Creating a View
- •Creating a Stored Procedure
- •Creating a Trigger
- •Review
- •Quiz Yourself
- •INSERT Statements
- •DELETE Statements
- •UPDATE Statements
- •SELECT Statements
- •Review
- •Quiz Yourself
- •The XML Design Specs
- •The Structure of XML Documents
- •XML Syntax
- •XML and the .NET Framework
- •Review
- •Quiz Yourself
- •ASP.NET Events
- •Page Directives
- •Namespaces
- •Choosing a Language
- •Review
- •Quiz Yourself
- •Introducing HTML Controls
- •Using HTML controls
- •How HTML controls work
- •Intrinsic HTML controls
- •HTML Control Events
- •The Page_OnLoad event
- •Custom event handlers
- •Review
- •Quiz Yourself
- •Intrinsic Controls
- •Using intrinsic controls
- •Handling intrinsic Web control events
- •List Controls
- •Rich Controls
- •Review
- •Quiz Yourself
- •Creating a User Control
- •Adding User Control Properties
- •Writing Custom Control Methods
- •Implementing User Control Events
- •Review
- •Quiz Yourself
- •Common Aspects of Validation Controls
- •Display property
- •Type Property
- •Operator Property
- •Using Validation Controls
- •RequiredFieldValidator
- •RegularExpressionValidator
- •CompareValidator
- •RangeValidator
- •CustomValidator
- •ValidationSummaryx
- •Review
- •Quiz Yourself
- •Maintaining State Out of Process for Scalability
- •No More Cookies but Plenty of Milk!
- •Out of Process State Management
- •Review
- •Quiz Yourself
- •Introducing the Key Security Mechanisms
- •Web.config and Security
- •Special identities
- •Using request types to limit access
- •New Tricks for Forms-based Authentication
- •Using the Passport Authentication Provider
- •Review
- •Quiz Yourself
- •ASP.NET Updates to the ASP Response Model
- •Caching with ASP.NET
- •Page Output Caching
- •Absolute cache expiration
- •Sliding cache expiration
- •Fragment Caching
- •Page Data Caching
- •Expiration
- •File and Key Dependency and Scavenging
- •Review
- •Quiz Yourself
- •A Brief History of Microsoft Data Access
- •Differences between ADO and ADO.NET
- •Transmission formats
- •Connected versus disconnected datasets
- •COM marshaling versus text-based data transmission
- •Variant versus strongly typed data
- •Data schema
- •ADO.NET Managed Provider Versus SQL Managed Provider
- •Review
- •Quiz Yourself
- •Review
- •Quiz Yourself
- •Creating a Connection
- •Opening a Connection
- •Using Transactions
- •Review
- •Quiz Yourself
- •Building a Command
- •Connection property
- •CommandText property
- •CommandType property
- •CommandTimeout property
- •Appending parameters
- •Executing a Command
- •ExecuteNonQuery method
- •Prepare method
- •ExecuteReader method
- •Review
- •Quiz Yourself
- •Introducing DataReaders
- •Using DataReader Properties
- •Item property
- •FieldCount property
- •IsClosed property
- •RecordsAffected property
- •Using DataReader Methods
- •Read method
- •GetValue method
- •Get[Data Type] methods
- •GetOrdinal method
- •GetName method
- •Close method
- •Review
- •Quiz Yourself
- •Constructing a DataAdapter Object
- •SelectCommand property
- •UpdateCommand, DeleteCommand, and InsertCommand properties
- •Fill method
- •Update method
- •Dispose method
- •Using DataSet Objects
- •DataSetName property
- •CaseSensitive property
- •Review
- •Quiz Yourself
- •Constructing a DataSet
- •Tables property
- •TablesCollection Object
- •Count property
- •Item property
- •Contains method
- •CanRemove method
- •Remove method
- •Add method
- •DataTable Objects
- •CaseSensitive property
- •ChildRelations property
- •Columns property
- •Constraints property
- •DataSet property
- •DefaultView property
- •ParentRelations property
- •PrimaryKey property
- •Rows property
- •Dispose method
- •NewRow method
- •Review
- •Quiz Yourself
- •What Is Data Binding?
- •Binding to Arrays and Extended Object Types
- •Binding to Database Data
- •Binding to XML
- •TreeView Control
- •Implement the TreeView server control
- •Review
- •Quiz Yourself
- •DataGrid Control Basics
- •Binding a set of data to a DataGrid control
- •Formatting the output of a DataGrid control
- •Master/Detail Relationships with the DataGrid Control
- •Populating the Master control
- •Filtering the detail listing
- •Review
- •QUIZ YOURSELF
- •Updating Your Data
- •Handling the OnEditCommand Event
- •Handling the OnCancelCommand Event
- •Handling the OnUpdateCommand Event
- •Checking that the user input has been validated
- •Executing the update process
- •Deleting Data with the OnDeleteCommand Event
- •Sorting Columns with the DataGrid Control
- •Review
- •Quiz Yourself
- •What Is Data Shaping?
- •Why Shape Your Data?
- •DataSet Object
- •Shaping Data with the Relations Method
- •Review
- •Quiz Yourself
- •OLEDBError Object Description
- •OLEDBError Object Properties
- •OLEDBError Object Methods
- •OLEDBException Properties
- •Writing Errors to the Event Log
- •Review
- •Quiz Yourself
- •Introducing SOAP
- •Accessing Remote Data with SOAP
- •SOAP Discovery (DISCO)
- •Web Service Description Language (WSDL)
- •Using SOAP with ASP.NET
- •Review
- •Quiz Yourself
- •Developing a Web Service
- •Consuming a Web Service
- •Review
- •Quiz Yourself
- •ASP and ASP.NET Compatibility
- •Scripting language limitations
- •Rendering HTML page elements
- •Using script blocks
- •Syntax differences and language modifications
- •Running ASP Pages under Microsoft.NET
- •Using VB6 Components with ASP.NET
- •Review
- •Quiz Yourself
- •Preparing a Migration Path
- •ADO and ADO.NET Compatibility
- •Running ADO under ASP.NET
- •Early Binding ADO COM Objects in ASP.NET
- •Review
- •Quiz Yourself
- •Answers to Part Reviews
- •Friday Evening Review Answers
- •Saturday Morning Review Answers
- •Saturday Afternoon Review Answers
- •Saturday Evening Review Answers
- •Sunday Morning Review Answers
- •Sunday Afternoon Review Answers
- •What’s on the CD-ROM
- •System Requirements
- •Using the CD with Windows
- •What’s on the CD
- •The Software Directory
- •Troubleshooting
- •ADO.NET Class Descriptions
- •Coding Differences in ASP and ASP.NET
- •Retrieving a Table from a Database
- •Displaying a Table from a Database
- •Variable Declarations
- •Statements
- •Comments
- •Indexed Property Access
- •Using Arrays
- •Initializing Variables
- •If Statements
- •Case Statements
- •For Loops
- •While Loops
- •String Concatenation
- •Error Handling
- •Conversion of Variable Types
- •Index
204 |
Saturday Evening |
Suppose that oDS is a DataSet object. In order to retrieve the name of a DataSet, you may use:
Dim sName As String sName = oDS.DataSetName
CaseSensitive property
The CaseSensitive property gets or sets a value (as a Boolean) indicating whether string comparisons within DataTable objects are case sensitive. The CaseSenstive property affects operations such as sorting, filtering, and searching a DataTable. The default value for this property is False. If you want to set the property to True, use the following syntax:
oDS.CaseSensitive = True
By default, setting the CaseSensitive property for a DataSet also sets each of its DataTable object’s CaseSensitive property to the same value. However, the DataSet’s CaseSensitive property can be overridden by a DataTable’s CaseSenstive property. In order to retrieve the CaseSensitive property you may use the following code:
Dim bCase As Boolean bCase = oDS.CaseSensitive
REVIEW
The ADO.NET DataSet object, is a very complex, yet exciting object. The DataSet is a mem- ory-resident database that provides a consistent programming model regardless of its data source. The DataSet is designed to work in a disconnected environment, so passing a DataSet from one system to another is expected. In order to create a DataSet, you can use a
DataAdapter, OleDbDataAdapter, or SqlDataAdapter object.
QUIZ YOURSELF
1.What are some of the differences between the Command and DataAdapter objects? (See session introduction.)
2.What is a DataSet and how does it differ from a DataReader? (See session introduction.)
3.How is the DataAdapter method used to populate a DataSet? (See “Fill method.”)
P A R T
IV
Saturday Evening
Part Review
The following set of questions is designed to provide you with feedback on how well you understood the topics covered during this part of the book. Please refer to Appendix A for the answers to each question.
1.Which namespace can be used to access the OleDbConnection objects?
a.System.Web
b.System.Data.Connections
c.System.Data.ADO
d.System.Data.OleDb
2.Which namespace can be use to manipulate XML data?
a.System.XML
b.System.Data.Connections
c.System.Data.ADO
d.System.Data.OleDb
3.OleDbConnection and SqlConnection objects must be created explicitly. True/False
206 |
Part IV—Saturday Evening Part Review |
4.Which of the following OleDbConnection properties is used to obtain the database to which an OleDbConnection object is connected?
a.Provider
b.DataSource
c.Database
d.UserID
5.A Command object is basically a facility for executing commands against a datasource.
True/False
6.In order to create an OleDbCommand object, an OleDbConnection object must be specified in its constructor.
True/False
7.Which OleDbCommand class property is used to specify the SQL command or stored procedure to execute?
a.ActiveConnection
b.Command
c.CommandText
d.ExecuteString
8.Fill in the blank: The SqlCommand class’s ______ property gets or sets how the CommandText is interpreted
9.A DataReader object is a forward-only collection of records from a data source.
True/False
10.Fill in the blank: The OleDbDataReader object is created via the ______
object’s Execute method.
11.A SqlDataReader object has a constructor. True/False
12.The OleDbDataReader allows forward and backward row navigation. True/False
13.A DataSet can contain multiple tables, but not the relationships between the tables.
True/False
Part IV—Saturday Evening Part Review |
207 |
14.The DataAdapter objects provide a bridge to retrieve and update data between a DataSet and a data store.
True/False
15.Fill in the blank: The OleDbDataAdapter’s ______ property gets or sets a Command object used to select records in a DataSet.
16.Fill in the blank: The SqlDataAdapter’s ______ method adds data from a datasource to a DataSet.
Part V — Sunday Morning
Session 21
Introducing Datasets, Part II
Session 22
Introducing Data Binding
Session 23
Using the DataGrid Control with Bound Data
Session 24
Beating the CRUD out of the DataGrid Control
Session 25
Data Shaping with ADO.NET
Session 26
Handling ADO.NET Errors
Part VI — Sunday Afternoon
Session 27
SOAP It Up!
Session 28
Web Services
Session 29
Migrating from ASP to ASP.NET
Session 30
Migrating from ADO to ADO.NET
P A R T
V
Sunday
Morning
Session 21
Introducing Datasets, Part II
Session 22
Introducing Data Binding
Session 23
Using the DataGrid Control with Bound Data
Session 24
Beating the CRUD out of the DataGrid Control
Session 25
Data Shaping with ADO.NET
Session 26
Handling ADO.NET Errors