SQL Server Database Coding Standards and Guidelines



Similar documents
DATABASE ADMINISTRATION SQL SERVER STANDARDS

FHE DEFINITIVE GUIDE. ^phihri^^lv JEFFREY GARBUS. Joe Celko. Alvin Chang. PLAMEN ratchev JONES & BARTLETT LEARN IN G. y ti rvrrtuttnrr i t i r

MOC 20461C: Querying Microsoft SQL Server. Course Overview

Duration Vendor Audience 5 Days Oracle End Users, Developers, Technical Consultants and Support Staff

Using SQL Server Management Studio

Oracle Database: SQL and PL/SQL Fundamentals

SQL Server. 1. What is RDBMS?

Consulting. Personal Attention, Expert Assistance

I. Naming Conventions

Oracle Database: SQL and PL/SQL Fundamentals NEW

Database Query 1: SQL Basics

SQL Server An Overview

SQL Server for developers. murach's TRAINING & REFERENCE. Bryan Syverson. Mike Murach & Associates, Inc. Joel Murach

Oracle Database: SQL and PL/SQL Fundamentals

PL / SQL Basics. Chapter 3

Introduction to Microsoft Jet SQL

Retrieving Data Using the SQL SELECT Statement. Copyright 2006, Oracle. All rights reserved.

2874CD1EssentialSQL.qxd 6/25/01 3:06 PM Page 1 Essential SQL Copyright 2001 SYBEX, Inc., Alameda, CA

Topics Advanced PL/SQL, Integration with PROIV SuperLayer and use within Glovia

T-SQL STANDARD ELEMENTS

Querying Microsoft SQL Server

Course ID#: W 35 Hrs. Course Content

SQL. Short introduction

Querying Microsoft SQL Server 20461C; 5 days

Structured Query Language. Telemark University College Department of Electrical Engineering, Information Technology and Cybernetics

3.GETTING STARTED WITH ORACLE8i

Course 20461C: Querying Microsoft SQL Server Duration: 35 hours

A basic create statement for a simple student table would look like the following.

Migrating from Sybase to SQL Server

Choosing a Data Model for Your Database

Performance Tuning for the Teradata Database

Data Tool Platform SQL Development Tools

SQL - QUICK GUIDE. Allows users to access data in relational database management systems.

Improving SQL Server Performance

Firebird. Embedded SQL Guide for RM/Cobol

PL/SQL Overview. Basic Structure and Syntax of PL/SQL

SQL Server Table Design - Best Practices

Instant SQL Programming

Database Programming with PL/SQL: Learning Objectives

In this session, we use the table ZZTELE with approx. 115,000 records for the examples. The primary key is defined on the columns NAME,VORNAME,STR

Querying Microsoft SQL Server Course M Day(s) 30:00 Hours

Oracle Database 12c: Introduction to SQL Ed 1.1

COMP 5138 Relational Database Management Systems. Week 5 : Basic SQL. Today s Agenda. Overview. Basic SQL Queries. Joins Queries

Chapter 5 More SQL: Complex Queries, Triggers, Views, and Schema Modification

Guide to SQL Programming: SQL:1999 and Oracle Rdb V7.1

Darshan Institute of Engineering & Technology PL_SQL

MOC QUERYING MICROSOFT SQL SERVER

Oracle SQL. Course Summary. Duration. Objectives

SQL Server 200x Optimizing Stored Procedure Performance

A Brief Introduction to MySQL

Oracle Database: SQL and PL/SQL Fundamentals NEW

Querying Microsoft SQL Server 2012

D61830GC30. MySQL for Developers. Summary. Introduction. Prerequisites. At Course completion After completing this course, students will be able to:

Introducing Microsoft SQL Server 2012 Getting Started with SQL Server Management Studio

Relational Database: Additional Operations on Relations; SQL

SQL Injection. The ability to inject SQL commands into the database engine through an existing application

SQL Query Performance Tuning: Tips and Best Practices

Handling Exceptions. Copyright 2006, Oracle. All rights reserved. Oracle Database 10g: PL/SQL Fundamentals 8-1

Maintaining Stored Procedures in Database Application

Oracle Database 10g Express

Guide to Upsizing from Access to SQL Server

Embedded SQL programming

Course 10774A: Querying Microsoft SQL Server 2012

Course 10774A: Querying Microsoft SQL Server 2012 Length: 5 Days Published: May 25, 2012 Language(s): English Audience(s): IT Professionals

Database Administration with MySQL

Recognizing PL/SQL Lexical Units. Copyright 2007, Oracle. All rights reserved.

How To Create A Table In Sql (Ahem)

MS SQL Performance (Tuning) Best Practices:

Netezza SQL Class Outline

2 SQL in iseries Navigator

Module 1: Getting Started with Databases and Transact-SQL in SQL Server 2008

A Comparison of Database Query Languages: SQL, SPARQL, CQL, DMX

Programming Database lectures for mathema

Database Design Standards. U.S. Small Business Administration Office of the Chief Information Officer Office of Information Systems Support

BCA. Database Management System

Introduction to the Oracle DBMS

Database Design Patterns. Winter Lecture 24

Writing Queries Using Microsoft SQL Server 2008 Transact-SQL

Data Compression in Blackbaud CRM Databases

Oracle Database 10g: Introduction to SQL

Duration Vendor Audience 5 Days Oracle Developers, Technical Consultants, Database Administrators and System Analysts

Toad for Oracle 8.6 SQL Tuning

news from Tom Bacon about Monday's lecture

PL/SQL MOCK TEST PL/SQL MOCK TEST I

Financial Data Access with SQL, Excel & VBA

Handling Exceptions. Copyright 2008, Oracle. All rights reserved.

Review your answers, feedback, and question scores below. An asterisk (*) indicates a correct answer.

In This Lecture. SQL Data Definition SQL SQL. Notes. Non-Procedural Programming. Database Systems Lecture 5 Natasha Alechina

Parameter Fields and Prompts. chapter

5. CHANGING STRUCTURE AND DATA

Writing Queries Using Microsoft SQL Server 2008 Transact-SQL

Review your answers, feedback, and question scores below. An asterisk (*) indicates a correct answer.

Using AS/400 Database Monitor To Identify and Tune SQL Queries

Writing Control Structures

Sybase Adaptive Server Enterprise

InterBase 6. Embedded SQL Guide. Borland/INPRISE. 100 Enterprise Way, Scotts Valley, CA

Transcription:

SQL Server Database Coding Standards and Guidelines http://www.sqlauthority.com Naming Tables: Stored Procs: Triggers: Indexes: Primary Keys: Foreign Keys: Defaults: Columns: General Rules: Rules: Pascal notation; end with an s Examples: Products, Customers Group related table names 1 Rules: sp<app Name>_[<Group Name >_]<Action><table/logical instance> Examples: sporders_getneworders, spproducts_updateproduct Rules: TR_<TableName>_<action> Examples: TR_Orders_UpdateProducts Notes: The use of triggers is discouraged Rules: IX_<TableName>_<columns separated by _> Examples: IX_Products_ProductID Rules: PK_<TableName> Examples: PK_Products Rules: FK_<TableName1>_<TableName2> Example: FK_Products_Orderss Rules: DF_<TableName>_<ColumnName> Example: DF_Products_Quantity If a column references another table s column, name it <table name>id Example: The Customers table has an ID column The Orders table should have a CustomerID column Do not use spaces in the name of database objects Do not use SQL keywords as the name of database objects In cases where this is necessary, surround the object name with brackets, such as [Year] Do not prefix stored procedures with sp_ 2 Prefix table names with the owner name 3 Structure Each table must have a primary key o In most cases it should be an IDENTITY column named ID Normalize data to third normal form o Do not compromise on performance to reach third normal form. Sometimes, a little denormalization results in better performance. Do not use TEXT as a data type; use the maximum allowed characters of VARCHAR instead In VARCHAR data columns, do not default to NULL; use an empty string instead Columns with default values should not allow NULLs As much as possible, create stored procedures on the same database as the main tables they will be accessing

Formatting Use upper case for all SQL keywords o SELECT, INSERT, UPDATE, WHERE, AND, OR, LIKE, etc. Indent code to improve readability Comment code blocks that are not easily understandable o Use single-line comment markers(--) o Reserve multi-line comments (/*....*/) for blocking out sections of code Use single quote characters to delimit strings. o Nest single quotes to express a single quote or apostrophe within a string For example, SET @sexample = 'SQL''s Authority' Use parentheses to increase readability o WHERE (color= red AND (size = 1 OR size = 2)) Use BEGIN..END blocks only when multiple statements are present within a conditional code segment. Use one blank line to separate code sections. Use spaces so that expressions read like sentences. o fillfactor = 25, not fillfactor=25 Format JOIN operations using indents o Also, use ANSI Joins instead of old style joins 4 Place SET statements before any executing code in the procedure. Coding Optimize queries using the tools provided by SQL Server 5 Do not use SELECT * Return multiple result sets from one stored procedure to avoid trips from the application server to SQL server Avoid unnecessary use of temporary tables o Use 'Derived tables' or CTE (Common Table Expressions) wherever possible, as they perform better 6 Avoid using <> as a comparison operator o Use ID IN(1,3,4,5) instead of ID <> 2 Use SET NOCOUNT ON at the beginning of stored procedures 7 Do not use cursors or application loops to do inserts 8 o Instead, use INSERT INTO Fully qualify tables and column names in JOINs Fully qualify all stored procedure and table references in stored procedures. Do not define default values for parameters. o If a default is needed, the front end will supply the value. Do not use the RECOMPILE option for stored procedures. Place all DECLARE statements before any other code in the procedure. Do not use column numbers in the ORDER BY clause. Do not use GOTO. Check the global variable @@ERROR immediately after executing a data manipulation statement (like INSERT/UPDATE/DELETE), so that you can rollback the transaction if an error occurs o Or use TRY/CATCH Do basic validations in the front-end itself during data entry Off-load tasks, like string manipulations, concatenations, row numbering, case conversions, type conversions etc., to the front-end applications if these operations are going to consume more CPU cycles on the database server Always use a column list in your INSERT statements. o This helps avoid problems when the table structure changes (like adding or dropping a column).

Minimize the use of NULLs, as they often confuse front-end applications, unless the applications are coded intelligently to eliminate NULLs or convert the NULLs into some other form. o Any expression that deals with NULL results in a NULL output. o The ISNULL and COALESCE functions are helpful in dealing with NULL values. Do not use the identitycol or rowguidcol. Avoid the use of cross joins, if possible. When executing an UPDATE or DELETE statement, use the primary key in the WHERE condition, if possible. This reduces error possibilities. Avoid using TEXT or NTEXT datatypes for storing large textual data. 9 o Use the maximum allowed characters of VARCHAR instead Avoid dynamic SQL statements as much as possible. 10 Access tables in the same order in your stored procedures and triggers consistently. 11 Do not call functions repeatedly within your stored procedures, triggers, functions and batches. 12 Default constraints must be defined at the column level. Avoid wild-card characters at the beginning of a word while searching using the LIKE keyword, as these results in an index scan, which defeats the purpose of an index. Define all constraints, other than defaults, at the table level. When a result set is not needed, use syntax that does not return a result set. 13 Avoid rules, database level defaults that must be bound or user-defined data types. While these are legitimate database constructs, opt for constraints and column defaults to hold the database consistent for development and conversion coding. Constraints that apply to more than one column must be defined at the table level. Use the CHAR data type for a column only when the column is non-nullable. 14 Do not use white space in identifiers. The RETURN statement is meant for returning the execution status only, but not data. Reference: 1) Group related table names: Products_USA Products_India Products_Mexico 2) The prefix sp_ is reserved for system stored procedures that ship with SQL Server. Whenever SQL Server encounters a procedure name starting with sp_, it first tries to locate the procedure in the master database, then it looks for any qualifiers (database, owner) provided, then it tries dbo as the owner. Time spent locating the stored procedure can be saved by avoiding the "sp_" prefix. 3) This improves readability and avoids unnecessary confusion. Microsoft SQL Server Books Online states that qualifying table names with owner names helps in execution plan reuse, further boosting performance. 4) False code: SELECT * FROM Table1, Table2 WHERE Table1.d = Table2.c True code: SELECT * FROM Table1 INNER JOIN Table2 ON Table1.d = Table2.c

5) Use the graphical execution plan in Query Analyzer or SHOWPLAN_TEXT or SHOWPLAN_ALL commands to analyze your queries. Make sure your queries do an "Index seek" instead of an "Index scan" or a "Table scan." A table scan or an index scan is a highly undesirable and should be avoided where possible. 6) Consider the following query to find the second highest offer price from the Items table: SELECT MAX(Price) WHERE ID IN ( SELECT TOP 2 ID ORDER BY Price Desc ) The same query can be re-written using a derived table, as shown below, and it performs generally twice as fast as the above query: SELECT MAX(Price) FROM ( SELECT TOP 2 Price ORDER BY Price DESC ) 7) This suppresses messages like '(1 row(s) affected)' after executing INSERT, UPDATE, DELETE and SELECT statements. Performance is improved due to the reduction of network traffic. 8) Try to avoid server side cursors as much as possible. Always stick to a 'set-based approach' instead of a 'procedural approach' for accessing and manipulating data. Cursors can often be avoided by using SELECT statements instead. If a cursor is unavoidable, use a WHILE loop instead. For a WHILE loop to replace a cursor, however, you need a column (primary key or unique key) to identify each row uniquely. 9) You cannot directly write or update text data using the INSERT or UPDATE statements. Instead, you have to use special statements like READTEXT, WRITETEXT and UPDATETEXT. So, if you don't have to store more than 8KB of text, use the CHAR(8000) or VARCHAR(8000) datatype instead. 10) Dynamic SQL tends to be slower than static SQL, as SQL Server must generate an execution plan at runtime. IF and CASE statements come in handy to avoid dynamic SQL. 11) This helps to avoid deadlocks. Other things to keep in mind to avoid deadlocks are: Keep transactions as short as possible. Touch the minimum amount of data possible during a transaction. Never wait for user input in the middle of a transaction. Do not use higher level locking hints or restrictive isolation levels unless they are absolutely needed. 12) You might need the length of a string variable in many places of your procedure, but don't call the LEN function whenever it's needed. Instead, call the LEN function once and store the result in a variable for later use.

13) IF EXISTS (SELECT 1 WHERE ID = 50) Instead Of: IF EXISTS (SELECT COUNT(ID) WHERE ID = 50) 14) CHAR(100), when NULL, will consume 100 bytes, resulting in space wastage. Preferably, use VARCHAR(100) in this situation. Variable-length columns have very little processing overhead compared with fixed-length columns.