| Acknowledgments |
|
xiv | |
| Introduction |
|
xv | |
|
Part I --- Introduction to Access 2003 VBA Programming |
|
|
|
|
|
3 | (9) |
|
|
|
3 | (1) |
|
|
|
4 | (2) |
|
Events, Event Properties, and Event Procedures |
|
|
6 | (5) |
|
|
|
7 | (1) |
|
Walking Through an Event Procedure |
|
|
7 | (4) |
|
Compiling Your Procedures |
|
|
11 | (1) |
|
|
|
11 | (1) |
|
The Visual Basic Editor (VBE) |
|
|
12 | (16) |
|
Understanding the Project Explorer Window |
|
|
12 | (1) |
|
Understanding the Properties Window |
|
|
13 | (1) |
|
Understanding the Code Window |
|
|
14 | (2) |
|
|
|
16 | (1) |
|
On-the-Fly Syntax and Programming Assistance |
|
|
16 | (6) |
|
|
|
17 | (1) |
|
|
|
18 | (1) |
|
|
|
19 | (1) |
|
|
|
19 | (1) |
|
|
|
20 | (1) |
|
|
|
20 | (1) |
|
Comment Block/Uncomment Block |
|
|
21 | (1) |
|
|
|
22 | (2) |
|
Using the VBA Object Library |
|
|
24 | (1) |
|
Using the Immediate Window |
|
|
25 | (2) |
|
|
|
27 | (1) |
|
Variables, Data Types, and Constants |
|
|
28 | (24) |
|
|
|
28 | (1) |
|
|
|
29 | (1) |
|
|
|
30 | (1) |
|
|
|
31 | (2) |
|
Specifying the Data Type of a Variable |
|
|
33 | (2) |
|
Using Type Declaration Characters |
|
|
35 | (1) |
|
Assigning Values to Variables |
|
|
36 | (2) |
|
Forcing Declaration of Variables |
|
|
38 | (2) |
|
Understanding the Scope and Lifetime of Variables |
|
|
40 | (3) |
|
Procedure-Level (Local) Variables |
|
|
40 | (1) |
|
|
|
41 | (1) |
|
|
|
42 | (1) |
|
Understanding and Using Static Variables |
|
|
43 | (2) |
|
Declaring and Using Object Variables |
|
|
45 | (2) |
|
Finding a Variable Definition |
|
|
47 | (1) |
|
What Type Is This Variable? |
|
|
47 | (1) |
|
Using Constants in VBA Procedures |
|
|
48 | (1) |
|
|
|
49 | (2) |
|
|
|
51 | (1) |
|
Passing Arguments to Procedures and Functions |
|
|
52 | (24) |
|
Writing a Function Procedure |
|
|
52 | (2) |
|
Specifying the Data Type for a Function's Result |
|
|
54 | (2) |
|
Passing Arguments by Reference and by Value |
|
|
56 | (1) |
|
|
|
57 | (2) |
|
Using the Is Missing Function |
|
|
59 | (1) |
|
|
|
59 | (1) |
|
Using the MsgBox Function |
|
|
59 | (8) |
|
Returning Values from the MsgBox Function |
|
|
66 | (1) |
|
Using the InputBox Function |
|
|
67 | (2) |
|
|
|
69 | (2) |
|
Using Master Procedures and Subprocedures |
|
|
71 | (4) |
|
|
|
75 | (1) |
|
|
|
76 | (15) |
|
|
|
77 | (1) |
|
Multi-Line If...Then Statement |
|
|
78 | (2) |
|
Decisions Based on More Than One Condition |
|
|
80 | (1) |
|
If...Then...Else Statement |
|
|
81 | (2) |
|
If...Then...ElseIf Statement |
|
|
83 | (1) |
|
Nested If...Then Statements |
|
|
84 | (1) |
|
|
|
85 | (5) |
|
Using Is with the Case Clause |
|
|
88 | (1) |
|
Specifying a Range of Values in a Case Clause |
|
|
88 | (2) |
|
Specifying Multiple Expressions in a Case Clause |
|
|
90 | (1) |
|
|
|
90 | (1) |
|
|
|
91 | (11) |
|
Using the Do...While Loop |
|
|
91 | (2) |
|
Another Approach to the Do...While Loop |
|
|
93 | (1) |
|
Using the Do...Until Loop |
|
|
94 | (1) |
|
Another Approach to the Do...Until Loop |
|
|
95 | (1) |
|
|
|
96 | (2) |
|
|
|
98 | (1) |
|
|
|
99 | (1) |
|
|
|
99 | (2) |
|
|
|
101 | (1) |
|
|
|
102 | (17) |
|
|
|
104 | (1) |
|
Array Upper and Lower Bounds |
|
|
105 | (1) |
|
Using Arrays in VBA Procedures |
|
|
105 | (2) |
|
Arrays and Looping Statements |
|
|
107 | (3) |
|
Using a Two-Dimensional Array |
|
|
110 | (1) |
|
Static and Dynamic Arrays |
|
|
111 | (2) |
|
|
|
113 | (3) |
|
|
|
113 | (1) |
|
|
|
113 | (1) |
|
|
|
114 | (1) |
|
The LBound and UBound Functions |
|
|
115 | (1) |
|
|
|
116 | (1) |
|
|
|
117 | (1) |
|
|
|
118 | (1) |
|
Custom Collections and Class Modules |
|
|
119 | (23) |
|
|
|
119 | (1) |
|
|
|
120 | (3) |
|
Declaring a Custom Collection |
|
|
121 | (1) |
|
Adding Objects to a Custom Collection |
|
|
121 | (2) |
|
Removing Objects from a Custom Collection |
|
|
123 | (1) |
|
|
|
123 | (7) |
|
|
|
124 | (1) |
|
|
|
124 | (1) |
|
Defining the Properties for the Class |
|
|
125 | (1) |
|
Creating the Property Get Procedures |
|
|
126 | (1) |
|
Creating the Property Let Procedures |
|
|
127 | (1) |
|
Creating the Class Methods |
|
|
128 | (1) |
|
Creating an Instance of a Class |
|
|
129 | (1) |
|
Event Procedures in the Class Module |
|
|
130 | (1) |
|
Creating the User Interface |
|
|
130 | (9) |
|
Watching the Execution of Your VBA Procedures |
|
|
139 | (2) |
|
|
|
141 | (1) |
|
Debugging VBA Procedures and Handling Errors |
|
|
142 | (29) |
|
|
|
143 | (1) |
|
|
|
143 | (13) |
|
|
|
144 | (5) |
|
|
|
149 | (1) |
|
Using the Immediate Window in Break Mode |
|
|
149 | (1) |
|
|
|
150 | (1) |
|
|
|
151 | (3) |
|
Removing Watch Expressions |
|
|
154 | (1) |
|
|
|
154 | (2) |
|
Using the Locals Window and the Call Stack Dialog Box |
|
|
156 | (2) |
|
Stepping Through VBA Procedures |
|
|
158 | (2) |
|
Stepping Over a Procedure |
|
|
159 | (1) |
|
Stepping Out of a Procedure |
|
|
160 | (1) |
|
Running a Procedure to Cursor |
|
|
160 | (1) |
|
Setting the Next Statement |
|
|
160 | (1) |
|
Showing the Next Statement |
|
|
161 | (1) |
|
Stopping and Resetting VBA Procedures |
|
|
161 | (1) |
|
Understanding and Using Conditional Compilation |
|
|
161 | (2) |
|
Navigating with Bookmarks |
|
|
163 | (1) |
|
|
|
164 | (3) |
|
Generating Errors to Test Error Handling |
|
|
167 | (1) |
|
|
|
168 | (3) |
|
Part II --- Creating and Manipulating Databases with ADO |
|
|
|
|
|
171 | (23) |
|
|
|
172 | (1) |
|
Establishing a Connection with the Data |
|
|
173 | (3) |
|
Opening a Microsoft Jet Database in Read/Write Mode |
|
|
176 | (1) |
|
Opening a Microsoft Jet Database in Read-Only Mode |
|
|
177 | (1) |
|
Opening a Microsoft Jet Database Secured with a Password |
|
|
178 | (1) |
|
Opening a Microsoft Jet Database with User-Level Security |
|
|
179 | (2) |
|
Opening a Microsoft Excel Spreadsheet |
|
|
181 | (1) |
|
Opening a dBASE File Using MSDASQL Provider |
|
|
182 | (2) |
|
Opening a Text File Using ADO |
|
|
184 | (1) |
|
Connecting to the Current Access Database |
|
|
185 | (1) |
|
Creating a New Access Database |
|
|
186 | (1) |
|
|
|
187 | (1) |
|
Connecting to an SQL Server |
|
|
188 | (2) |
|
|
|
190 | (2) |
|
|
|
192 | (1) |
|
|
|
193 | (1) |
|
Creating and Accessing Tables and Fields with ADO |
|
|
194 | (18) |
|
Creating a Microsoft Access Table |
|
|
195 | (3) |
|
|
|
198 | (1) |
|
Deleting a Database Table |
|
|
199 | (1) |
|
Adding New Fields to an Existing Table |
|
|
200 | (1) |
|
Removing a Field from a Table |
|
|
201 | (1) |
|
Retrieving Table Properties |
|
|
202 | (1) |
|
Retrieving Field Properties |
|
|
203 | (1) |
|
Linking a Microsoft Access Table |
|
|
204 | (1) |
|
Linking a Microsoft Excel Spreadsheet |
|
|
205 | (2) |
|
|
|
207 | (1) |
|
|
|
208 | (1) |
|
Listing Tables and Fields |
|
|
209 | (1) |
|
|
|
210 | (1) |
|
|
|
211 | (1) |
|
Setting Up Indexes and Table Relationships with ADO |
|
|
212 | (9) |
|
|
|
212 | (1) |
|
Creating a Single-Field Index |
|
|
213 | (2) |
|
Adding a Multiple-Field Index to a Table |
|
|
215 | (1) |
|
Listing Indexes in a Table |
|
|
216 | (1) |
|
|
|
217 | (1) |
|
Creating Table Relationships |
|
|
218 | (2) |
|
|
|
220 | (1) |
|
ADO Techniques for Finding and Reading Records |
|
|
221 | (28) |
|
Introduction to ADO Recordsets |
|
|
221 | (8) |
|
|
|
222 | (2) |
|
|
|
224 | (1) |
|
|
|
225 | (1) |
|
|
|
226 | (3) |
|
|
|
229 | (7) |
|
Opening a Recordset Based on a Table or Query |
|
|
230 | (3) |
|
Opening a Recordset Based on an SQL Statement |
|
|
233 | (1) |
|
Opening a Recordset Based on Criteria |
|
|
234 | (1) |
|
Opening a Recordset Directly |
|
|
235 | (1) |
|
Moving Around in a Recordset |
|
|
236 | (1) |
|
Finding the Record Position |
|
|
236 | (1) |
|
Reading Data from a Field |
|
|
237 | (1) |
|
Returning a Recordset as a String |
|
|
238 | (2) |
|
Finding Records Using the Find Method |
|
|
240 | (1) |
|
Finding Records Using the Seek Method |
|
|
241 | (2) |
|
Finding a Record Based on Multiple Conditions |
|
|
243 | (1) |
|
|
|
244 | (2) |
|
Using Bookmarks to Filter a Recordset |
|
|
246 | (1) |
|
Using the GetRows Method to Fill the Recordset |
|
|
247 | (1) |
|
|
|
248 | (1) |
|
|
|
249 | (15) |
|
|
|
249 | (1) |
|
|
|
250 | (1) |
|
Canceling Changes to the Data |
|
|
251 | (1) |
|
|
|
251 | (2) |
|
|
|
253 | (1) |
|
Copying Records to an Excel Spreadsheet |
|
|
254 | (2) |
|
Copying Records to a Word Document |
|
|
256 | (3) |
|
Copying Records to a Text File |
|
|
259 | (1) |
|
Filtering Records with an SQL Clause |
|
|
260 | (1) |
|
Filtering Records Using the Filter Property |
|
|
261 | (1) |
|
|
|
262 | (1) |
|
|
|
263 | (1) |
|
Creating and Running Queries with ADO |
|
|
264 | (23) |
|
Creating a Select Query Manually |
|
|
264 | (4) |
|
Creating a Select Query from a VBA Procedure |
|
|
268 | (3) |
|
|
|
271 | (3) |
|
Creating a Parameter Query |
|
|
274 | (1) |
|
Executing a Parameter Query |
|
|
275 | (2) |
|
Creating a Pass-Through Query |
|
|
277 | (3) |
|
Executing a Pass-Through Query |
|
|
280 | (1) |
|
Executing an Update Query |
|
|
281 | (2) |
|
|
|
283 | (2) |
|
Listing Queries in a Database |
|
|
285 | (1) |
|
|
|
285 | (1) |
|
|
|
286 | (1) |
|
Using Advanced ADO Features |
|
|
287 | (47) |
|
|
|
287 | (3) |
|
|
|
290 | (2) |
|
Saving a Recordset to Disk |
|
|
292 | (13) |
|
|
|
305 | (5) |
|
Introduction to Data Shaping |
|
|
310 | (20) |
|
Writing a Simple Shape statement |
|
|
311 | (1) |
|
Working with Data Shaping |
|
|
312 | (4) |
|
Writing a Complex Shape Statement |
|
|
316 | (1) |
|
Shaped Recordsets with Multiple Children |
|
|
317 | (3) |
|
Shaped Recordsets with Grandchildren |
|
|
320 | (10) |
|
|
|
330 | (3) |
|
Creating a Simple Transaction |
|
|
330 | (3) |
|
|
|
333 | (1) |
|
Implementing Database Security with Adox and JRO |
|
|
334 | (37) |
|
Two Types of Security in Microsoft Access |
|
|
334 | (1) |
|
|
|
334 | (1) |
|
|
|
335 | (1) |
|
Understanding Workgroup Information Files |
|
|
335 | (10) |
|
Creating and Joining Workgroup Information Files |
|
|
337 | (8) |
|
|
|
345 | (11) |
|
|
|
345 | (3) |
|
|
|
348 | (1) |
|
Adding a User to a New Group |
|
|
349 | (2) |
|
|
|
351 | (1) |
|
|
|
352 | (1) |
|
Listing All Group Accounts |
|
|
353 | (1) |
|
Listing All User Accounts |
|
|
354 | (1) |
|
|
|
355 | (1) |
|
Setting and Retrieving User and Group Permissions |
|
|
356 | (13) |
|
Determining the Object Owner |
|
|
356 | (2) |
|
Setting User Permissions for an Object |
|
|
358 | (3) |
|
Setting User Permissions for a Database |
|
|
361 | (1) |
|
Setting User Permissions for Containers |
|
|
362 | (2) |
|
Checking Permissions for Objects |
|
|
364 | (2) |
|
Setting a Database Password |
|
|
366 | (1) |
|
|
|
367 | (2) |
|
|
|
369 | (1) |
|
|
|
370 | (1) |
|
|
|
371 | (24) |
|
|
|
372 | (2) |
|
|
|
374 | (1) |
|
Creating a Partial Replica |
|
|
375 | (3) |
|
|
|
378 | (2) |
|
|
|
380 | (2) |
|
|
|
382 | (2) |
|
Retrieving Replica Properties |
|
|
384 | (1) |
|
Synchronization Conflicts |
|
|
385 | (6) |
|
|
|
391 | (4) |
|
Part III --- Programming with the Jet Data Definition Language |
|
|
|
Creating, Modifying, and Deleting Tables and Fields |
|
|
395 | (18) |
|
|
|
397 | (4) |
|
|
|
401 | (1) |
|
|
|
402 | (1) |
|
Modifying Tables with DDL |
|
|
402 | (10) |
|
Adding New Fields to a Table |
|
|
402 | (1) |
|
Changing the Data Type of a Table Column |
|
|
403 | (1) |
|
Changing the Size of a Text Column |
|
|
404 | (1) |
|
Deleting a Column from a Table |
|
|
405 | (1) |
|
Adding a Primary Key to a Table |
|
|
406 | (1) |
|
Adding a Multiple-Field Index to a Table |
|
|
406 | (1) |
|
Deleting an Indexed Column |
|
|
407 | (1) |
|
|
|
408 | (1) |
|
Setting a Default Value for a Table Column |
|
|
409 | (1) |
|
Changing the Seed and Increment Value of AutoNumber Columns |
|
|
410 | (2) |
|
|
|
412 | (1) |
|
Enforcing Data Integrity and Relationships between Tables |
|
|
413 | (11) |
|
|
|
414 | (4) |
|
Establishing Relationships between Tables |
|
|
418 | (3) |
|
Using the Data Definition Query Window |
|
|
421 | (2) |
|
|
|
423 | (1) |
|
Defining Indexes and Primary Keys |
|
|
424 | (9) |
|
Creating Tables with Indexes |
|
|
424 | (1) |
|
Adding an Index to an Existing Table |
|
|
425 | (2) |
|
Creating a Table with a Primary Key |
|
|
427 | (1) |
|
Creating Indexes with Restrictions |
|
|
428 | (4) |
|
|
|
432 | (1) |
|
|
|
432 | (1) |
|
|
|
433 | (11) |
|
Setting the Database Password |
|
|
433 | (1) |
|
Removing the Database Password |
|
|
434 | (1) |
|
|
|
435 | (1) |
|
|
|
436 | (1) |
|
|
|
437 | (1) |
|
|
|
438 | (1) |
|
Removing a User from a Group |
|
|
438 | (1) |
|
|
|
439 | (1) |
|
Granting Permissions for an Object |
|
|
440 | (1) |
|
Revoking Security Permissions |
|
|
441 | (1) |
|
|
|
442 | (1) |
|
|
|
443 | (1) |
|
Views and Stored Procedures |
|
|
444 | (15) |
|
|
|
444 | (3) |
|
|
|
447 | (1) |
|
|
|
448 | (1) |
|
Creating a Stored Procedure |
|
|
448 | (2) |
|
Creating a Parameterized Stored Procedure |
|
|
450 | (2) |
|
Executing a Parameterized Stored Procedure |
|
|
452 | (2) |
|
Deleting a Stored Procedure |
|
|
454 | (1) |
|
Changing Database Records with Stored Procedures |
|
|
454 | (1) |
|
|
|
455 | (4) |
|
Part IV --- Event Programming in Forms and Reports |
|
|
|
|
|
459 | (42) |
|
|
|
460 | (9) |
|
|
|
460 | (1) |
|
|
|
461 | (1) |
|
|
|
462 | (1) |
|
|
|
463 | (1) |
|
|
|
464 | (1) |
|
|
|
465 | (1) |
|
|
|
466 | (1) |
|
|
|
466 | (1) |
|
|
|
467 | (1) |
|
|
|
468 | (1) |
|
|
|
469 | (1) |
|
|
|
469 | (1) |
|
|
|
469 | (1) |
|
|
|
470 | (1) |
|
|
|
470 | (1) |
|
|
|
470 | (3) |
|
|
|
470 | (1) |
|
|
|
471 | (1) |
|
|
|
471 | (2) |
|
|
|
473 | (1) |
|
|
|
473 | (1) |
|
|
|
473 | (1) |
|
|
|
473 | (3) |
|
|
|
473 | (1) |
|
|
|
474 | (1) |
|
|
|
475 | (1) |
|
|
|
476 | (2) |
|
|
|
476 | (2) |
|
|
|
478 | (2) |
|
|
|
478 | (1) |
|
|
|
479 | (1) |
|
|
|
480 | (2) |
|
|
|
480 | (2) |
|
PivotTable/PivotChart Events |
|
|
482 | (17) |
|
Referencing the Microsoft Office Web Components Object Library |
|
|
483 | (1) |
|
|
|
483 | (1) |
|
|
|
483 | (1) |
|
|
|
484 | (1) |
|
|
|
484 | (1) |
|
|
|
484 | (3) |
|
|
|
487 | (1) |
|
|
|
487 | (1) |
|
|
|
487 | (1) |
|
|
|
488 | (2) |
|
|
|
490 | (1) |
|
|
|
491 | (1) |
|
|
|
492 | (1) |
|
|
|
492 | (1) |
|
|
|
493 | (1) |
|
|
|
493 | (1) |
|
|
|
494 | (1) |
|
|
|
494 | (1) |
|
|
|
495 | (1) |
|
|
|
495 | (1) |
|
|
|
496 | (1) |
|
|
|
497 | (1) |
|
|
|
498 | (1) |
|
Keyboard and Mouse Events |
|
|
498 | (1) |
|
Events Recognized by Form Sections |
|
|
499 | (1) |
|
DblClick (Form Section Event) |
|
|
499 | (1) |
|
|
|
500 | (1) |
|
|
|
501 | (13) |
|
|
|
501 | (1) |
|
|
|
502 | (1) |
|
|
|
503 | (1) |
|
|
|
504 | (1) |
|
|
|
504 | (1) |
|
|
|
505 | (1) |
|
|
|
506 | (1) |
|
Events Recognized by Report Sections |
|
|
507 | (6) |
|
Format (Report Section Event) |
|
|
507 | (3) |
|
Print (Report Section Event) |
|
|
510 | (3) |
|
|
|
513 | (1) |
|
|
|
513 | (1) |
|
Events Recognized by Controls |
|
|
514 | (14) |
|
|
|
515 | (1) |
|
|
|
516 | (1) |
|
|
|
517 | (2) |
|
|
|
519 | (1) |
|
|
|
520 | (5) |
|
|
|
525 | (2) |
|
|
|
527 | (1) |
|
More about Event Programming |
|
|
528 | (21) |
|
Sinking Events in Standalone Class Modules |
|
|
529 | (8) |
|
Writing Event Procedure Code in Two Places |
|
|
537 | (1) |
|
Responding to Control Events in a Class |
|
|
537 | (4) |
|
Declaring and Raising Events |
|
|
541 | (5) |
|
|
|
546 | (3) |
|
Part V --- Taking Your VBA Programming Skills to the Web |
|
|
|
Access and Active Server Pages |
|
|
549 | (58) |
|
Introduction to Active Server Pages |
|
|
552 | (3) |
|
|
|
555 | (1) |
|
Installing Internet Information Services (IIS) |
|
|
556 | (1) |
|
Creating a Virtual Directory |
|
|
557 | (2) |
|
Connecting to a Microsoft Access Database via DSN |
|
|
559 | (6) |
|
Other Methods of Connecting to a Microsoft Access Database |
|
|
565 | (2) |
|
Establishing a DSN-less Connection |
|
|
566 | (1) |
|
Connecting to a Microsoft Access Database Using OLE DB |
|
|
566 | (1) |
|
|
|
567 | (12) |
|
Breaking Up a Recordset When Retrieving Records |
|
|
569 | (7) |
|
Retrieving Records with the GetRows Method |
|
|
576 | (3) |
|
Database Lookup Using Drop-Down Lists |
|
|
579 | (4) |
|
Database Lookup Using a Multiple Selection List Box |
|
|
583 | (5) |
|
|
|
588 | (4) |
|
|
|
592 | (5) |
|
|
|
597 | (4) |
|
Creating a Web User Interface for Database Access |
|
|
601 | (4) |
|
|
|
605 | (2) |
|
XML Features in Access 2003 |
|
|
607 | (64) |
|
|
|
607 | (2) |
|
XML Support in Access 2003 |
|
|
609 | (1) |
|
|
|
610 | (14) |
|
Understanding the XML Data File |
|
|
612 | (3) |
|
Understanding the XML Schema File |
|
|
615 | (2) |
|
Understanding the XSL Transformation Files |
|
|
617 | (3) |
|
Viewing XML Documents Formatted with Stylesheets |
|
|
620 | (1) |
|
Advanced XML Export Options |
|
|
620 | (1) |
|
|
|
620 | (2) |
|
|
|
622 | (1) |
|
Presentation Export Options |
|
|
623 | (1) |
|
Applying XSLT Transforms to Exported Data |
|
|
624 | (5) |
|
|
|
629 | (5) |
|
Exporting to and Importing from XML Programmatically |
|
|
634 | (16) |
|
Exporting to XML Using the ExportXML Method |
|
|
635 | (8) |
|
Transforming XML Data with the TransformXML Method |
|
|
643 | (7) |
|
Importing to XML Using the ImportXML Method |
|
|
650 | (1) |
|
Manipulating XML Documents Programmatically |
|
|
650 | (8) |
|
Loading and Retrieving the Contents of an XML File |
|
|
652 | (1) |
|
Working with XML Document Nodes |
|
|
653 | (2) |
|
Retrieving Information from Element Nodes |
|
|
655 | (1) |
|
Retrieving Specific Information from Element Nodes |
|
|
656 | (1) |
|
Retrieving the First Matching Node |
|
|
657 | (1) |
|
Using ActiveX Data Objects with XML |
|
|
658 | (10) |
|
Saving an ADO Recordset as XML to Disk |
|
|
658 | (2) |
|
Attribute-Centric and Element-Centric XML |
|
|
660 | (1) |
|
Changing the Type of an XML File |
|
|
660 | (1) |
|
Applying an XSL Stylesheet |
|
|
661 | (2) |
|
Transforming Attribute-Centric XML Data into an HTML Table |
|
|
663 | (3) |
|
Loading an XML Document in Excel |
|
|
666 | (2) |
|
|
|
668 | (3) |
| Index |
|
671 | |