Skip to main content

Understanding T-SQL

T-SQL is the term coined by Microsoft & Sybase collaboration. It's the proprietary extension of SQL of Microsoft & Sybase. T-SQL is the main RDBMS to manage & manipulate the data in sql server. Like SQL, you don't need to write strongly type T-SQL. SQL server will parse the T-SQL into sql then execute the parsed query on top of the relational database model.

Let's try to understand the T-SQL

1. SQL is a standard of ISO & ANSI. T-SQL is a dialect of SQL.
2. Every database vendors (oracle, sybase..) implement the dialects of SQL as the main language to handle data in their database. Therefore core language element is same across all the database vendors.
3. SQL is strongly typed checked. Every SQL statement should end with semicolon (" ; ")                 T-SQL: it's not mandatory to end the every statement with " ; " semicolon.                              e.g. "Let's say we've an employee table and we want to fetch all the records"                          Using SQL syntax ( semicolon is mandatory): following query will give compilation error "SELECT * FROM Employee"                                                                                                      Using T-SQL syntax ( semicolon is optional): same query will execute successfully "SELECT * FROM Employee "
4. SQL: to get the result set from underlying table or sub-query it's mandatory to have "SELECT", "FROM" & "" T-SQL: To get the result set only "SELECT" is the mandatory key-word. Let's say you want to see the current date. Using SQL: you've to take the help of other data source "SELECT FROM Employee WHERE 1 = 0; " Or some dummy table\view provided by your database vendors "SELECT FROM DUAL ; " Using T-SQL: "SELECT GetDate() "
5. As per relational model all the attributes should have some name. But using T-SQL we can get the result-set based on the expression or column levele sub-queries without any name "SELECT Id , FirstName + ' ' + MiddleName + ' ' + LastName FROM Employees "
6. According to relational model all attributes of result-set should have unique name. T-SQL allows the query to return result-set with duplicate column-names. T-SQL example: "SELECT e.Id , d.Id FROM Employees as e JOIN Department as d ON e.DepartmentId = d.Id "

Comments

Popular posts from this blog

EFCore - Collate function

Search in SQL server query is generally case insensitive (by default or based on database level collation). Suppose we have an employees table with a row having first-name column value as "My-First-Name", so if we want to do the case-sensitive search we have to explicitly use the related collate: In EF 5 (currently in Release Candidate version [RC.2.20475.6]) Collate function got introduced which helps us to use our specific collation based search.  C# with EF5 code sample: var employeeCaseSensitiveSearch = _dbContext.Employees .Where(x => EF.Functions.Collate(x.FirstName, "Latin1_General_CS_AS") == "my-first-name") .FirstOrDefault(); A related database query will be something like this: T-SQL: Case sensitive search (use specific collation e.g.: Latin1_General_CS_AS) SELECT * FROM dbo.Employees AS e WHERE e.FirstName Collate Latin1_General_CS_AS = 'my-first-name' Some of the useful CSharp function which g...

EFCore - Parallel db call on same dbContext

Practically there are multiple instances when we want to do parallel DB call which will save us some time. Like if we want to get a few employees details as well as users detail and if both entities are independent of each other better to go with a parallel call to fetch the details.  With the growing ORM usage and enhanced & optimized framework of like EFCore, in most of the application (related to C# development), we generally prefer to use EFCore. With EFCore if we try to use the same DB context to do parallel db call we are getting an error (... different thread using the same DbContext....). Because dbContext call is not thread-safe Parallel DB call on the same dbContext:  Code snipped: which will throw an error private void DbCallWithParallelCallOnSameDbContext() { try { var employeesTask = _dbContext.Employees.ToListAsync(); var usersTask = _dbContext.Users.ToListAsync(); ...

How to install Zen-coding plugin

As a web-developer, irrespective of the technologies (java, c-sharp, python, php e.t.c.…), we used to write CSS code to make our web-pages looks good if not at least we’re involved in write html codes. What if there is some tool to whom you give some instruction and that tool generates a good, well formatted html tags for you. These kind of coding is possible and known as “ Zen coding ” and there are lots of plug-in available from different vendors. We’re going to  discuss the steps to install this “zen-coding” plugin for “visual studio, eclipse, sublime-text & notepad++ in next few lines. Follow the below steps to install "zen-coding" plugin based on your editor.  Steps to install zen-coding plugin for (visual studio, eclipse, sublime-text,notepad++) -- -- For Visual Studio 1. Go to "Tools" -> "Extensions and Updates" 2. It'll open the "Extensions and Updates windows"    Select online form Left hand menu items ent...