Jeremy Kingry, eBECS | ADVANCED SQL SERVER FOR ADMINS AND ANALYSTS
Course Overview SQL Server Management Studio (SSMS) Joins, INNER, OUTER, FULL Aggregates and Grouping Temp Tables
Course Overview Advanced SQL Functions SQL Create User SQL BACKUP, RESTORE SQL Jobs and Maintenance Plans
SQL JOINS - INNER JOIN Returns rows when there is a match between BOTH tables SELECT table1.column, table2.column FROM table1 INNER JOIN table 2 ON table1.key = table2.key
SQL Joins - INNER JOIN
SQL JOINS – LEFT OUTER JOIN Complete set of records from Table1, with the matching records (where available) in Table2 SELECT table1.column, table2.column FROM table1 LEFT JOIN table 2 ON table1.key = table2.key
SQL JOINS – LEFT OUTER JOIN
SQL JOINS – RIGHT OUTER JOIN Complete set of records from Table2, with the matching records (where available) in Table1 SELECT table1.column, table2.column FROM table1 RIGHT JOIN table 2 ON table1.key = table2.key
SQL JOINS – RIGHT OUTER JOIN
SQL JOINS – FULL OUTER JOIN Produces the set of all records in Table1 and Table2, with matching records from both sides where available SELECT table1.column, table2.column FROM table1 FULL JOIN table 2 ON table1.key = table2.key
SQL JOINS – FULL OUTER JOIN
SQL JOINS DEMO
AGGREGATE FUNCTIONS Aggregate functions perform a calculation on a set of values and return a single value. SELECT aggregate(column1) FROM table1
AGGREGATE FUNCTIONS AVG() - Returns the Average Value COUNT() - Returns the Number of Rows MAX() - Returns the Largest Value MIN() - Returns the Smallest Value SUM() - Returns the Sum STDEV() – Returns the Standard Deviation
AGGREGATE FUNCTIONS SELECT dg.StateProvinceName, SUM(sls.SalesAmount) FROM dbo.FactInternetSales AS sls INNER JOIN dbo.DimCustomer AS dc ON sls.CustomerKey = dc.CustomerKey INNER JOIN dbo.DimGeography AS dg ON dc.GeographyKey = dg.GeographyKey Column 'dbo.DimGeography.StateProvinceName' is invalid in the select list because it is not contained in either an aggregate function or the GROUP BY clause.
GROUP BY The GROUP BY statement is used in conjunction with the aggregate functions to group the result-set by one or more columns. SELECT dg.StateProvinceName, SUM(sls.SalesAmount) FROM dbo.FactInternetSales AS sls INNER JOIN dbo.DimCustomer AS dc ON sls.CustomerKey = dc.CustomerKey INNER JOIN dbo.DimGeography AS dg ON dc.GeographyKey = dg.GeographyKey GROUP BY dg.StateProvinceName
GROUP BY StateProvinceNameSalesAmount Alabama37.29 Alberta Arizona Bayern
HAVING and ORDER BY HAVING allows a “WHERE” type criteria for aggregate functions ORDER BY allows sorting query results
HAVING and ORDER BY SELECT dg.StateProvinceName, dg.EnglishCountryRegionName, SUM(sls.SalesAmount) AS SalesAmount FROM dbo.FactInternetSales AS sls INNER JOIN dbo.DimCustomer AS dc ON sls.CustomerKey = dc.CustomerKey INNER JOIN dbo.DimGeography AS dg ON dc.GeographyKey = dg.GeographyKey GROUP BY dg.StateProvinceName, dg.EnglishCountryRegionName HAVING SUM(sls.SalesAmount) > ORDER BY dg.EnglishCountryRegionName
AGGREGATE FUNCTIONS DEMO
TEMP TABLES Can Improve Performance Allows for Temporary Data Manipulation Reduces Table Locking Can be Indexed Can be Reference by More than one Query Identified with #
TEMP TABLES CREATE TABLE #tempCust ( CustomerKey INT, CustomerName VARCHAR(150) )
TEMP TABLES DEMO
ADVANCED SQL FUNCTIONS ROW_NUMBER – Returns sequential row numbers within a partition of a result set RANK – Rank for each row of a partition within a set NTILE – Splits the set into n tiles (quartile etc)
ADVANCED SQL FUNCTIONS DEMO
Users and Logins Creating a Login and User are one of the first primary functions of a dba. This procedure allows granting and revoking access to database objects to ensure a user can not only get to the data they need but they are also prevented from performing actions they should not be allowed to do.
Users and Logins 1.Login - grants or revokes server access 2.User - grants or revokes database access 3.Login can be SQL or Windows domain account 4.User must have a login 5.Login has one user per database
CREATE LOGIN AND USER DEMO
BACKUP Having a proper backup strategy is essential to ensuring uptime and safety of the data stored in MS SQL Server. Designing a proper strategy including backup types, timings, and storage options is essential for todays modern systems where downtime and lost data can cost millions.
BACKUP 1.How many hours a day do applications have to access the database? 2.How frequently are changes and updates likely to occur? 3.Are changes likely to occur in only a small part of the database or in a large part of the database? 4.How much disk space will a full database backup require?
Backup – Full Backup Backs up entire database Most reliable method but takes a long time Consumes a lot of space even compressed Simplest to restore (one step)
Backup – Differential Backup Backs up all changes since last full backup Must have at least one full backup before starting differential backups Are cumulative in nature so only have to restore latest full and latest diff backup Conserves space and time backing up
Backup – Transaction Log Backup Captures all changes written to the transaction log since last full or log backup Must have at least one full backup before starting log backups Allows backing up frequently enough to prevent large data losses Conserves space and time backing up
Backup – Tail Log Backup Works in event of corrupt database but the transaction log is still available Backs up the tail of the log from the last backup to the time of the error occurring Use only when a problem has occurred to minimize data loss
Backup – Backup Strategy Weekly full backup Nightly differential backups Transaction log backups every four hours Adjust for needs and volume
BACKUP BACKUP DATABASE { database_name } TO [ WITH { DIFFERENTIAL | [,...n ] } ]
RESTORE Once a database has been backed up you hope to never have to use it but if you do RESTORE is the way to recover the backup copy. Restore can be performed from the user interface or through the SQL Command RESTORE.
RESTORE RESTORE DATABASE { database_name } [ FROM [,...n ] ] [ WITH { [ RECOVERY | NORECOVERY | STANDBY = {standby_file_name } ] |, [,...n ] |, } [,...n ] ]
BACKUP AND RESTORE DEMO
SQL Jobs and Notifications 1.Ability to schedule tasks 2.Notify people on job status: a.Job Completes b.Job Fails c.Job Succeeds 3.Automate manual processes
Database Maintenance Plan 1.Workflow creation of maintenance tasks 2.Easy wizard driven creation 3.Performance tuning multiple databases 4.Manage backup tasks 5.Can clean up after itself
Additional Topics 1.SQL Logs (Management -> SQL Server Logs) 2.Standard Reports (Right Click DB and Choose Reports)
SQL JOB AND MAINTENANCE DEMO
QUESTIONS
46 #AXUGFocus CPE Credit Code: 53C2 Complete Surveys FINAL REMINDERS
47 #AXUGFocus Jeremy Kingry eBECS SPEAKER CONTACT INFO