Presentation is loading. Please wait.

Presentation is loading. Please wait.

Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Slide 10- 1 STARTING OUT WITH Visual Basic 2008 FOURTH EDITION Tony Gaddis.

Similar presentations


Presentation on theme: "Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Slide 10- 1 STARTING OUT WITH Visual Basic 2008 FOURTH EDITION Tony Gaddis."— Presentation transcript:

1 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Slide 10- 1 STARTING OUT WITH Visual Basic 2008 FOURTH EDITION Tony Gaddis Haywood Community College Kip Irvine Florida International University

2 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Chapter Working With Databases 10

3 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Slide 10- 3 Introduction Basic database terminology Fundamental database concepts Use ADO.NET to access databases Display, sort, and update database data Use the DataGridView control

4 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Database Management Systems 10.1 Visual Basic applications use database management systems to make large amounts of data available to programs

5 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Visual Basic and Database Management Systems Simple text files as shown in chapter 9 are: Fine for small amounts of data But impractical for large amounts of data Businesses must maintain huge amounts of data A database management system (DBMS) is the typical solution to the data needs of business Designed to store, retrieve, & manipulate data Visual Basic can communicate with a DBMS Tells DBMS what data to retrieve or manipulate Slide 10- 5

6 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Layered Approach to Using a DBMS Applications that work with a DBMS use a layered approach VB application is topmost layer VB sends instructions to next layer, the DBMS DBMS works directly with data Programmer need not understand the physical structure of the data Just need to know how to interact with the database Slide 10- 6

7 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Visual Basic Supports Many DBMS’s Visual Basic can interact with many DBMS’s Microsoft SQL Server Oracle DB2 MySQL Microsoft SQL Server 2008 Express used in this chapter Slide 10- 7

8 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Database Concepts 10.2 A database is a collection of one or more tables, each containing data related to a particular topic

9 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Slide 10- 9 Terminology Database: a collection of interrelated tables Table: a logical grouping of related data A category of people, places, or things For example, employees or departments Organized into rows and columns Field: an individual piece of data pertaining to an item, an employee name for instance Record: the complete data about a single item such as all information about an employee A record is a row of a table

10 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Emp_IdFirst_NameLast_NameDepartment 001234IgnacioFletaAccounting 002000ChristianMartinComputer Support 002122OrvilleGibsonHuman Resources 003400BenSmithAccounting 003780AllisonChongComputer Support Slide 10- 10 Database Table Row (Record) ColumnField Each table has a primary key Uniquely identifies that row of the table Emp_Id is the primary key in this example Columns are also called fields or attributes Each column has a particular data type

11 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Slide 10- 11 VB and SQL Server Data Types VB data types must match table data types SQL Server and VB have similar data types SQL TypeUsageVisual Basic Type BitTrue/false valuesBoolean DateTimeDates and timesDate, DateTime Decimal, MoneyFinancial valuesDecimal FloatReal-number valuesDouble IntInteger valuesInteger SmallintIntegers -32,768 to 32,767Short Varchar(n)Variable length stringsString TextStrings more than 8000 charString

12 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Slide 10- 12 Choosing Column Names Define a column for each piece of data Allow plenty of space for text fields Avoid using spaces in column names For the members of an organization: Column NameTypeRemarks Member_IDintPrimary key First_Namevarchar(40) Last_Namevarchar(40) Phonevarchar(30) Emailvarchar(50) Date_JoinedsmalldatetimeDate only, no time values Meeings_Attendedsmallint OfficerYes/NoTrue/False values

13 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Slide 10- 13 Issues with Redundant Data Database design minimizes redundant data In the following employee table: IDFirst_NameLast_NameDepartment 001234IgnacioFletaAccounting 002000ChristianMartinComputer Support 002122OrvilleGibsonHuman Resources 00300JoseRamirezResearch & Devel 003400BenSmithAccounting 003780AllisonChongComputer Support Same dept name appears multiple times Requires additional storage space Causes problems if misspelled What if a department needs to be renamed?

14 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Slide 10- 14 Eliminating Redundant Data Create a department table Dept_IDDept_NameNum_Employees 1Human Resources10 2Accounting5 3Computer Support30 4Research & Development15 Reference department table in employee table IDFirst_NameLast_NameDept_ID 001234IgnacioFleta2 002000ChristianMartin3 002122OrvilleGibson1 003000JoseRamirez4 003400BenSmith2 003780AllisonChong3

15 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Slide 10- 15 One-to-Many Relationships The previous changes created a one-to-many relationship Every employee has one and only one dept Every department has many employees DeptID in department table is a primary key DeptID in employee table is a foreign key One-to-many relationship exists when primary key of one table is specified as a field of another table

16 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley DataGridView Control 10.3 The DataGridView Control Allows you to Display a Database Table in a Grid Which Can be Used at Runtime to Sort and Edit the Contents of the Table

17 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Slide 10- 17 Connecting VB to a Database VB provides tools to display database tables Data binding links tables to controls on forms Controls called components establish the link A wizard guides you through the process We’ll use these data-related components: Data source – usually a database Binding source – connects data bound controls to a dataset Table adapter – uses SQL to select data Dataset – in-memory copy of data from tables

18 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Slide 10- 18 Connecting VB to a Database The flow of data from database to application Data travels from data source to application Application can view/change dataset contents Changes to dataset can be written back to the data source Tutorial 10-1 demonstrates how to connect a database table to a DataGridView control

19 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Data-Bound Controls 10.4 Some Controls Can Be Bound to a Dataset. A Data-bound Control Can be Used to Display and Edit the Contents of a Particular Row and Column

20 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Slide 10- 20 Advantages of Data-Binding Can bind fields in a data source to controls: Text boxes Labels List boxes Contents of data-bound controls change automatically when moving from row to row Data-bound control also allow the contents of a database field to be changed

21 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Adding a New Data Source Open the Data Sources window Click the Add New Data Source link Follow the steps in the Data Source Configuration Wizard to create a connection to the database Slide 10- 21

22 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Deleting a Data Source Once created, it’s almost impossible to rename a data source Easier to delete and create a new data source than rename one A data source named Employees for example would be defined by a file named Employees.xsd To delete this data source: Select Employees.xsd file in Solution Explorer Press Delete Slide 10- 22

23 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Slide 10- 23 Binding Existing Dataset to DataGrid If you wish to bind a dataset already found in the Data Sources window Locate the table in the Data Sources window Drag table to an open area of a form Creates a data grid bound to the data source Automatically adds a navigation bar to form Set Dock property to Center Docking to make the data grid fill the entire form

24 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Slide 10- 24 Binding Individual Fields to Controls Use the dataset in the Data Sources window Select Details from the table drop-down list Drag table to an open area of a form Creates a separate control for each field Can also drag columns individually Text and numeric fields added as text boxes Yes/No fields added as checkboxes DateTime fields use DateTimePicker controls May wish to change some control properties Tutorial 10-3 & 10-4 demonstrate binding

25 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Slide 10- 25 Binding to List and Combo Boxes List and combo boxes are frequently used to supply a list of items for a user to select from Such lists are often populated from a table Must set two list/combo box properties DataSource identifies a table within a dataset DisplayMember identifes the table column to be displayed in the list/combo box If table column dragged onto a list/combo box Visual Studio creates the required dataset, table adapter, and binding source components Tutorial 10-5 demonstrates binding to a list box

26 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Slide 10- 26 Adding Rows to a Database Table A data source has a schema definition file (.xsd) An.xsd file was created in Tutorial 10-5 for the Members table DataTable created when data source added TableAdapter object created for the DataTable A TableAdapter object has an Insert method Used to add a new row to the database table Each column is an argument of the method Just provide the values for each argument MembersTableAdapter.Insert(10, “Hasegawa”, _ “Adrian”, “305-999-8888”, #5/15/2008#)

27 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Identity Columns Some database tables have an identity column Assigned a unique number by the database Occurs automatically for identity columns Thus no need to supply a value for this column Payments table uses an identity column So omit ID column value Supply Member_Id, Payment_Date, & Amount Tutorial 10-6 adds a row to the Payments table Slide 10- 27 PaymentsTableAdapter.Insert(5, #5/15/2008#, 50D)

28 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Slide 10- 28 Reading Dataset Rows with For-Each A For-Each statement can be used to iterate over all rows of a dataset Usually use a strongly typed dataset for this Sum Amount column of dsPayments dataset Dim row as PaymentsDataSet.PaymentsRow Dim decTotal as Decimal = 0 For Each row in Me.PaymentsDataSet.Payments.Rows decTotal += row.Amount Next Tutorial 10-7 demonstrates this technique

29 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Structured Query Language (SQL) 10.5 SQL Is a Standard Language for Working With Databases

30 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Slide 10- 30 The Select Statement Select retrieves rows from one or more tables in a database Basic form of Select for a single table is Select column-list From table column-list contains column names to select from table, each separated by a comma The following Select statement retrieves the ID and Salary fields from the SalesStaff table Select ID, Salary From SalesStaff

31 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Slide 10- 31 Column Names Use asterisk to select all columns in a table Select * From SalesStaff Unlike VB names, SQL columns can have embedded spaces If so, use square brackets around column names Select [Last Name], [First Name] From SalesStaff Better to avoid embedded spaces for this reason As operator can be used to rename columns Select Last_Name, Hire_Date As Date_Hired From Employees

32 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Slide 10- 32 Creating New Columns Sometimes useful to create a new column by appending existing columns together Create a Full_Name field from first and last name Select Last_Name + ‘, ‘ + First_Name as Full_Name From Members Creates a Full_Name field in the format last, first Can also be useful to create a new column by performing arithmetic operations Columns involved must be numeric Select ID, hrsWorked * hourlyRate As payAmount From Payroll Creates a payAmount column with gross pay

33 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Slide 10- 33 Sorting Rows with Order By Clause SQL Select has an optional Order By clause that affects the order in which rows appear Order by Last_Name, First_Name Displays rows in order by last name, then first Sort in reverse order (high to low) using Desc Order by Last_Name DESC Order By clause appears after From clause Select First_Name, Last_Name, Date_Joined From Members Order By Last_Name, First_Name Lists all members by last name, then first

34 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Slide 10- 34 Selecting Rows with Where Clause SQL Select has an optional Where clause that can be used to select (or filter) certain rows Where Last_Name = ‘Gomez’ Displays only rows where last name is Gomez Must be a defined column (in table or created) This example selects based on a created field Select Last_Name, hrsWorked * Rate As payAmount From Payroll Where payAmount > 1000 Order by Last_Name Selects those being paid more than $1,000

35 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Slide 10- 35 SQL Relational Operators SQL Where uses relational operators just like a VB If OperatorMeaning =equal to <>not equal to <less than <=less than or equal to >greater than >=greater than or equal to Betweenbetween two values (inclusive) Likesimilar to (match using wildcard) Example of Between operator: Where Hire_Date Between #1/1/1992# and #12/31/1999# Example of Like operator with % sign as wildcard: Where Last_Name Like ‘A%’

36 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Slide 10- 36 Compound Expressions SQL uses And, Or, and Not to create compound expressions Select all employees hired after 1/1/1990 and with a salary is greater than $40,000 Where (Hire_Date > #1/1/1990#) and (Salary > 40000) Select all employees hired after 1/1/1990 or with a salary is greater than $40,000 Where (Hire_Date > #1/1/1990#) or (Salary > 40000) Select employee names not beginning with A Where Last_Name Not Like ‘A%’

37 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Modifying a Query in a Data Source Dataset schema file contains an SQL query Created as part of schema file Named Fill, GetData() by default Right-click title bar of TableAdapter in schema Click Configure from pop-up Use Configuration Wizard to change simple queries Query Builder often used for complex queries Slide 10- 37

38 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Query Builder Visual Studio tool to work with SQL queries Consists of 4 sections or panes Diagram pane displays tables Grid pane displays query in spreadsheet form SQL pane shows actual SQL created Results pane shows data returned by query Slide 10- 38

39 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Adding a Query to a DataGridView Can add a new query as well as changing an existing one Right-click table adapter icon in component tray Select Add Query to display Search Criteria Builder Add Where clause Click New query name radio button enter a name for query Query made available from ToolStrip control Slide 10- 39

40 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Karate School Management Application 10.6 Create an Application that Works With the Karate School Database

41 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Karate School Startup Form Slide 10- 41 Menu Selections:  File Exit  Membership List All Find member Add new member  Payments All members One member

42 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Karate School Member Forms Slide 10- 42 All Members Form Add New Member Form Find Member by Last Name Form

43 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Karate School Payments Forms Slide 10- 43 Payments by All Members Form Payments by One Member Form

44 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Introduction to LINQ (Optional Topic) 10.7 Language Integrated Query

45 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley LINQ SQL allows you to query the data in a database. LINQ allows you to query data from many other sources. LINQ is built into Visual Basic. Slide 10- 45

46 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley LINQ Suppose we have the following array: The following statement uses LINQ to query the array for all values greater than 100: Slide 10- 46 Dim intNumbers() As Integer = {1, 101, 2, 102, 3, 103, 4, 104} Dim queryResults = From item In intNumbers _ Where item > 100 _ Select item

47 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley LINQ Slide 10- 47 Dim queryResults = From item In intNumbers _ Where item > 100 _ Select item This is the LINQ query. This object will hold the results of the LINQ query.

48 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley LINQ Slide 10- 48 Dim queryResults = From item In intNumbers _ Where item > 100 _ Select item For Each intNum As Integer In queryResults lstNumbers.Items.Add(intNum) Next This For Each loop adds each value of the queryResults object to a list box.

49 Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley LINQ Slide 10- 49 Dim queryResults = From item In intNumbers _ Where item > 100 _ Select item _ Order By item The Order By operator sorts the query results Dim queryResults = From item In intNumbers _ Where item > 100 _ Select item _ Order By item Descending Add the Descending key word to sort in descending order.


Download ppt "Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Slide 10- 1 STARTING OUT WITH Visual Basic 2008 FOURTH EDITION Tony Gaddis."

Similar presentations


Ads by Google