Download presentation
Presentation is loading. Please wait.
Published byDebra Hollie Lynch Modified over 9 years ago
1
SQL Views Chapter 3A DAVID M. KROENKE and DAVID J. AUER DATABASE CONCEPTS, 4 th Edition
2
Appendix Objectives Learn basic SQL statements for creating views Learn basic SQL statements for using views Understand the reasons for using views KROENKE and AUER - DATABASE CONCEPTS (4th Edition) © 2010, 2008 Pearson Prentice Hall 3A-2
3
SQL Views A SQL view is a virtual table that is constructed from other tables or views A view has no data of its own, but uses data stored in tables or other views Views are created using SQL SELECT statements Views are used in other SELECT statements just as if they were a table The SQL statements that create the views may not contain an ORDER BY clause If the results of a query using a view need to be sorted, the sort order must be provided by the SELECT statement that processes the view KROENKE and AUER - DATABASE CONCEPTS (4th Edition) © 2010, 2008 Pearson Prentice Hall 3A-3
4
SQL CREATE VIEW Statement The SQL CREATE VIEW statement is used to create view structures. CREATE VIEW ViewName AS {SQL SELECT statement}; KROENKE and AUER - DATABASE CONCEPTS (4th Edition) © 2010, 2008 Pearson Prentice Hall 3A-4
5
SQL CREATE VIEW Example CREATE VIEW EmployeePhoneView AS SELECT FirstName, LastName, Phone AS EmployeePhone FROM EMPLOYEE; KROENKE and AUER - DATABASE CONCEPTS (4th Edition) © 2010, 2008 Pearson Prentice Hall 3A-5
6
Creating a SQL View in SQL Server 2008 KROENKE and AUER - DATABASE CONCEPTS (4th Edition) © 2010, 2008 Pearson Prentice Hall 3A-6
7
Creating a SQL View MySQL 5.x KROENKE and AUER - DATABASE CONCEPTS (4th Edition) © 2010, 2008 Pearson Prentice Hall 3A-7
8
Using an SQL CREATE Once the view is created, it can be used in the FROM clause of SELECT statements just like a table. SELECT * FROM EmployeePhoneView ORDER BY LastName; KROENKE and AUER - DATABASE CONCEPTS (4th Edition) © 2010, 2008 Pearson Prentice Hall 3A-8
9
Using the EmployeePhoneView in SQL Server 2008 KROENKE and AUER - DATABASE CONCEPTS (4th Edition) © 2010, 2008 Pearson Prentice Hall 3A-9
10
Using the EmployeePhoneView in MySQL 5.X KROENKE and AUER - DATABASE CONCEPTS (4th Edition) © 2010, 2008 Pearson Prentice Hall 3A-10
11
Some Uses for SQL Views KROENKE and AUER - DATABASE CONCEPTS (4th Edition) © 2010, 2008 Pearson Prentice Hall Hide columns or rows Display results of computations Hide complicated SQL syntax Layer built-in functions C-11
12
Using SQL Views: Hide columns or rows I CREATE VIEW BasicDepartmentDataView AS SELECT DepartmentName, Phone AS DepartmentPhone FROM DEPARTMENT; SELECT * FROM BasicDepartmentDataView ORDER BY DepartmentName; KROENKE and AUER - DATABASE CONCEPTS (4th Edition) © 2010, 2008 Pearson Prentice Hall 3A-12
13
Using SQL Views: Hide columns or rows II CREATE VIEW MarkingDepartmentProjectView AS SELECT ProjectID, Name AS ProjectName, MaxHours, StartDate, EndDate FROM PROJECT WHERE Department = 'Marketing'; SELECT * FROM MarkingDepartmentProjectView ORDER BY ProjectID; KROENKE and AUER - DATABASE CONCEPTS (4th Edition) © 2010, 2008 Pearson Prentice Hall 3A-13
14
Using SQL Views: Display results of computations – SQL Statement CREATE VIEW ProjectHoursToDateView AS SELECT PROJECT.ProjectID, Name AS ProjectName, MaxHours AS ProjectMaxHours, SUM(HoursWorked) AS ProjectHoursWorkedToDate FROM PROJECT, ASSIGNMENT WHERE PROJECT.ProjectID = ASSIGNMENT.ProjectID GROUP BY PROJECT.ProjectID; KROENKE and AUER - DATABASE CONCEPTS (4th Edition) © 2010, 2008 Pearson Prentice Hall 3A-14
15
Using SQL Views: Display results of computations – Results SELECT * FROM ProjectHoursToDateView ORDER BY PROJECT.ProjectID; KROENKE and AUER - DATABASE CONCEPTS (4th Edition) © 2010, 2008 Pearson Prentice Hall 3A-15
16
Using SQL Views: Hide complicated SQL syntax – SQL Statement CREATE VIEW EmployeeProjectHoursWorkedView AS SELECT Name, FirstName, LastName, HoursWorked FROM EMPLOYEE AS E JOIN ASSIGNMENT AS A ON E.EmployeeNumber = A.EmployeeNumber JOIN PROJECT AS P ON A.ProjectID = P.ProjectID; KROENKE and AUER - DATABASE CONCEPTS (4th Edition) © 2010, 2008 Pearson Prentice Hall 3A-16
17
Using SQL Views: Hide complicated SQL syntax – Results SELECT * FROM EmployeeProjectHoursWorkedView; KROENKE and AUER - DATABASE CONCEPTS (4th Edition) © 2010, 2008 Pearson Prentice Hall 3A-17
18
Using SQL Views: Layering Computations and Built-in Functions 1 st SQL Statement CREATE VIEW ProjectHoursToDateView AS SELECT PPOJECT.ProjectID, Name AS ProjectName, MaxHours AS ProjectMaxHours, SUM(HoursWorked) AS ProjectHoursWorkedToDate FROM PROJECT, ASSIGNMENT WHERE PROJECT.ProjectID = ASSIGNMENT.ProjectID GROUP BY PROJECT.ProjectID; KROENKE and AUER - DATABASE CONCEPTS (4th Edition) © 2010, 2008 Pearson Prentice Hall 3A-18
19
Using SQL Views: Layering Computations and Built-in Functions 2 nd SQL Statement CREATE VIEW ProjectsOverAllotedMaxHoursView AS SELECT ProjectID, ProjectName, ProjectMaxHours, ProjectHoursWorkedToDate FROM ProjectHoursToDateView WHERE ProjectHoursWorkedToDate > ProjectMaxHours; KROENKE and AUER - DATABASE CONCEPTS (4th Edition) © 2010, 2008 Pearson Prentice Hall 3A-19
20
Using SQL Views: Layering Computations and Built-in Functions Results SELECT ProjectID, ProjectName, ProjectMaxHours, ProjectHoursWorkedToDate, (ProjectHoursWorkedToDate - ProjectMaxHours) AS HoursOverMaxAllocated FROM ProjectsOverAllotedMaxHoursView ORDER BY ProjectID; KROENKE and AUER - DATABASE CONCEPTS (4th Edition) © 2010, 2008 Pearson Prentice Hall 3A-20
21
SQL Views End of Presentation on Chapter 3A DAVID M. KROENKE and DAVID J. AUER DATABASE CONCEPTS, 4 th Edition
22
All rights reserved. No part of this publication may be reproduced, stored in a retrieval system, or transmitted, in any form or by any means, electronic, mechanical, photocopying, recording, or otherwise, without the prior written permission of the publisher. Printed in the United States of America. Copyright © 2010 Pearson Education, Inc. Publishing as Prentice Hall
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.