SQL Full Course | SQL Tutorial For Beginners | Learn SQL (Structured Query Language) | Edureka

Estimated read time: 1:20

    Learn to use AI like a Pro

    Get the latest AI workflows to boost your productivity and business performance, delivered weekly by expert consultants. Enjoy step-by-step guides, weekly Q&A sessions, and full access to our AI workflow archive.

    Canva Logo
    Claude AI Logo
    Google Gemini Logo
    HeyGen Logo
    Hugging Face Logo
    Microsoft Logo
    OpenAI Logo
    Zapier Logo
    Canva Logo
    Claude AI Logo
    Google Gemini Logo
    HeyGen Logo
    Hugging Face Logo
    Microsoft Logo
    OpenAI Logo
    Zapier Logo

    Summary

    In this comprehensive SQL course by Edureka, viewers are introduced to the foundational concepts of SQL, including data definition and manipulation language commands, normalization, RDBMS properties, and types of constraints. The tutorial delves into creating, altering, and deleting database objects, as well as data retrieval using SQL commands. Key aspects such as SQL operators and joins, inbuilt functions, and creating advanced database objects like stored procedures, functions, and triggers are discussed. Ideal for beginners, it offers a structured approach to mastering SQL.

      Highlights

      • Introduction to relational database management systems (RDBMS) 📚
      • How to normalize databases for better performance ✅
      • Creating, altering, and deleting database objects in SQL 🛠️
      • Handling data with SQL's data manipulation language commands 📈
      • Advanced topics: SQL joins, inbuilt functions, and triggers 🔄

      Key Takeaways

      • Understanding SQL basics is essential for database management 🧠
      • Normalization helps maintain data consistency in databases ✔️
      • Master different types of joins to manipulate data efficiently 🔗
      • Learn to create stored procedures for enhanced database operations 🚀
      • SQL functions can simplify complex data queries 📊

      Overview

      SQL is a powerful tool for managing and manipulating databases. This course by Edureka provides a thorough introduction for beginners interested in mastering SQL and database operations. It starts with foundational concepts like RDBMS and data normalization, ensuring that viewers grasp the basics before moving on.

        The session explores various SQL commands and their practical applications, such as data definition language (DDL) and data manipulation language (DML). It highlights the importance of joins and constraints, offering real-world use cases to understand their relevance.

          Advanced topics such as creating stored procedures, functions, and triggers are covered, allowing learners to gain in-depth knowledge. Whether you're altering existing databases or fetching complex data, this course offers the tools needed for effective database management.

            SQL Full Course | SQL Tutorial For Beginners | Learn SQL (Structured Query Language) | Edureka Transcription

            • 00:00 - 00:30 Hi Guys. Welcome to this interesting session on SQL Full Course. So in this we'll mainly understand the different concepts related to SQL. So without wasting any further time, Let's take a look at the topics for today's session. So we'll start today's session by understanding the data definitions language commands in which we'll understand what is relational database management system.
            • 00:30 - 01:00 How to normalize your database management systems, how to create, delete and alter database objects. And also get an understanding about the different types of constraints present in database such as create, alter and delete. Once you understand the data definition language commands, the next topic would be the data manipulation commands. So in the data manipulation language commands would basically understand how to enter and update the data in existing tables using SQL commands. Apart from that, you will also understand how to delete data from single tables, and also how to fetch and show the data from databases
            • 01:00 - 01:30 using various kinds of commands. And finally we'll end this topic with the SQL operators such as comparison, logical, and so on to get an understanding of how you can play around with your databases. After you get an understanding about the data manipulation commands. We'll the next get into how to retrieve data from multiple tables. So in this part of the session, you'll basically understand the different types of joints, present in SQLs, that is the inner left, right and cross. And after you understand the joints, the next topic would be the inbuilt functions in SQL. So in this topic,
            • 01:30 - 02:00 we'll basically look into how to use the built in functions and SQL and also understand what is group by clause and having clause. And finally, we'll end the session by understanding how to create advanced database objects in which we'll mainly focus on the store procedures, functions, and triggers. So I hope the agenda was clear to you guys. So today we have a special guest, Anil, who's gonna take the session forward. So, over to you Anil. Hello guys, this is Anil from Edureka, and welcome to SQL Full Course.
            • 02:00 - 02:30 So let's start with what is RDBMS. So as you can see on the screen, RDBMS basically stands for, relation database management system. So basically in RDBMS we'll define the data, or we store the data in to collection of tables, which is a two dimensional database. So as I mentioned, it's stored the data in tables and the tables have rows and columns. So some of the properties of relational database, as you can see in the screens, it's Values are Atomic, Column Values are of the same thing.
            • 02:30 - 03:00 Columns are undistinguished. Sequence of row, how the data is stored is of insignificance. They can store the data in any sequence and all the columns have a unique name. Most of the database which we know as of the like Oracle, MySQL, all are relation database management system, and SQL is the common query language for all database management systems. As we discussed that RDBMS is basically we store data into collection of tables.
            • 03:00 - 03:30 So then we store the data and collection of tables, it is very important that data is organized properly. So we applied the concept of normalization for the better management of DBMS. As you can see, normalization is a process of organizing data to avoid duplications and redundancy. So we apply normalization to database systems to minimize duplicate data, data modification issues to simplify queries because we don't want to run into complex queries
            • 03:30 - 04:00 when we fetch the information from database. If our database is not properly normalized, then we may face issues when we try to update any records in the database. There are various rules for normalizations, but generally we follow third normal form in order to organize our data efficiently. So we have first NF that is first normal form, second normal form, third normal form and the end we have Boyce and Codd Normal Forms,
            • 04:00 - 04:30 But it is enough and it's sufficient if we satisfied up to third normal form. Okay, so what is first normal form? So as for the first normal form, as you can see on the screen that each set of column must have a unique value. It means every column should have a single value in it. On the screen as you can see in the left hand side we have our students table and this table has three columns, student, age and course. But in the first row as you are seeing on screen
            • 04:30 - 05:00 that we have two values for a single column: CR001 and CR005. CR001 and CR005. Because of the multiple values in a single column, it is violating first normal form. So in order to satisfy first normal form, we have to split the row into multiple rows. So after I splitting in the right hand side you can see that we have split the row first into two rows, Adam 15 and the course is CR001. Adam 15 and the course is CR001, and another ways, Adam 15 CR005.
            • 05:00 - 05:30 So we have split the multiple values into single values and now our table is satisfying the first normal form. Let's move to the second normal form, as per the second normal form, there must not be any partial dependency of any column on primary key. So first of all, what is primary key? So primary key is a key which helps us in identifying a unique row in a table. Most of the time,
            • 05:30 - 06:00 the primary key is a single column, but sometimes more than one column can be combined to create a single primary key. Now as you can see on the screen, our table was not satisfying the first normal form. So we have split into two rows. So in this table we cannot consider student as a primary key because as I mentioned that the very first prerequisite of a primary key is that no two row can have the same value for that key. Here in the first column strength, we have Adam as two entries of Adam.
            • 06:00 - 06:30 So a student is not a primary key. So in order to make a primary key, sometimes big continent, or add one more column to our primary key. So in our case we have student and goes as a primary key. So our primary key generally contains a single column, but sometimes aspect of business requirement. We may add multiple columns in the primary key. So in this table, student and course together have a primary key.
            • 06:30 - 07:00 Now, second normal form states that in order for a table to be in satisfy the second normal form, it first satisfy the first normal form. And after that all the columns should depends only on the primary key and they should not partially dependent on the primary key. So as of now, and you can see in this table that column age, only depend on the student and not on the course. So age is partially dependent on the primary key because our primary key has student and goes in it.
            • 07:00 - 07:30 So that is the reason it is not satisfying second normal form. So in order to make it satisfy the second normal form, we have split the table into two tables. Now the first table we have student as a one column and age as another column. So age is now dependent on the student as well as in the second table we have student and course. So the course is also dependent on the student. So now the columns are not partially dependent on primary. So in order to satisfy the second normal form,
            • 07:30 - 08:00 our tables should first satisfy the first normal form as we can see that no columns has a multiple values in it so it is satisfying first normal form. And the second normal form states that any non-key columns should not partially dependent on primary key. So in this age is dependent on student as well as schools is dependent on student. So our table is satisfying the second normal form. Let's move to third normal form. third normal forms applies that every non-prime attribute
            • 08:00 - 08:30 of a table must be dependent on primary key. Or we can say that there should not be a case that a non-prime attribute is determined by another non-prime attribute . So let's take a example here. So this example will help us understand what the statement means. So we have a student table here and these are the columns: student id, student name, date of birth, street, city, state and zip. So we have seven columns in our student table.
            • 08:30 - 09:00 And in this table their student id is the primary key. So a third normal forms states that all columns should be dependent on the primary key only. So if you'll see street, city and state, street, city and state, these three columns are basically dependent on the zip, zip code of that area and not on that student. So that is the reason it is not satisfying the third normal form. So in order to make it
            • 09:00 - 09:30 satisfy the third normal form, we have again split the table into two tables. So one table we have student id, student name, date of birth and zip. And the address table we have zip street, city and street. So this is how guys we design our database. So it is very important when you design your database, when you decide that, okay these are the tables which we are going to create. So you need to first apply all the normal forms. So database will be more efficient,
            • 09:30 - 10:00 it will allow you to remove any redundant data or duplicate data from our database. So I hope the first, second and third normal forms are clear. And the important part here guys is that the third normal form, for example, any normal form should satisfy the previous normal form. It cannot be the case that my table is satisfying the third normal form, but it will fail the first normal form. So second normal form, it has to be satisfied the first normal form and the third normal form, it has to satisfy the second normal form.
            • 10:00 - 10:30 After we know the best practices to design our database, we'll discuss about the Data Types in SQL. When you store the data in our database, we know that what kind of information you are storing. It can be integer value, it can be strings or characters and we can store the salary, it can be monitoring data. For example, money or the currencies. We can store the data in terms of date and time when some action has happened or when an order is made or when we purchased certain items,
            • 10:30 - 11:00 we can store the binary string. For example, we can store images or we can store pictures in our databases, so the store in the binary form and so on. So basically we would define that there are four broad categories of data types in SQL. What the the character string, numeric values, date and time, and binary. So let's discuss about the character string data type. So we have these six type of string data types. One is char(n) and and then we have nchar(n),
            • 11:00 - 11:30 varchar(n), varchar(max) and nvarchar(n) and nvarchar(max). So these slides are self explanatory and it mentioned that it basically depends upon what is the size of data we can store for these data types. Apart from this guys, we have this varchar, nchar. So var basically stand for variable length character. And this n stands for Unicode character. So if you want to store the data, for example, all non-English data,
            • 11:30 - 12:00 I want to store some Japanese languages or in some Arabic keywords, then we basically use nchar or nvarchar, basically stores for Unicode characters. Character is a static, for example, if I defined character 20 and I'm trying to store our values of five corrector then in order to match that defined data type the right side of my data type, will be embedded with the blank spaces. So we decide basically whether we want a variable character or the static character.
            • 12:00 - 12:30 We have numeric data type, so numeric data type we have eight tiny, small and big. And so there's this tiny small, big, and it all depends upon the size of the data we want to store in our database. So as for our business requirement, how small or the big data we want to student database, we decide our data type. If you want to store the data in terms of currencies that we have money. Again money based upon what is the size
            • 12:30 - 13:00 of a new data we want to store in money data type. We have money in small money, we have decimal in the decimal, as you can see we have two parameters, P and S. Which basically stands for precision and scale. So the maximum precision is 38 digits. Again, we have numeric float and real. So these data if you will see, are basically more in line with the database of the basic language like cc plus, plus we have all these data types.
            • 13:00 - 13:30 Data and time is one of the most important data type guys. So we have different format of data types available for this section, we have date. So as you can see the date data types store states between Jan 1, 001 and December 31st, 999. between Jan 1, 001 and December 31st, 999. And its length is basically have three bytes and if you want to store time along with date then we have datetime. So in the datetime also we have two different date. One is date and one datetime two.
            • 13:30 - 14:00 Also depends upon whether we want to store the time in milliseconds, or you want to include the nanosecond part also. We have the small datetime and if you want to store only the time component, not the date part, then we can use the data type time. And in the end we have binary data type. So we have, as we discussed, we have with store a single bit of data. For example, if you want to have true and false zero and one we have binary stores and bytes of binary data.
            • 14:00 - 14:30 We have varbinary, varbinary(max), so we generally use varbinary(max) when we try to save data. For example, some images and pictures where we don't know about the site. It can change dynamically run time of big data, so we generally use varbinary. So I hope you are clear with the basic data types. So so far we have discussed what RDBMS is, how we design a better database management systems by applying the rules of normalization. We discussed three normalization forms,
            • 14:30 - 15:00 first NF and second NF and three NF and then we discuss the order that various data types which we can use to store our data in database system. After that we'll discuss about the various SQL statements. So generally in SQL we write queries. So our queries falls into four broad categories. One is data definition language. One is data manipulation language. We have data control language and we have transaction control language. So data definition language
            • 15:00 - 15:30 that we are going to discuss in the coming slides and we'll discuss about the schema of our database that how we create the database object, how we modify our database objects. And if not required, how we can drop or delete those database objects. In data manipulation language we do not manipulate the database schema. We basically manipulate that data which is stored in our database objects. So these are the four basic commands as you can see,
            • 15:30 - 16:00 we have select commands, we have insert, update and delete commands. So we modify the data, we tried the data, we update the data and if not required we delete the data. So the basic difference between deleting the database objects and data is that when we delete the database is there just we are deleting that data insight object. And then we have data control language. So include command such as grant, mostly concerned with rights and permissions.
            • 16:00 - 16:30 For example, a new member has joined in your team and you want to give the permission so that he can play around with your database. Then you have to grant some permission to the new user. If someone is leaving your team or leaving your projects. In that case you no longer want him to the database. So in that case, you're gonna revoke the permissions with a person having on the database. So we use grant and revoke commands, and this falls on the data control language. Transaction control language is basically
            • 16:30 - 17:00 when we commit or the rollback the data. When we are savings the data and we might be constantly saving the data in multiple tables. And while saving the data, if there is an error in any one of the table, we basically rollback the entire data. So we use rollback or commit commands to save or roll back all the changes which you made to the database. So this falls on the transaction control language. So as discussed in this module, we'll be discussing more about
            • 17:00 - 17:30 the data definition language, where we discuss about the schema of our database. So in order to start with, we have to first create our database and in the database again, then we'll create multiple different database objects like functions, store procedures, tables. So to start with the very first step is that we need to create a database object. So in order to understand database, database is nothing but it is an organized collection of the data. When I say organize the data is stored in multiple tables.
            • 17:30 - 18:00 The tables are related to each other based upon the various business conditions. So these business requirements and the main purpose of databases basically to operate large amount of information's by storing, by retrieving and manipulating and managing the data. So I'll show you how to create a new database. So as I mentioned earlier, that after installation of Microsoft SQL server, we have in order to access the server,
            • 18:00 - 18:30 they need to open Microsoft SQL Server Management Studio. So if you'll search for SSMS that is SQL server management studio. So this is how the I can look like and you have to open it. Once you open it, the screen will look like this. So on the left hand side you have object explorer and these are the various tool box. So you can go through these toolboxes as a self-explanatory. So in order to create new database we have to click on new query
            • 18:30 - 19:00 and it is a straight forward command to create a database. Let me increase the font size for better visibility. So we have to just write create database and the name of the database. So by default, as you can see, these are the databases here. These are the custom in which we have created, Eduraka, empTB. These were the system database. And once we install Microsoft SQL server, this database will be presented by default.
            • 19:00 - 19:30 So that command is create then database and the name of the database. So all you have to do is, and the name of the database. For example, I'm creating test one. So to execute this command, either you can select this query, and then can press F5 audit after selection, you can click on execute button here. So if there's no error while executing the command, you will get this message that command completed successfully. And in order to check whether the database has been created successfully or not,
            • 19:30 - 20:00 we can go ahead and refresh our database. So in order to refresh it, you have to right click the databases and just click refresh here. As you can see that test one database has been created. You can expand this and you can see by default in any database you will see these categories will be present. But under tables, these are the system tables because we have not created anything custom as of now. So whatever is present and the test one database as of now is out of box.
            • 20:00 - 20:30 So creation of database is first step to manage the entire database objects or to start playing with the data. After creation of a database we need to create some tables in it because table is where we store our data. And all other database objects are basically based on SQL tables. As you can see on the screen, the basic syntax to create the table is, create table. Then we have table name, what is the name you want to give it to our table.
            • 20:30 - 21:00 Then we define what the columns we required in our tables and followed by the data type. We've already discussed what are the various data types present in SQL. So based upon our business requirement, based on our requirement we defined kind of data type a column should have. So let me execute this command here. So let's, let's create our table and see how we can create the table. So in order to save time,
            • 21:00 - 21:30 let me crate one table for you guys. So we can delete this line or we can create a new query window. Let me again increase the font size. So as, as you can see, we have to follow, this syntax is very important. And the best part is that it is not case sensitive. It is not that I have to give everything in cap. I can provide this small bit font size or it is not case sensitive. So we have provide create table and name of your table,
            • 21:30 - 22:00 it can be any name. So as of now it's giving the test table and these are the columns which I'm defining in my table. Employee id, INT primary key. We'll discuss about what are the keys in the very end of this module, we'll discuss more of the various constant, how we can create a primary key, what is a use of it, what is foreign key. So we create when columns as of now I'm not making it primary key and just defining the data type.
            • 22:00 - 22:30 So for employee id I'm defining the data as INT, then I'm defining the last name. So let's make it more readable and defining it as a last name in one column and first name as another column. And I'm defining the data type as varchar and I'm defining it's not null that it is required to have a value in this. So if we want that certain column are mandatory, while we're inserting the data, then we have to make them not null. By default it is null.
            • 22:30 - 23:00 So we have to explicitly write this keyword, not null, if we want to make those column mandatory. Semi column in the end is not required. It is not mandatory in Microsoft SQL server. But if you will write this query in MySQL, then semi-colon the end of statement is required. So I'll execute this command and if everything runs successfully, there is no error while executing this command, then we'll get this message command completed successfully.
            • 23:00 - 23:30 So in order to see, okay, now guys, important part. If I go to, if I'll see that, whether the table has been created in the database, which we have created. So let me refresh our database and see the table is not here. So it is very important guys that when we create the table, we have to ensure under which database we are creating this table. So this window on the top will specify that which database we are using to execute these commands.
            • 23:30 - 24:00 So in order to create the database in test one database, which we have created, we have to select this. If we don't want to select this, then we have the write the keyboard, use test one. So this ensure that we are creating this table under this database test one. Now if I execute this command, executed successfully, and if I refresh my database now I can see the test table has been created in it.
            • 24:00 - 24:30 So this is how we create the tables, so you can expand this table and can see various columns in it. So we have created three columns. So since I have not mentioned as I mentioned that if I am not provide whether this column needs information, yes or not. Then by default it will be marked as a null, means it is optional to provide values for this column. So we have to explicitly write not null if you want to make the column mandatory, like a table can have many columns,
            • 24:30 - 25:00 So based on business requirements we add the columns in it and then we defined the data type of the columns. I hope creation of the table is clear to all of you. Let's move to the next point. So you can try this example guys, where you can create a new table, employees. So this has employee id one of column and its data type is numeric four. First name, last name, manager id, hire date. Since it is a date, we have defined the data type as date here.
            • 25:00 - 25:30 Then we have job id and department number. Okay, so we have created a table. Now there might be a scenario that we might need to modify our table. We need to define or we need to redefine the scheme of table while creating the table. We may have missed any column we have. We may have wrongly defined the data type of any column or we might not want certain columns. And we want to drop those columns, so delete those columns from our table.
            • 25:30 - 26:00 So to define, to redefine or to alter the schema of our database object, we use alter commands. So we use alter table commands to add, delete and modify columns, or we use alter table commands to add or drop constraint on an existing table. So as of now we'll discuss about first point and the second point about the constraint we'll discuss when we discuss about the various constraints in the coming slides. So as you can see, we can use alter table commands
            • 26:00 - 26:30 to add a new column in our existing table. We can use alter table commands to drop a column to remove or delete a column from our table and we can again use alter table command to modify that data type of a column. So let's see how we can use it, alter table. So let's see how we can use it, alter table. Then we have to follow the name of the table. Let's assume that we missed age of the employee. So we are going to add a new column, age in our database.
            • 26:30 - 27:00 Age and the, so this is the syntax, alter table, Age and the, so this is the syntax, alter table, the name of the table, add name of the column and then the data type. So we'll define add age and we define data type as INT. So we'll select this and we'll execute. So it has executed successfully. So let's see whether this column has been edited
            • 27:00 - 27:30 in our existing table. So we'll just right click our table and click on refresh here. As we can see we have added a new column, age in it. Since they have not defined it as not null. So it is again an optional, so it is up to us whether we provide the values for age while inserting the data in this column or not. Again guys, we can use alter table to drop a column from our table. Syntax is again same. We have to write alter keyword first,
            • 27:30 - 28:00 followed by the table keyword and the name of the table from which we you want to delete our column. Then you have to use the keywords drop again followed by keyword column and the name of the column. So guys, this is the syntax. So we have to replace the table name. In our case we have the table name as test table here, drop column and the name of column. So in order to remove the same column, which you've added just now, so I'm deleting the column again.
            • 28:00 - 28:30 So you have to follow alter table, name of the table. The column which needs to be dropped. You know it's an important part is that if you have multiple queries in the same window, then please don't click on execute, because if you click on execute in the top, it will execute all the queries present in the same window. So either you will write your query in the new window or in order to execute the required query, you have to select that. And then you can either click F5
            • 28:30 - 29:00 or you have to click execute. It's mentioned that command completed successfully. So now if I refresh my table again, the column is normal. We have successfully deleted the column from our table. So this is one use of our alter commands that we can add columns in it. And again we can delete the columns from a table. Other than that we can use alter table commands to modify the data type of any extreme columns.
            • 29:00 - 29:30 So this is the commands for that. I'll go to management studio, paste it I'll go to management studio, paste it and they have to replace the value in the ankle bracket. So we'll have to define the table name. So we have that test table here, alter column, name of the column. So let's assume we need to chase the data type of employee id from INT to character. So I'll define it as mentioned the name of the column
            • 29:30 - 30:00 of which we want to change the data type and now we'll define what new data type we want. So I'm defining it as character 10. If I'll go ahead and refresh this, I can see the data type of employer id has been changed from INT to character 10. And modifying the data type, we can use this alter tables command to modify the constraint to add a constraint in a table.
            • 30:00 - 30:30 Even we can use it to disable the constraint. Sometime we don't want to delete the constraints. We just want to disable. And then as and when required re enable again. So we'll discuss this when we we'll discuss about the various constraints in the coming slides. These are the various examples so you can practice these examples. So here we are adding a new column salary in the employee table and the data type is numeric 10, two. In a second statement we are again removing your column called job id from employer table.
            • 30:30 - 31:00 And in the third statement we are changing that data type of first name column and we are making it to varchar(25). Good part here is that we do need to provide the old data type. All we have to do is that we have to type the new data type. Now we have drop table statements. So in the drop table statement is basically if you want to drop a table, we need to delete the entire table from the database. As of now in the previous example we have deleted a column
            • 31:00 - 31:30 from a table. But now if we want to delete the entire table from our database, in that case we use the drop table keywords. So syntax is straight forward, we have to write the drop keyword followed by the table keyboard and the name of the table which you want to drop from our database. So let's assume you want to drop the table, which we have created just now. In that case, we simply write the syntax here.
            • 31:30 - 32:00 drop table and the name of table. drop table and the name of table. Guys it is very important when you're dropping or deleting a table because when you drop a table, that data, it will also get deleted. So we have to be very cautious while deleting the database objects. Select this and click on execute. Command has completed successfully. And if I'll try to go and refresh the tables again, I won't see the test table there because we have just now deleted it
            • 32:00 - 32:30 by executing drop table command. So so far we have discussed that we can use create keywords to create a new database. When we create a new database, it is of no use because we have not defined our objects in it. The database will by default have all the out of box objects in it. So we have to first create our tables so that we can store our data anytime and can create various other objects. So we have a created tables, we have created database and after creation of a table
            • 32:30 - 33:00 we saw that in order to modify any schema of any existing tables, then we have to use alter commands. We have to use alter keywords. So we have modify the data type. We have added a new column, we have deleted a column. We have deleted an entire table from our database. Now we'll discuss about the constraints. So constraints basically these are the various rules which we apply on the table whenever a row are inserted,
            • 33:00 - 33:30 updated and deleted from our tables. So it even prevents the deletion of a table, if there are dependency from other tables. So for example, as we discussed that this database is relationship database. So various tables have relations among them. So we can not delete a table if it has a dependency on another table. We'll see that what kind of dependency tables may have in these slides. So define the constraint at column or table level.
            • 33:30 - 34:00 So we can define whether the constraint is only for the one particular column or the constraint is for the entire table. So good part here is that it is not that we have to always apply the constraint while creation of the tables. So let's assume that you have created a table and then you realize that you forget to add a constraint, then no problem. Even after creation of a table, we can go ahead and use the alter commands,
            • 34:00 - 34:30 we can add constraint in the existing tables also. So we will see now how we can add those, how we can add a constant while creating a table or how we can concern after creation of the table. So before that lets discuss what are the various common constraints which apply on tables or columns. So not null as we already discussed that specified that a column must have some value. If you won't provide not null, then by default the column will be optional. And it is up to us whether we want to provide value
            • 34:30 - 35:00 for that column while inserting data in a table. We have unique keyword, specify that collar must have a unique value. So if I define the column as a unique, it means no two row can have the same value for the column. We have primary key, primary key specify column or a set of column that uniquely identify a row. It does not allow null values. So guys this is the difference,
            • 35:00 - 35:30 and as you can see we, when we say unique constraint and primary key constraints, both the constraint states that it helps us to uniquely identify the values. Then what is the difference between unique key and primary key? So one basic differences that is unique constraint even allows us to insert the null value. The point is that there should be only one single null value, because the moment you'll add one more null values in another row, then it violates the unique key constraint because no two row can have the same value for that column.
            • 35:30 - 36:00 But yes, for a single row you can have a null value, but it's just not the case for the primary key. Primary key, if you want to make any column as a primary key the first criteria is that the column cannot have null values in it. Second main differences is that we can have only one primary key in a table, whereas a table can help multiple unique keys or multiple unique columns in it.
            • 36:00 - 36:30 Okay, so let's discuss more about primary keys and how we create it. So as we discussed in the normalization also, that generally a single columns is a part of a primary key, but it is not that only single columns will be there, based on your business requirement, we can add more columns in a primary key. So a primary can key can have more than one value in it. It can be two, it can be three. So those primary key which have more than one column it,
            • 36:30 - 37:00 they are called as a candidate key. Let's see how we can create the primary keys. Okay, so far we have discussed about like how we can drop the tables from the database and let's discuss about the various constraints. So constraints enforce rules on the table, whenever rows are inserted, updated and deleted from the table. So we can apply the constraint activity level or at the particular column level.
            • 37:00 - 37:30 Constraint also prevents the deletion of a table if there are dependencies from another table. So as we discussed in RDBMS, So as we discussed in RDBMS, that RDBMS is a collection of related tables, is a relational database. So if their dependency between tables in terms of primary key, foreign key, if you try to delete a table, then if you give an error that the two tables are related and there's a dependency on other tables. So constraint prevails, the deletion of a table,
            • 37:30 - 38:00 the good part of our constraint is that they can be applied during creation of a table and even we missed the constraint while creation of the table, then we can add the constraint even after the creation of the tables. Like we using alter commands. So before we see how we can apply the constraints, lets discuss what are the various constraint available, column one and not constraint. You already discuss about this constraint when we created our table. So not null specify that a column must have some values. So if you won't provide this constraint by default SQL
            • 38:00 - 38:30 consider it as a null and that column will become optional. So in order to make column mandatory, we have to explicitly provide not null constraint when providing the data type. So we have to specify the not null after that data type. So let me show you. So in the last name we have defined the data type where I get 50 and after that we defined not null. It means that the value in this column will be mandatory
            • 38:30 - 39:00 and we cannot provide a null value while inserting data in test table. Where as for employer id, since we have not provided this constraint, employee id will be null and we may or may not provide the data while inserting in the test table. Then we have unique constraints. Unique constraints specify that column must have unique values. So if I'll specify the column as a unique, no two rows can have the same values for that column
            • 39:00 - 39:30 and we have primary key. Primary key, specify a column or a set of column that uniquely identifies a row and it does not allow an values. So as you will see, unique and primary, both of these constant define, that column should be having a unique value. Then what is the basic difference between unique and primary keys? Difference is that unique allows null value in it whereas primary key, does not allowed null value. The second difference is that there can be only one primary key in a table,
            • 39:30 - 40:00 but there can be many uniquely in a table. So this is the second difference, second main difference between this. Again guys, primary key, generally we have single column as a primary key, but based on business requirements we can add more columns to that primary key. It may be two columns, it may be three columns. So our primary key having more than one minute is called as candidate key. So before we'll discuss about the foreign key and other constraints, we'll first see what his primary key, how we'll define it.
            • 40:00 - 40:30 I will create the primary key while creating that table and how we can add the primary key after we have done with the creation of the table. So let me move to management studio and to save time I have your examples with me, so we'll create an employee table. So I'll open a new query here. So guys, if I want to make a key, primary key, all I have to do is that I have to write the keyword
            • 40:30 - 41:00 primary key after my column. So if I'll execute this command, let me increase the font, once I'll execute this and if I'll refresh the table, I can see the employee table has been created. And if I'll go and see the key that created on my column employee id. And you can see there's a prefix of PK, primary key. So you can check which column and you can see the key sign, so this is for primary key. So just by expanding the columns
            • 41:00 - 41:30 we'll come to know okay, which column is basically my primary key. So you can check the keyword and you can check this icon before the column. So to create a column as a primary key, all you have to do is write the keyword, primary space key, right after that data type of your column. So this is one way of creating the key. Some alternate ways also, so this is another way or the alternate way to create the primary key. So I'll just changed the name of the table
            • 41:30 - 42:00 since we already created emp table, and if I'll try to recreate the same table, it will give me an error the table already exist in the database. So one database cannot have two tables with the same name. So let me show you, if I'll try to create the same table again, it will give me an error that there is already an object name emp in the database. So it means at database cannot have any two objects with the same name. So you have to be careful. So let's create an employee one table here.
            • 42:00 - 42:30 So in the previous example, we have just added keyword, So in the previous example, we have just added keyword, primary key after employee id. But here I am not adding that query, and I'm defining the constraint. Constraint and I have to write the name of the constraint. Here, I'm not provided the name of my primary key constraint. So SQL itself will provide a name of the constraint. As you can see, we have not provided this PK_emp and so on
            • 42:30 - 43:00 and followed by a unique id. But in our case, if we are creating a primary key using this alternate approach, then we have to provide the keyboard constraint, name of our constraint and we'll define the primary key. And we have to explicitly in the parenthesis we'll define okay for which column we are considering for primary key. So let's create a primary key here, successfully created. So I'll go ahead and refresh the table.
            • 43:00 - 43:30 So here I'll see columns, again employer id is a primary key. If I'll expand the keys here. see the name is exactly the same, which we have provided the emp_pk. Yeah, so both this approach is good. You can pick anywhere on the approach to create the primary key. But there's a slight disadvantage of using the alternate approach. If I want to include multiple columns in the primary key as we discuss that a primary key
            • 43:30 - 44:00 may have more than one column in it, then we cannot go with this approach, this approach, if you want to create only one column, primary key. So if you want to consider multiple columns, then we need to consider the second approach, this alternate approach for primary key. Let me show you one example. Let's consider this example guys. In this case we are considering two columns for primary key.
            • 44:00 - 44:30 Last name and first name, so I cannot go with the first approach. I have to fall in the second approach where I have explicitly provide the constraint EPR. So I'll go ahead and create the primary key, the table again and let me refresh. As you can see, we have successfully created employee two table and since we have considered both of these columns for primary key, I can see the key icon in front of both these columns, l_name and f_name, let me expand this,
            • 44:30 - 45:00 As we mentioned, primary key cannot allow null values so by default this columns are having not null and if you'll see the key's name, this is the same name which we provided while creating the constraint. So this is how we create the primary key while creating the table. But it is not that we cannot add primary key once the label has been created. So let's see, one example where we will create primary key once the table has been created. Okay, so this is the syntax for that.
            • 45:00 - 45:30 Before that, let me go ahead and create a table. So what I'm going to do, I'm creating an employee four table and I'm not providing this keyword here I'm just providing not null. So I have created a table, so I've created successfully the table employee four. Let me go ahead and refresh the tables again. So we have employ four tables, but there's no primary key here. And now I want to make employee id as a primary key
            • 45:30 - 46:00 so for that we need to follow this syntax. We have to alter the table. Again, alter table not only helps us to add a column, to delete a column from the table, or to modify the data type of a column, but we can also use alter keywords to add a constant or to believe the constraint from the table. So I'm using alter table, name of our table. In our case we have employee four as our table. So I've given the name employee four, I'll provide name of our employee key for example,
            • 46:00 - 46:30 employee primary key, and then followed by the keyword. And then I'll define which column I need to consider for my primary key. So we are considering employer_id. So I've given employer_id here. And if I'll run this particular SQL query, command completed successfully. And now if I'll refresh employee four, I can see the key has been created and if I'll go and see the columns
            • 46:30 - 47:00 its taking time, yeah, I can see the employee ids now the primary key. So you've seen both examples where we can create the primary key while creating the table or we can alter the existing table and add the primary key even after the table has been created. I hope this was clear guys. Important part and most important part here is that please do not forget that, we can have more than one columns in a primary key and those primary key sometimes
            • 47:00 - 47:30 are often called as candidate key. Let's continue and discuss and we'll discuss about the foreign key. So these two tables can be related and the two tables in the database can be related by means of primary key and foreign key. So first let's define what foreign key is. So foreign key helps us to create or to enforce the referential integrity within our database. A foreign key means that value in one table
            • 47:30 - 48:00 must also appears in the another table. So when we joined these two tables, that reference table is called as the parent table. While the table in which we create the foreign key is called the child table. So the foreign key in the child table. will generally reference a primary key in the parent table. This is how we create primary key or this is how we get relationship between tables by means of primary key and foreign key. So let's first see how we can create the foreign key
            • 48:00 - 48:30 and then we'll discuss about the relationship. So if I create a foreign key, see now again, let's revisit the point number two. The point number two says that constraint prevents the deletion of a table if there are dependency from another table. So if two tables are related by means of primary key and foreign key and if you tried to delete the parent table, then it won't allow us to delete the parent table because the parent table is referenced by the child table. So that is what is the meaning of the sentence to that.
            • 48:30 - 49:00 If there are relationship between tables, it prevents the deletion of a table. So let's see the syntax of creating foreign key. Again guys like how we edit primary key. We can create the primary key while creating the table or we can modify the table, and then using alter table commands or using alter keywords we can add the primary key. Same way we can create the foreign key while creating the table or once a table has been created, we can go ahead, use the alter commands
            • 49:00 - 49:30 and then add a foreign key. So for this I'll consider two tables guys. As you can see on my screen, I am considering, let me increase the font. Yup, so I'm considering two tables here. First is the product table and in product table prod_id is my primary key and I'm creating one more table called orders. And orders, order_id is my primary key, but I'm creating a foreign key. So the product id of my orders tables
            • 49:30 - 50:00 will be related or will be connected with the product table. By means of a foreign key. So let's see how we'll add, let me copy these two tables and we'll open a new window in management studio. Increase the font, paste it here. So first of all, I'm creating my parent table. That is a product. So I'll select it and execute it. So command completed successfully. If I'll go ahead just to verification I'll just refresh this and I see okay,
            • 50:00 - 50:30 it has been created successfully and all the columns are there, order id is a primary key. Now what I'm doing is that I'm creating a child table called orders, and the order tables we'll be referencing the product id column, which is the primary key of products table. So this is the primary key of orders table and this product id. This second column will be a foreign key and this will be connected with the product id off my product table. So in order to do that we have the write constraint,
            • 50:30 - 51:00 explicit keyword. Then we have to provide the name of our constraint. It can be any name, you have to decide, all we have to do is that we have to ensure that this constraint does not exist in our database. Okay, it has to be unique value. Then we have to provide the foreign key. Okay, which column we want to consider for foreign key. So out of these three columns: order_id, prod_id, quantity. We are considering prod_id for a foreign key.
            • 51:00 - 51:30 So I provided the prod_id in the parenthesis and then we have to tell okay, which table we are referencing, there can be 100s of table in our database. So if I want to create a foreign key, I need to define the parent table for that, the table which we are referencing. So in our case we are referencing the product table. So I've selected product here and then in the parent table which columns we want to reference. So we are the first finalize the table and then the table, then we have to finalize the key which we'll be referencing.
            • 51:30 - 52:00 So don't get confused because I have the same name of the column in the child as well as in the parent table. I'll execute this command, successfully created. So if I'll go ahead and refresh the tables again, I can see product with id and if I'll expand orders, so guys, can you see the icon with this orange color is basically primary key. And this, this grey color is my foreign key. And you can see this keyword as a prefix FK foreign key.
            • 52:00 - 52:30 So this is how we create our foreign key. So this is how we create while creating the table. And let me show you the syntax and how we can create the foreign key once the table has been created. Yep, so I will be creating it. So let's assume I have one table orders one, and have tables one product one. So as far as create these two tables, the tables has been created successfully.
            • 52:30 - 53:00 Now I want to add a foreign key, once the table has been created. So I have to define alter table commands, and I defined which table I want to modify. So I want to modify the child table that is the orders one. I'll define the constraint here, I'll define the foreign key again, which column I need to consider. So we are considering again the product_id. So I provide that in the parenthesis. We are referencing the product one, since I've renamed the table. So I have just renaming the table as a product one
            • 53:00 - 53:30 and the column name is same here. So we have product_id. So if I execute this command this will go ahead and create a foreign key. So I'll refresh the tables of the database. I can see there's a table called orders one and these are the two columns. Order id and product id and the key is FK_product_id one, which we have given. So this is how can we create the foreign key and we'll discuss more about foreign key in the module
            • 53:30 - 54:00 when we insert the data. Quite an important part here guys is, that when we create a foreign key on a child table, for example the data of a parent table is referenced in our child table and if you want to delete the data from the parent table, it will give us an error that the data is already referenced in the child table. Sometimes there are business scenario when you want to go ahead and delete the data from the parent table, which is referenced in your child table. But you cannot do that because it will give you an error,
            • 54:00 - 54:30 but it will define our foreign key in such a way that there is a cascade delete that if I'll delete the data from the parent table, it will also delete the data from the child's table. Then while creating the key, we need to define this keyboard on delete cascade. This is an important one guys. So by default your foreign key is having a relation of restrict delete. It means if you'll try to delete the data from the parent table,
            • 54:30 - 55:00 which is referenced in child table it will give an error. That data is referenced, you cannot go ahead and delete it. In order to fix this issues, there might be business scenario when you want to delete the data from parent as well as child. Then while creating the foreign key, we have to provide this keyword on delete cascade. So this is all about foreign key guys. So we have learned various constraints. We discuss about the not null, that not null is used if you want to make our column mandatory that it is mandatory for us to provide the data
            • 55:00 - 55:30 while inserting records. We discuss about the unique key. For the unique key, all you have to do is that you just have to write the unique key word in front of your column. So unique keyword, just define the unique key. We discuss about the primary key and discuss about the difference between unique key and primary key. Unique key may allow null keywords, but it only allow for one single row because the moment we'll try to add null key in two rows, it violates the constraint of uniqueness
            • 55:30 - 56:00 because uniqueness defines that no two rows can have the same value for the column. But primary key won't allow null values. Second thing is that our table can have more than one unique key, but they will be only one and one primary key in a table. Then we'll discuss about foreign key, and foreign key we can create a relationship between two tables by means of primary key and foreign key, that tables which you're going to reference is called as a parent table
            • 56:00 - 56:30 and the table in which will create a foreign key is called as my child table. I hope your understanding the various constraints and check again specify a condition that and check again specify a condition that must be satisfied by all row in a table. So again these are the various examples. So if you'll see in the first example they've created an employee table and while creating the table we are providing the keyword primary key. So we are creating the primary key,
            • 56:30 - 57:00 while creating the table. But in the second example, well we are adding the constraint to an existing table. We've already seen through the example of the key in the syntax. So you have to write alter table. name of the table in which we want to add the constraint. We have to provide the constraint by using add keywords. So we have that in add constraint. Name of the constraint is mandatory. If we are adding the constraint to existing table, what kind of constraint we are adding. So this keyword, for example here,
            • 57:00 - 57:30 if I'll add foreign key then it will learned a foreign key key constraint. If I'll add a unique key then it will add unique key constraint. So as of now we are creating a primary key constraint, then I have to explicitly define what kind of constraints I am adding to existing table. And in the last, as you can see it is, not only we can create a constraint to an existing table, but we can remove the constraint from an existing table. As you can see that syntax is straight forward, you have to write the keyword alter table, and then we have the name of the table,
            • 57:30 - 58:00 followed by the keywords, drop constraint and then which constraint we want to delete. So guys it is very important that when you are creating or adding a constraint, you should give a meaningful name to it so that it will be easy for you to understand what is the name of the constraint. So if you want to drop that constraint, it comes handy because we have to provide the name of the constraint which you want to delete. So I hope we are clear with the constraints, various constants we have discussed, not null, unique, primary key, foreign key and check.
            • 58:00 - 58:30 We have seen that we can create those constraints while creating the tables or we can add to the existing tables and not only we can add, but we can drop the constraint from the existing tables. The last topic for this module is view. As you can see, a view is a named design virtual table of view takes the output of a query and treat it as a table. So view basically it takes out just as focused on this time, it takes the output of a query,
            • 58:30 - 59:00 and treat it as a table, but it is not a table. It act as a virtual table. So we can create a view from a single table, or we can create a view from multiple tables. So I'll show you how we create the views from multiple tables in module three then we discuss about the joints. So before creating used for multiple tables we first to understand what join is and how we can join more than two tables. So as of now, I will show them how we can create
            • 59:00 - 59:30 a view using a single table. The syntax is straightforward. We have to just write create view, name of the view which you want to create. Just focus on the keyword guys. We have to write as keyword and select and then start from which table you want to include, okay. So let me show you one example. If write create view, guys as I mentioned that SQL is not case sensitive,
            • 59:30 - 60:00 but sometimes as an naming convention we provide caps for our reserve keywords that we know that these are the reserve keyboards. So you can follow the same naming convention if you wish. Create view, followed by the name of the view. So as of now, I'm creating a test view and then as select, and then as select, star from and the name of the table. For example, let's say I'm creating a view from employee table.
            • 60:00 - 60:30 Yeah, it's completed successfully. And in order to see the view, I have to first go and refresh my database. And guys, there's a separate categories for views. We have separate categories for tables. We have separate categories for programmability and under programmability we stored procedures, functions, which we are going to discuss and triggers in the last module. So we have a separate categories for most common database objects. So in order to see the view which we have created just now
            • 60:30 - 61:00 we'll see, okay, see of you has been created, dbo.TestView. And if I'll expand this guys, I'll see that this view has three columns, employee id, last name and first name. Because we have created a view from employee table. So I'm employee table has three columns, employee id, l name, f name. If we do not want all columns from a table, in that case guys we have to explicitly provide the name of the columns. For example, I just want only employee id and l name,
            • 61:00 - 61:30 I don't want first name while creating the view. So if I'll create a view now, it is basically having employee id and the l name from employee. So if I'll execute this, we'll go ahead and create another view, but this view will now be having the selected columns which you provided while creating the view. Let me see, it has only two colors. So this up too is how many columns we want to define inner view.
            • 61:30 - 62:00 A table can have like 100 of columns, but if you want to have a selected columns, few columns in our view we can do that. So view is a virtual table. We create view, for example, we need to write a query quite often, you're using that query quite often. So we can, instead of writing that query everytime, we can create a view and then can view can act as a virtual table and we can query the view, the way query our SQL table. So DML commands basically define the schema
            • 62:00 - 62:30 of database objects. And DML commands basically helps us to manipulate the data in the database objects. So the important DML commands are, or the most common DML commands are: insert, update, delete and select. Lets first discuss about the insert statement. So insert command is used to insert data or record in the database table. When we create a table, the table is blank.
            • 62:30 - 63:00 There's no data in it. It has only the scheme of the tables. What are the columns we have defined and the constraint of the tables. So very first thing we have to do is that we have to insert some record in the tables. So they are two basics syntax of the inserted into statement which we use to insert records in the table. The first one is insert into name of the table in which we want to insert record followed by the column names
            • 63:00 - 63:30 and we assume that these are the field names, field names or column names. So sometimes we refer the columns as a field also. So after table name we'll define what are the columns in the table. Then we define the can keyword values and the values of the corresponding columns. Important part here is that the order in which we'll define the column here, the value should be in the same order or else we'll get an error while inserting the record in the table.
            • 63:30 - 64:00 So let me show you one example. I'm increasing the font size for better visibility. Let's assume we have a table called department one here. So we are using employee DB database here. Good practice to use it upfront that which database we are using for our queries. I'm using emp database, so I'm using it the false statement in my query window, then I'm writing insert into department one,
            • 64:00 - 64:30 department number, department name, values, 20 and HR. So these are the values I'm going to insert in. So this is the syntax, insert into name of the table, followed by the column names. Then we'll use the keyword values and followed by the values of the column which we are going to insert. So let me execute this command. As you can see, one row affect it means, we have inserted the changes. So in order to see whether the record has been inserted,
            • 64:30 - 65:00 you need to fetch the data. To fetch the data We basically use the commands, but we will discuss about the select command in the coming slides. You can right click the table and you can see select top 1,000 rows. As you can see here, we have inserted the ninth record with the department id. Department number 50 and the department name HR. This is what we've inserted into. So if I will change the order, lets assume I've changed the order and make it 17.
            • 65:00 - 65:30 So I've changed the order of the values. The order is not the same as I have defined the columns. And if I execute the query, let's see what happen, we'll get an error because of the mismatch data type. So department number is basically numeric and department name is character type. So what we are going to do, since we have changed the order of our values, so we are trying to insert string
            • 65:30 - 66:00 or character data into numeric. That is why we are getting this error. So the important thing is we have to take care about the order of the columns and order of the values while inserting that record. So this is the first syntax that we need to provide, the name of the columns. Second syntax is, if you want to insert the data in all the columns, let me show you on the slide, so you can see insert into departments which we have discussed.
            • 66:00 - 66:30 So if you want to insert values in all columns, then no need to specify the column names, but order of the column value should be in sync with the column names, that's what we discussed now. So they are two difference in texts. One we need to define the columns or we can skip the column names, we can directly mention insert into table name and the values here. So if I'll go here I can say insert into department one
            • 66:30 - 67:00 and then I can directly right what values I want to insert, and say I want to enter, the department IT in the location, Mumbai. Again the insert is successful. The one important thing here guys, have you noticed that when when we are inserting the record, numeric records. We asked simply writing it, but when we are inserting string or character
            • 67:00 - 67:30 then we have to enclose this end in single codes. Since IT and Mumbai, these are the string values which I'm going to insert into the columns. The columns are location, department name and department number. Department number is numeric. So I'm not enclosing this value in single codes, whereas department name and location is variable and character. So I need to enclose the string into single quotations.
            • 67:30 - 68:00 If I'll tried to insert the record without the quotation, I will get an error, let me try to insert this, invalid column name. So please take care of this. For string data or character data, we need to enclose this in single stream. And other important insert command is insert as select statement. So far we are inserting the data in table, but here using insert as select statement, we'll insert the data in the table
            • 68:00 - 68:30 but the data will come from another table. So using this commands, records from one table will be inserted in another table. As you can see the syntax, we can insert into table name, followed by the column names. What are the columns names, which you want to define. Then we need to select the columns from the next two table. So we are defining, select column names from table name, where condition and then this is the syntax.
            • 68:30 - 69:00 So let me show you the examples here. For example, I'm inserting the values in department one table, I'm defining what are the columns which I want to insert into. So these are the columns. So if we have department number, we have the department name, and then we have location. And then if I want to insert all the columns
            • 69:00 - 69:30 so I can define the star here, followed by the column name. If I'll execute this query, I can see they were four records in the department tables. If you'll see in the department, if I'll execute this query, select top 1,000 queries, I can see there are four records. That is the reason when I executed this command, I got a message, four rows affected. So what we have done in this query is,
            • 69:30 - 70:00 I have inserted all the record from department table into department one table. If I don't want to insert all the records, then I have to specify a where condition here. If you see if for example, let's assume this is my table and I want to only insert those records whose having department number greater than 20. In that case, I have to write where department number
            • 70:00 - 70:30 is greater than 20. If I'll execute this query now, see only two records are affected. Why? Because we have only two records which is satisfying the conditions of department number greater than 20. So if I'll go and see the department table, I can see all records has been inserted. In the last, we have inserted 30 and 40 because it is satisfying the condition that department number is greater than 20.
            • 70:30 - 71:00 So if we want to insert all the records of one table in another table, then we have to skip the where command, or the where clause. If you want to insert a specific rows, specific records, then we have to filter those records using the where clause. Another important thing here is, it's not that we have to always insert the values of all the columns. I can skip or I can selectively insert
            • 71:00 - 71:30 the values for column. For example, I don't want to insert the value for location, I can skip it. But here also instead of a star, I need to define which are the column I'm selecting. So I have for defined department number and then department name. Again the important part here to notice is we have to consider the same order of the columns. Since we are inserting department number and department name,
            • 71:30 - 72:00 from the second table also we need to arrange the column in the same order. If I execute this query, it will execute it successfully. All the full records are inserted into department one again, but if I changed the order, and I felt executed now, we'll get an error, the same error, the data types mismatch. So be careful whichever insert syntax you are using, whether you want to insert one table record to another table
            • 72:00 - 72:30 or you are inserting only directly the table, the order of the column is very important. Another important part here is that when we are inserting record in a table, we have to ensure that we'll always select all the columns which are not null. If you remember in the previous module we discuss about the not null constraint. Not null constraint defines that value in the column should be mandatory.
            • 72:30 - 73:00 So when I'm inserting a record in a row, I have to provide the value for all the columns which are mandatory. Let's take this example. In the department one table, we have department number as a not null department name as not null and location that is loc is null. So in this example I have not provided loc but still I'm able to insert the record. But if I'll skip the department name
            • 73:00 - 73:30 and I'll consider loc for insertion, and even though I'll maintain the same order of the column, but I will get an error while inserting the record, see. Cannot insert the value null into the column department name. So department name is not null column, when we are inserting the records we have not specified department named column. So if you're not specify so then null value will be inserted in that.
            • 73:30 - 74:00 And since the column has a constraint of not null, it won't allow us to insert the record. So we have discussed about insert statements. These are the very important table commands because without inserting records in the tables, we cannot update those. We cannot delete them, we cannot fetch them. So insert statement is the main table commands as it helps us to populate our database objects with some data. Database is not static.
            • 74:00 - 74:30 It's not that we insert the data once and then we are done. No, data needs to be modified as and when required, as and when there is a business requirement. So used update statement to modify the data. Update statements modify the existing data in the tables. Using these statements we can update the value of a single column or multiple columns, in a single statement. We have the choice, whether we want to update the value of a single column
            • 74:30 - 75:00 or whether we want to update the values of the multiple columns and these can be executed in a single SQL query. We don't have to write multiple queries for each and every column. When the update the records in the SQL table, it is very important that we should provide the condition that which records we want to update. If you fail to provide the condition, then all the records in a table will get updated. So whenever we are updating the records,
            • 75:00 - 75:30 it is very important for us to define the condition. As you can see in the notes, without where clause, all the rows will get updated. So let's see one example, let me open another table. So I have department two and I can see they are four records in it and I want to update the department name
            • 75:30 - 76:00 of the department number 30. As of now it is IT and I wants to change it to marketing. So we have to follow the syntax update. Let me copy it so we can save some time. So we have to set the department name and we want to set the department name to marketing. So I had to define the new value, which we are going to update,
            • 76:00 - 76:30 and we have to update the value of department name for the department number 30. So I need to mention that in the where clause. So let me execute this query. As you can see, one row affected. It means the update has been done and it is successful. So let me again see the records. So we have updated department, not the department two. So I have updated the wrong table. So let me execute it again. Again, one row affected and if I'll execute this,
            • 76:30 - 77:00 select top 1,000 rows. I can see that the department name has been updated. I was talking about the where clause. That where clause is very important while you make any update statements. Let's assume we forget to include, so this is how guys, if you want to comment anything, you can two hyphen. So the green part here in the query is that it is commented. Or you can write forward slash star,
            • 77:00 - 77:30 and then star for the backward slash. This is how you can add comments in your SQL queries. We'll see the use of this comments when we'll discuss about functions and modules when you have to write some comments so that other developers can understand what you are writing. So to add comments in SQL queries, either we have to follow this syntax or we have to write two hyphen. So if I'll skip the where clause in the update statement. Let's see what happens.
            • 77:30 - 78:00 Can you see four rows effected. They were four rows in the department two table. And while updating, when we skip the where clause, all the records get updated. So can you see, the department name for all the rows has been updated to marketing. So it is very important that while we are updating we have to specify the where clause or else all the records will get updated with the same value for a particular column
            • 78:00 - 78:30 which we are updating. So in this example, I have updated the value of a single column, that is department name. But in single SQL query we can update values of multiple columns. Let's take the example. So in the department two, I am just updating the values of department name into marketing and I'm updating the location to Chennai. And I'm updating it for only department name number 30.
            • 78:30 - 79:00 So in this single statement, I'm trying to update department name and location where it has been executed successfully and if you'll go and see the record now, 30 has been up updated to marketing. So maybe to remove the confusion, what we can do, we can update it with some of the value. Let's say it's a HR and may execute it again. As you can see, since in the where clause I have mentioned department number 30. So I have updated the department name and location
            • 79:00 - 79:30 in a single update statement. Whether we insert the record in the table or whether we update the records in the table. The data type plays a important row. We have to always update the data as per the data type of a column. If I'll try to insert, let's assume that I'm updating the department number, so let me write one more query. Let me first increase the font, let's assume I'm updating the department number
            • 79:30 - 80:00 and instead of a number I'm trying to update with string or character. So I'm trying to update the department number 30, with value HR. If I'll execute this, you give me an error. That error converting data type where get to numeric because department number, it has a data type numeric and I'm trying to insert string or character in the numeric data type. So irrespective of whether we are executing update statement or insert statement, we have to always take care about the underlying data type
            • 80:00 - 80:30 of our fields or columns. Now we'll show some lights on delete statements. So delete commands helps us to delete row or records from the database table. Similar to update statement, delete statement can be executed with or without where condition. Again, point here to be noted is that, if you'll execute the delete commands without where condition, than all the records or rows from the table will be deleted.
            • 80:30 - 81:00 So where clause is very important. Whether we are working with update statements or delete statement. So if we purposefully want to delete all rows from our table, then of course we won't include the where clause. And if you want to specify whether to start a single row but multiple rows. But if you want to not delete all the rows, then of course we need to include a where clause. Let me show you few example,
            • 81:00 - 81:30 let me open a new query. So let me first you what are the records are there and we'll try to delete those. So I'm, we'll be deleting the record with department number 40. So one rows affected means the query has executed successfully.
            • 81:30 - 82:00 So if I'll go ahead and execute this again. I can see only three records, because the desire has been deleted from the table. Now if I will skip the where clause, so I'm commenting the where clause by adding two hyphens here, as discussed we can add the comments by using either hyphens or using forward slash star and then star and then again forward slash. If I execute this query now, can you see in the recent, three rows affected.
            • 82:00 - 82:30 So after deleting the department with the department number 40, we had only three rows and all three of those has been deleted. So if I query the table again, it's empty. Now there are no more record in department two, so that is a reason it is very important to include where clause in the delete. When we add the condition in the where clause, it can be like single conditions or multiple conditions. We'll discuss that how we can add the logical operators
            • 82:30 - 83:00 and how we can use the or conditions, or and conditions in the where clause. So far we have discussed three important statements for DML data manipulation, language commands, insert, update and delete. Now we'll be discussing about the select statement. So far we have discussed that how we can insert the record, how we can update the existing data or we can remove that unwanted data from our database. But how we are going to fetch the information
            • 83:00 - 83:30 from our database and show it to the end user is very important. In this module we will be focusing only on retrieval from a single table. In the next module we will be discussing about retrieval from multiple tables by means of joins. Where condition is optional in select statement, so as we discussed earlier, where condition is always optional, whether it is updated statement, delete statement or select statement.
            • 83:30 - 84:00 So we have to be very careful while using where conditions. It's up to us that whether there's a business requirement to include the where clause or not. When we use where conditions there are various operators which helps us for the better retrieval or better condition. So to retrieve the data, we use select statement. As you can see the syntax, select, field one, field two, field n, and these are the various columns
            • 84:00 - 84:30 from table name, which column we want to include for data retrieval, and followed by a where clause which is optional. Let's see one example of the select statement and then we'll move to the next slide. Let's assume I want to select the records from department tables or employee table. Let me like the query here, let me delete the previous query. So select statement helps us in data retrieval.
            • 84:30 - 85:00 If we want to include all the columns of a table, then we have to use this star or asterisk sign. So this is the basics syntax off a select query. Asterisk helps us in retrieval of all the columns. So I'm writing select star or asterisk from employee. As you can see all the columns of employee table are their in my result sets. Lets retrieve some other table.
            • 85:00 - 85:30 Let's retrieve department table. Again, I want to retrieve all the columns, so I will write select star from department, since they are totally three columns in the department, I can see all the three columns are here. And there are only four records, so all the four records are displayed. Why four records are displayed because we have not included any where condition. We are telling SQL server that we want to fetch all columns and all rows.
            • 85:30 - 86:00 So if we'll skip the where clause and we'll add an asterisk in as select, it means we want to fetch all the columns and all the rows in our result sets. One important thing that for example, I'm creating two different tables as of now, so it is not that at any given point of time I can fetch only values from single table. If I click on execute without selecting any particular SQL query, I can see the results that of both the SQL queries.
            • 86:00 - 86:30 So though where condition is optional, but it is very important to include where clause in SQL queries to set right conditions so that we'll get that precise result or else you'll get all the results of all the rows. In real world scenarios, we have millions of records in our database. Generally 1,000 of rows. So if you forget to add the where condition, think about the number of records you will get
            • 86:30 - 87:00 and it's very difficult to get the right results. So it's very important to include where condition, whether they use update, delete, or select statement in DML commands. As of now, since we have not included where clause, but even without using where clause, we can filter the number of records which we want to include in our result sets. So we have a keyword, a reserve keyword in SQL that is top.
            • 87:00 - 87:30 Let me show you one example of that. So though I'm including all the columns by using asterisk sign in this query. But I'm explicitly telling to the SQL server that I want only want top three results to be included in my result sets. So if I'll execute this query, I will get only three records. So we can define, we can change the values.
            • 87:30 - 88:00 In this example I've shown only top three. We can include top five, we can include top one. I can confine or I can restrict the result sets, but again it will be only from the top five, or bottom five. So we cannot replace the where clause or the where conditions by top five, but top five helps us to retrieve only selected portions of our data in a result sets. So far we have discussed that we can use asterisk signs
            • 88:00 - 88:30 if you want to include all the columns in our result sets. But in the practical scenario and in the real time, our table may contains 100s of columns. But we might not be interested in getting values of fetching values for all the columns. We might be interested in few columns, then yes, we can include selected columns in our select statement instead of star or asterisk.
            • 88:30 - 89:00 Let's do an example. So as of now, as you can see, we have nine columns in the employee table. But I want to see only the first name and last name of the employee. So in instead of writing star or asterisk, I can mention select, first name, followed by comma, last name from employee. first name, followed by comma, last name from employee. So I will get the results only for two columns.
            • 89:00 - 89:30 And again, if we want to restrict the results, I can use top, even with the selected columns. So this can show me only top five records in the result sets. So when we are retrieving the results. We, if you want to include all the columns, then we'll use asterisk. If you want to include selected columns, then we have to specify the name of the columns and all the column should be separated with each other by comma.
            • 89:30 - 90:00 And the order in which we specify the column names in select statement, in the same order, we'll get the columns in the result set. Since in my results that I'm getting first name as the first column because I have defined the first name in the same order in my select statement. In select statement, we can use Alias name for a field or a column. Please don't get confused between field and a column. Field is used for the column name of a column in SQL.
            • 90:00 - 90:30 Why we use Alias, let me show you. Let's take the example of department table. As you can see, we have loc for the location. But maybe it is not clear to some developer what loc stands for, so I can change loc to location. So for that we need to use alias in SQL. So how do you use that? Let me show you. You have to write select department number, loc.
            • 90:30 - 91:00 We have to use as keyword and we have defined the name of our column location from department. If you'll see I have used an alias location for the loc column. So to increase the readability of columns, we use alias. Sometimes, when use of alias is in inner joins, so when we'll discuss about joins in the next module. I'll revisit this particular topic
            • 91:00 - 91:30 and I'll explain to you, sometimes the column name, table name is very long so we can use alias for column as well as for the tables. As of now I'm showing you example for the column, but we can use alias for tables also. It is not that we have to use alias only for a single column. We can use it for as many as columns in our select statement. Even we can use for all the columns which are there in our select statement. So to sum up, alias helps us and better result sets,
            • 91:30 - 92:00 it made result sets more readable for the end user or for developers. Let's move to the next slide, distinct values. A column can have the same values if it is not primary key. So as we discussed in the previous modules, a primary key or a unique constraint. These helps us in maintaining a unique values for each row for a single column, but other than unique and primary key, we can have multiple values for the same columns
            • 92:00 - 92:30 in different rows. Sometimes when we are retrieving, we are more interested in only distinct values. In that case we'll use distinct keyword to filter our result in such a way that it will only retrieve the unique values for a particular column. So let's understand that using one example. Let's take the example of department one column. As you can see, I have Chennai at different places
            • 92:30 - 93:00 for locations, and I want to know that in which location my department is. And I want only the unique values, I don't want that repeated data or redundant data in my result sets. So far that, what we can do is that we can use unique keyword white fetching the data from tables. So we use other by to show the results or to filter the records. So far we have discussed about the unique or distinct keywords in the select statement.
            • 93:00 - 93:30 Now we'll see how we can sort the data. So for sorting the use order by, so order by is used along with a where clause to display the specified column in ascending order or descending order. By default, the order is ascending order. If we won't provide any specific keyword, the results will always be in ascending order. So order by is used along with where clause, but it is not a mandatory conditions that we have to use
            • 93:30 - 94:00 order by only with the where clause. So let's see one example, let me make a new query. We have select star from department, let me increase the font, select star from department and then we can use order by, so we have department, since I have not provided any keywords here, so by default it will be ascending, or even I can provide ASC.
            • 94:00 - 94:30 ASC stands for ascending. So if I'll execute it now, I can see the results, same result. But if I change the keyword ascending to descending, descending stands, DESC stands for the descending. So if I'll execute it now, I can see department in the reverse order. The results that has been reversed. So this is how we can sort our records in the result set. So in the previous slides we have discussed about the top one or top five, top 10,
            • 94:30 - 95:00 so we can club top keywords along with order by to fetch the bottom records. We can filter or we can fetch the bottom five records, the bottom 10 records because there is no result givers for bottom. We only have the keywords as a top. So if I want to show the bottom two records, let's see how we can club top with order by to fetch the desired results. So first of all I'll show you that results without using order by,
            • 95:00 - 95:30 so I'm just showing you top two results from department column. And in the next query, I will write select top two, star from department and I write order by department number. If I'll execute both the queries. You will see that in the first results. In the first since we have not used the order by in the descending order, I'm getting the top two records, but in the next result sets since we have used order by
            • 95:30 - 96:00 along with the top two, we are getting the bottom two records. So this is how we can, use a various concepts in our select queries to get the desired result set. So we have discussed the sorting, that how we can start the data. As you can see in this example we have used multiple columns in the order buyer by, so it is not that we can use only one column in the order by, we can include multiple columns, but the results will be sorted in the order
            • 96:00 - 96:30 in which we have specified our columns. So since we have specified department name first and the other is ascending, the result sets that will be first sorted by department name column. So yes we can include multiple columns in the order by clause. Let's move to the next slide, filtering. So so far we have discussed that how we can insert the data and then updation of data using update statements then delete statements
            • 96:30 - 97:00 and we discussed about the select statement, top five, bottom five, how we can include all the columns in our query or result sets or we can include a selected columns. We have seen that by order by clause we can sort our data. Now we are going to discuss about the filtering. So so far whatever examples you have discussed about the select statement, we have not included where clause, since we clause is optional. But if you will not include where clause in our SQL queries,
            • 97:00 - 97:30 then we are going to get all the results, which is not a good idea because your database or your table can have 1000s of records. So it may impact the performance also than when you are you know, fetching all the records in one go. So we use various conditions in a SQL query, While fetching that data, so we use where clause to narrow down our result. So in the where clause, we use various operators. We use comparison operators, we use logical operators.
            • 97:30 - 98:00 So there are three main logical operators, and, or and not. So we'll discuss and operator first. So and logical operator used to combine two conditions and it fetches the result which satisfy both the conditions. So instead of writing two different queries, we can club the two conditions in one single query. And if a query will satisfy both the condition,
            • 98:00 - 98:30 that only those records are or those rows will be shown in our result sets. Let's see with an example. Let me first show you all the records of the department table. So we have four records and let's assume we want to filter the record which has department number 10 and along with one more records, which has department name, HR. So what we can do, we can use select since we are including all the columns,
            • 98:30 - 99:00 select star from, table name, department and now we'll use the where clause. So we'll use where keyword, where departments number is equals to 10 followed by the and keyboard, and department name is HR. Please pay attention that we should not use double quotes. We always use a single quotes in SQL.
            • 99:00 - 99:30 So like other programming languages, CC plus plus, C Sharp Java, where we use double quotes for string. Here we use only single quotes. Whether it is a character or a string. If I'll execute this query, it is not showing me any results because it is not satisfying any condition. Why? Because there is not as single row, we just having department number 10 and department name HR. So if I change it department number to 20. That will satisfy the condition, the second record will satisfy the condition.
            • 99:30 - 100:00 So that's what we have discussed, that if it will satisfy both the condition, then only the rows will be displaced in the result sets. Now if I'll execute this query, we'll get the desired results. This is how we use and logical operator to get the results or get the desert rows in the result set. So again, let's see this example. So in the first example we mentioned that we are fetching the selected columns, we're using select first name,
            • 100:00 - 100:30 the last name from employee table where first name is equals to Miller and last name is equals to Ward. This is how we're getting the result. In the second example, we are fetching that that the first name, department name and salary from employee table, where salary is greater than 20,000 and salary is less than 35,000. So we can use multiple conditions and only those records will come which was satisfy both the conditions.
            • 100:30 - 101:00 Let's move to another logical operator or like end operator, or operator is also used to combine two or more conditions. But the main difference is that it will fetch the results if any one of the conditions is satisfied in the old statement. So let's discuss it with an example, example we discuss when we made it to 10 we got the empty result set because no row is or satisfying both the conditions. But if I'll replace and with all keyboard,
            • 101:00 - 101:30 we'll see both the rows. So the main difference between all logical operators and and logical operator is that in and it has to satisfy both the condition, whereas in or if any one of the condition satisfy, we'll get the rows or record in our result set. So based upon the business requirement, we use either and or or logical operator. I will discuss the last logical operator not,
            • 101:30 - 102:00 so not operator is basically used to negate the condition. It basically fetches the opposite of the results, which is basically defined in the conditions. So it is also used in combinations with other keywords like not in, not between. As you can see in this screen, we are using select department name, location from department when location not in Chennai and Bangalore. Let's see this with an example.
            • 102:00 - 102:30 So let me show you first all the records so that we know what we querying. So let's assume that I want to get all the departments which are not located in Hyderabad. So I'll do, I'll write select star from table So I'll do, I'll write select star from table where column name, not keyword because we're looking for a negation, not in, we'll discuss about in operator in the meanwhile.
            • 102:30 - 103:00 Let's execute this and here we go. So now since we use, we want all the departments which are not in Hyderabad. So we used not logical operator in a negative sense and we are getting all the records other than Hyderabad. So this is how we use not operator. So for filtering we use logical operators as well as comparison operator. So so far we have discussed three important logical operators and, or and not. We used and, and the we'll get the desired result
            • 103:00 - 103:30 if it satisfies both the conditions we get the result set if it will satisfy any one of the condition, if you use the or logical operator and not logical operator is used in a negative sense, or to negate the conditions. So let's move to other operators, like comparison operators. So we have various comparison operators, which we can use it in the where clause to filter our results.
            • 103:30 - 104:00 We have equals two followed by a not equals two. We can use either exclamatory sign and equal to for not equals to or less than greater than sign, in combinations for not equals two. So we'll get the same results. We can use either one of them. Then we have greater than and equal to, less than equals to, like operator. Like operator we generally use, when they use our play around with the strengths or characters, we use between operators when we want to find
            • 104:00 - 104:30 or when we want to affect the results from a range in keyword. We just saw an example. So these are the various comparison operators. Let's start with the between operator. So the between operator is used to search for values within a set of values. So let's see this example. So we are fetching the details of employee whose salary is basically between 2,000 and 35,000. So lets see with this example.
            • 104:30 - 105:00 Let me open a new query. So we are going to fetch employees, so let me first increase the font size for better visibility. So now I want to fetch the record, salary is greater than 20,000 and less than 35,000. So I'll do that. Then right select star from employee Then right select star from employee where salary between 20,000 and then 35,000. where salary between 20,000 and then 35,000.
            • 105:00 - 105:30 So between operators always used in combination with and operator, this is how I get the results. There's only one record which is satisfying these conditions. This one, Smith. So this is how we are getting the desire row in our result set. So it's basically used for a range, so you can use between operator. Lets move to the next operation, not in. We've already discussed about the not in.
            • 105:30 - 106:00 So not keywords is, not is a basically the logical operators and it is used along with other operators like in an other, so we have just seen one example where we want to show the departments which are not in Hyderabad. So this is the repetition of the same example. In the previous example which I shown I include only one locations, but we can use multiple keywords if you're using the in keywords, we'll see the example, not in. In operator fetches values from a set of literals.
            • 106:00 - 106:30 So this condition see generally used when you want to fetch values from multiple values in a single statement. So it's not that I can use only in, I can use or operators, if there are only one or two conditions, I can either use or operator or in operator. But if the values are more, it is not a good idea to use so many or operators or logical operators. Let's assume, I want to see the results intensities.
            • 106:30 - 107:00 So it I'll write, like where location is equals to Mumbai or New Delhi or Hyderabad, or Bangalore or Chennai, it is not readable, it's not good. So instead of writing so many or operators, we can use in operators. So the in we basically include all the values out of which we want to filter our reserves. So you want to fetch our values. So let's see with an example.
            • 107:00 - 107:30 So let me open a new query window, and write select from department. So if I want to see the results, or see the departments which are either in Chennai or Bangalore. So I'll write, select star from department, where location in, it can be in anyone of these location. That's how we are Bangalore.
            • 107:30 - 108:00 Don't forget to include strings or characters in single codes in SQL. So this fetch the desired results. So we can use multiple values, in the parenthesis if he used in comparison operator. So if I use not in, then this will go in negation and it will show the opposite of what an operator is doing. So we have discussed not in, as well as in. So if there are multiple values instead of or,
            • 108:00 - 108:30 we have to use it is good practice to use in keyword. Then basic comparison operators, we have greater than, equals to, less than, greater than equals to. So this is pretty much self-explanatory. So if I want to select the employees who's salary is greater than 20,000, so let's see how we'll get the results. So I can use the previous window, so where salary, instead of this, I'd can write salaries greater than 20,000.
            • 108:30 - 109:00 So I'm getting three results. So the three I got are three rows or three employees, whose salary is greater than 20,000. So if I include greater than or equals to, then I guess I'll get four reasons. So I don't think so we have a salary of 20,000 here. No, we don't have. So let's take the example of 30,000 here. So we'll get the three results. But if I remove the equals to keywords,
            • 109:00 - 109:30 then of course we'll get only two rows in result set. And if I use the equals to, then we'll get the only single row which will satisfy that desire or required condition. So this is how we use our various operator greater than, equals to, less than, greater than equals to. Again, this example, we can use equal operator, it will satisfy the desired conditions to fetch the results. Comparison operator use a like,
            • 109:30 - 110:00 how we use the like keywords in comparison operator. So generally we use light operators to perform wild card searches of valid search string values. As I mentioned earlier, that like keyword is generally used when we are filtering or fetching the strings. So it used with two wild cards. One is a percentage, percentage denotes zero many characters and underscore denotes one characters.
            • 110:00 - 110:30 So let's see. So in the first example as you can see, I'm getting the values from the department table whose locations starts with C, or the C alphabets. whose locations starts with C, or the C alphabets. Let's see how we can use it. So we'll first see how we use the percentage of wild card. If I want to note, that what are the different departments where the location start with the alphabet C. So will write select star from department,
            • 110:30 - 111:00 where LOC like we use the like keyword, like parenthesis. And then the keyword C with the percentage sign that is wild card would get the results. So if I just change the order, if I'll write the wild card first and then C, it means I have to show the department whose location ends with C. So if I'll write it, I here. Then again, I'll get the desired results
            • 111:00 - 111:30 because I am fetching the rows who's location and with the I keyboard or I alphabets. So if I'll use first wild card and then alphabet, it means it ends with, if I first used the alphabet and then wild card means it's start. If I'll write something like this, it C and then wild card, it means it starts with C, and ends with I. So fetch me the locations who's start with C
            • 111:30 - 112:00 because I'm using the C before the wild card. And since I'm using I after the wild card, so it ends with I, if I'll execute this query, again it will show me the same results because, if I'll change it, for example, I'm starting with H and ending with I. So there's no department within such a condition, so you'll get an empty result set. And I find to show that, show me the department who starts with edge, in that case on I have to do is that we have to remove the I.
            • 112:00 - 112:30 So we have to use the keyword before the wild card and it will show us the results. So along with percentage signs, we use underscores also as a wild card. So in this example, as you can see, the second example, select department or location from department where locations like. So it means the first three words should be CHEN, then we can use underscore. So we have to first satisfy the first keyword. So the first three should be this.
            • 112:30 - 113:00 So this is how we use the underscore or wild card. The last topic of this module is the case expression. So case expressions helps us to kind of simulate the if then else statement, like in most of the programming language we use if else. So this helps us to write the same, only point or the key statement is that, as you can see that note, we cannot use non values in the case statement because it always use the equals to operator. And we cannot use equals to operator with the null keyword.
            • 113:00 - 113:30 We have to use is null, that I'll show you after this example. So let's assume I'm fetching values from employee. So if I'm looking for the salary column, there are a few rows which are having none values in there are a few rows which having values in it. So if I want to see that, what are the different employees which have a null values for the salary column. So if I try to write where salary equals to null,
            • 113:30 - 114:00 then I won't get any results here because equals to operators does not work with null. If I'm checking now we have to use is null. If I'll execute this query, again I'll get the desires. If I want to check, if I want to fetch the columns which do not have null values for the salary column, then we have to use is, and then they have to use the not logical operator, is not null. So not logical operators is always used
            • 114:00 - 114:30 in combinations with other operators. They get all the employees did not have null values for their salary column. So that is a reason we are using case expressions, so we cannot use the null values, otherwise it will break because we use the equal to operators and equal operators not used along with null. So this is how the syntax of cases expressions, as you can see we have declared a variable int input instead of int.
            • 114:30 - 115:00 And we have set the values as equaled to two. Its just an example so the have to put in the value here in this example. So we are selecting case, I'm just selecting that if the value is one, then we'll show that put as one. When it is two, them we are showing the output as two. When it is three, then we are showing output as a three. And if it is not out of any these three values, one, two and three, then we'll show the message as your message. This is how we are doing in this example. So let me give you one example for that.
            • 115:00 - 115:30 Let me do one thing. Let me find out the states of the cities where my department is. So as you know, the channel is in Tamil Nadu, and Bangalore is in Karnataka. So let's see how we can do that using the case statement. So we have to write select, then case keyword, in the case keyword we will define which columns you want to fetch, I am fetching the location. And then we write the when condition, so I'm writing when Chennai, then show the result as Tamil Nadu,
            • 115:30 - 116:00 when Bangalore. Then let's say Karnataka, and I'm adding an else condition if it is not part of anything. So lets just write, no idea. So we have to end the when condition, then we have to write from which tables we are basically fetching (mumbles). So if I'll execute this query, I'll get say, if it is Chennai, I'm getting the results as Tamil Nadu,
            • 116:00 - 116:30 and if it Bangalore then I'm getting as KR, and there's some departments which do not have any values like Hyderabad we're getting is just no idea. So this is how we can use if else conditions and SQL statement or select statement by using case expression. Important point is that we should not deal with where we're using null because we use equal to operator. A join clause is used to fetch data from two or more than two data tables, based on the join condition
            • 116:30 - 117:00 which we'll provide in the SQL query or SQL statement. Join clause is used to combine rows from one or more tables. When we say one means, if we are trying to join the condition on a single table, then this particular condition is called as self-join. So these joints basically happens, or takes place between tables based on the common columns between them. In SQL server we have the following joins,
            • 117:00 - 117:30 we have self-join, we have inner join, left join, right join and full outer join. Cross join is also call as Cartesian products. A table can we join to it to itself, in a self-join. The important part here is that when we'll use the self-join. Then we have to use that table alias. Because our table name is same,
            • 117:30 - 118:00 because we are making a join on the same table. So if you'll see the syntax, in the select statement we will mention that columns which we are trying to fetch from the tables. Then we have a keyboard from which table we wants to fetch and then the table alias T1. Then join another table, table name because the table name is same. That's why we have to use another alias
            • 118:00 - 118:30 for the same table, that is T2. And then we'll provide a joint condition with a on key word you mentioned T1.column name equals to T2.column name. So this index will be more clear when we will show some examples of self-joins and other joins. So this is an example of a self-join, where we are joining the same columns. So we will see this example, we'll execute this example in the management studio, but before that we'll discuss other join as well.
            • 118:30 - 119:00 And then I'll show you the examples of our self-join. It is not that we quite often execute self-join. We execute self-join only in some rare scenarios. Most of the time we tried to join two or more than two tables. So we have inner join. The inner join fetches the record that have matching values in both the tables. So that is called self-join
            • 119:00 - 119:30 or sometimes we call it as simple join also. So here is the same text for the inner join, we write the select statement or the column list, we mentioned the from, that from which tables we want to fetch the informations. And then we provide the table alias. It is not mandatory to provide the table alias but it is good practice as sometimes, the table name is very long so we don't have to write the table name always. So to avoid this we provide small table alias
            • 119:30 - 120:00 which will help us to identify, which helps us to fetch the columns in the select statement as well as in the on condition. So let's see an example of inner join first. Let me close all this windows which are open in management studio. So for join, we will be using these two tables. We will be using employee table. Let me show you the data of the employee table.
            • 120:00 - 120:30 This is our first table, employee table. So we have the following records in it. We have six rows and the column is employee id, first name, last name and address. In the address we have the city name. For the fifth record, we do not have the value for that address, it is null. The other table which will consider to show you the examples is orders,
            • 120:30 - 121:00 and the order table, let me first execute the single statement first. So this is the order table. We have five entries of five records in it and employee id is null for the order id fifth or for the fifth record. Let me execute these two statements together. So if you'll see my orders table is the child table, whereas the employee table is the parent table. Employee id is the primary key
            • 121:00 - 121:30 and order id is the primary key in this table. And these two tables are joined by employee id column. So when we join two tables, there should be one common column or there should be some matching values in both the tables. If there is no matching values in parent and child tables or two tables in which we want to apply joins, then there won't be any results and the result sets. So the basic prerequisite is that
            • 121:30 - 122:00 the two tables which we are going to join should have some common values in between them. So let's take an example of inner join now. We are clear with the two tables. So this is this syntax. In select statement we'll provide what are the columns which we are going to fetch. So in this example we are fetching three columns, one column from employee table
            • 122:00 - 122:30 and two columns from the orders table. So that is the reason we have explicitly mentioned the table name, the dot followed by the column name in it. So when we use joins, it is important to provide the table name before the column name. Let's assume what will happen if I'll remove the table name. See the moment I removed the table name, I'll get an error. That ambiguous column name, employer id.
            • 122:30 - 123:00 Why ambiguous? Because if you'll see we have employee id column in employee table as well as in the orders table. So if we will not provide the table name then it is difficult for SQL server to identify that which column, we want to fetch as the same column maybe present in both the tables. But if I try to remove this table then I won't get an error.
            • 123:00 - 123:30 The reason is the order id column is unique. It is present only in the orders table and not in the employee. But it is good practice that we will provide the table name in the select statement to avoid any such issues. I hope this is clear that why will provide the table name before the column name the select statement. Because if the column name is same in parent
            • 123:30 - 124:00 and child table, then it will throw an error and we won't be able to execute our SQL queries. Because there will be an ambiguity for the same column name. If the column is unique and is not presenting both the tables, then we have the options to skip the table name before the column name. So we provide the column names in the select statement. Then we'll first provide the name of our first table
            • 124:00 - 124:30 followed by a keyword inner join. So based upon type of joint which you want to create, we'll provide these keywords. If it is left join, then we'll replace inner join with the left join. If it is right joint than replace in a join with right join. So based upon the join we'll replace this keywords. So as of now in this example I'm showing you the inner join example. So we have included the inner join keyword.
            • 124:30 - 125:00 So if you'll see we are basically joining two tables. So one is employee, the other is orders. So first we have to identify which two tables we need to consider for join. In our case we have considered employee, emp table and orders table. And the second part of join is that, how we want to join these two tables. As I mentioned, there should be some matching columns
            • 125:00 - 125:30 or matching data between these two table in order to join them. So in both the tables employee id is common and it has the matching data. So we have to specify an on condition. And then the on condition, I have mentioned that emp dot employee is equals to ordered dot employee, fetch me all those records. And then followed by the employee id. As we discussed in module two, we use order by keywords
            • 125:30 - 126:00 or order by clause to sort the data. By default, sorting is in the ascending order. If you won't provide any keyword and the order by clause, it will be always be in the ascending order. So let's execute this statement first. Yeah, so if you'll see the the table data here, we'll be getting only four records here because in the order tables, we have only four records for the employee id.
            • 126:00 - 126:30 Though we have six records in the employee table and five records in the orders tables, But matching condition is only for the four records of four rows in both the tables. In the result we will get one zero four employee id, one zero two one zero five and one zero one. Since employee id is not there in the orders table. Also one zero six is not here. That is a reason these two row will be skipped from the result set.
            • 126:30 - 127:00 As you can see, there is no row with the employee id one zero three and one zero six. So in this example, the inner joining is returning all rows from the employee and order tables where there is a matching employee id value in both the employer and orders table. That is the reason, the rows where employee id equals two one zero three and one zero six in the employee table would be omitted.
            • 127:00 - 127:30 Since they are not present in both the tables. So this the syntax which we are seeing as of now on the screen is the latest syntax, or the recommended syntax or the (mumbles) syntax. But there is an older syntax where we do not use the on keywords but still we can achieve the same result of join. Let's just have a look on the oldest syntax also because some authors or some people choose oldest syntax for the inner join and other joins.
            • 127:30 - 128:00 But this index are not recommended and if you're writing joins you have to follow the syntax which we have discussed just now. So in the oldest index we just mentioned the name of the tables and the tables will be the comma separated and instead of on conditions we include the condition in the where clause, where employee dot employee id is equals to order dot employee id, followed by the order by clause. So it is not that every time when you're writing joins,
            • 128:00 - 128:30 we have to provide the order by clause. Order by clause is always optional. So if I'll try to execute this query, I'll get the same result set. And if you want to change the sorting order, we can change it to the descending order also. And if I'll execute, the result will be in the descending order of employee id, as you can see. 105 is on the top. Again, order by is always optional and it is not mandatory to involve order by
            • 128:30 - 129:00 an inner joins or any of the query. So inner join helps us to fetch the rows from both the tables which have matching value in both the tables. That's why sometimes call it as (mumbles) joins or simple joins or inner join. So don't get confused between these synonym terms. Sometimes since we are matching the values which is common, people call this (mumbles) joins.
            • 129:00 - 129:30 It is the simplest of all the joins. So we often call it as a simpler join, as simple join. And technically this is inner join. Since we are using the inner join keyword to fetch themselves. But in the oldest syntax, we do not use inner join keywords. It is good to know about the oldest syntax, but it is not recommended to use oldest syntax going forward. Let's understand more about inner joins by helps of a Venn diagram. So best we're looking at this diagram
            • 129:30 - 130:00 you'll come to know, so we have for example, two tables, table employee and table department. As of now I've shown you the examples from orders tables, but let's assume that we are joining two tables, department and employee. So in inner join the values which is common in both the tables, so the intersecting part will be fetched in the result set. So better visualizations, you can relate inner join with this Venn diagram example.
            • 130:00 - 130:30 And if it is self join, instead of these two tables we'll join the same table. When we saw the example, when you see the syntax of inner join. See that we're using table alias here. But in our case we haven't used any table alias. Using table is optional. If I want to change to the table alias then I have to do, for example, let's say I'm writing it as E for employ
            • 130:30 - 131:00 and orders for orders, O for orders table. In that case cases I'm using alias, I have to remove the table name and have to replace with the table alias. To sum up, if you use the table alias then we cannot use a table name. We have to replace with alias only, not only the select statement, we have to use all the places for this not mandatory to use this.
            • 131:00 - 131:30 We can either give the table in other table alias. Generally we use table alias when there is a long name for the tables. Good practices is that do not provide the keywords like how I have done E and O. It has to be meaningful name. For example, let's assume the table name is employee information. So I can write the short form emp info, just looking at alias we should understand that this alias is for this particular table. So if I'll execute this statement again,
            • 131:30 - 132:00 I'll get the same results. So if we are using self-join, then it is mandatory to use the table alias because, or it is good to use, I would rather not say mandatory, it is good to use because we will be using the same table name. If I will be using the self-join, then if I'll provide the same alias, I cannot use it. Because we cannot use the same table name
            • 132:00 - 132:30 in both the clause. So let's assume that I'll remove this table then get an error because you cannot use the same table name in the inner join, as you can see the objects emp and emp in the from clause has the same exposed names. Use correlation names to distinguish name. So my first statement was right, yes, it is mandatory to use table alias when you are using self-join.
            • 132:30 - 133:00 So we can give it as E1, or we can give the same table the other alias as E2, and I can replace it with E1, E2 and E2. These columns are not there. So that is the reason it is giving an error. So we'll get this desire. So this is how we create the self-join or provide the syntax for self-join. So it is mandatory to provide the table alias in self-join
            • 133:00 - 133:30 because we cannot have the same table name in the from clause or in the inner join. I hope, self-join and inner-join is clear. And let's move to the next slide. So this is again example of inner join before we move to the next slide. So in this we are joining the department table and employee table, with the department number. So we have provide the table alias, for the department we provide the T1 and for employee T2. And when we are providing the in the select statement
            • 133:30 - 134:00 then we have to explicitly provide that which column is coming from which table. So first name is defined in the employee table, but that is the reason they're mentioned T2.first name. And this is a good example, here we are providing the alias for column name as well as table name. So alias is applicable for column name, if you want to give a meaningful name for the columns because first and sole name it is good to use in the backend.
            • 134:00 - 134:30 But if you want to show the results and the result set in the query window, or if you want to consume this result set somewhere in our programming language by meanings 80.net or any other means, then it is good to provide them meaningful and more readable names. So that is the reason we provide column alias. So let's move to next join that is left outer join. So the left outer join returns rows to the left,
            • 134:30 - 135:00 even if there is no rows on the right of the join clause. So the left and right is basically decided by the arrangement of the tables in the on clause. So this type of join, return all rows from the left hand table specified in the on clause. And on conditions, and only and only those clause from the other table where the join fields are equal
            • 135:00 - 135:30 join condition is met. So I repeated it again, as you can see the points. Second, the result is null for the row on the right table when there is no match. When they execute right outer join, it will always fetch the values from the left table. And if there is no matching terms in the right table, then those values will be replaced by a null keyword. The syntax of left join is almost similar to the inner join.
            • 135:30 - 136:00 The major differences is inner join is replaced with another keyword that is left outer join. Here the left table will be T1, and right table will be T2. So let's see an example of left outer join. So here are left table employee and the right tables is orders. So if I execute this statement,
            • 136:00 - 136:30 this is the result set. So the left outer join is basically returning all the rows from the employee table. And only those rows from the orders table where the join fields are equal or there is a matching condition. So if the employee id value in the employee table does not exist in the order table, all the fields in the order table will display the null value in the result sets.
            • 136:30 - 137:00 In this result sets the rows where employee id is 103 and 106 would be included the left outer join, but the order id and order date will displace null. So if you'll see the data, since we are using left outer join and that left table is employee. So it will fetch all the six records, 101, 102, three, four, five and six inner result sets,
            • 137:00 - 137:30 because we are fetching three columns, employer id, order id and order date. So left outer join will include all the records from the left table. That's why we are having six records in the result sets. But if there's no matching values in the right table, so our right table is orders and order id and order date are basically fetched from right table that is orders, and then the order tables, there's no value for employee id 103 and employee id 106.
            • 137:30 - 138:00 If you'll see again in the orders table, we do not have any rows with the employee id 103 and 106. So those values are replaced by null here. So that is the reason for the employee id 103 we have null values for order id and order date. Which is coming from orders table and that is the right table in the left outer join in this example.
            • 138:00 - 138:30 I repeat when we use left outer join, all the values from the left hand side table will be included in the result sets and if there are no matching records for those rows in right table, then those values will be replaced by null. In some databases, the outer keyword is omitted and basically use left join. So in some database instead of writing left outer join,
            • 138:30 - 139:00 we simply mention left join. And if I'll execute the command again I'll get the same result sets. So don't get confused between left outer join and left join. It is one in the same thing. I hope left join is clear. Let's move to other examples. So this is one more example of left outer join before we move to the next join. Here we have first name and department.
            • 139:00 - 139:30 These are from two different tables. So employee is our left table here and department is the right table. So we'll always get all the records from the left table, that is the reason if you'll see in the first name we have all the records, but in the right hand side that is a department table. For Miller, there is no value in the department. There is no department number which is there in the employee table in the department table.
            • 139:30 - 140:00 That is the reason the value is coming as null in the result set. All the values from the left table plus all the values which have them matching values and if there is no matching than it will be replaced by null keyword. So let's move to the right outer join. So right after joint returns the rows to the right relationship table, even if the is no matching rows on the left relation table. It is almost similar to the left outer join,
            • 140:00 - 140:30 only the conditions as reversed in right outer join. That result is not for the rows on the left table when there is no match, whereas in the left outer join the result is null for the right table when there is no match. If you'll see the syntax, only difference here in the syntax is in the right join we basically use right outer join as a keyword, whereas in a left outer join and you left outer join as the keywords for join.
            • 140:30 - 141:00 So right after joint returns all the rows from the right table specified in the on conditions and only those rows from other table where the join tables are equal will be fetched. And as I mentioned in the point two, if there is no match the results will be null in the result sets. Again, it is not mandatory to have the outer keyword. We can simply use right join as well.
            • 141:00 - 141:30 Don't get confused between right outer join and right join. These are one in the same thing. So let's see an example of right outer join, or right join. In this example, right table is orders, so we'll get all the results, or all the rows from the right table. As you can see, I'm fetching,
            • 141:30 - 142:00 let me first use change order by clause instead of employee id, let me fetch it using the order id, order by, order id and descending. order by, order id and descending. Let me execute the statement again. As you can see we have sorted this using the order id, the result sets. Since orders is the right table, we have all the records from the orders table, but since there's no matching records in the employee id,
            • 142:00 - 142:30 we're getting it as a null value. So in this example, the right outer join is there turning all rows from the order table and only and only those rows from the employee table where the join fields are equal. So it is almost a reverse of the left outer join. I hope this is clear. So let's understand left outer join, right outer join by help of a diagram. So if you'll see this is example of left join example here,
            • 142:30 - 143:00 bottom left. So in this example we are considering these two tables, employee and department. So if you'll see all the records from the table employee will be included in the result set. Whereas only those records from the department table will be considered, which are common in both the tables or which has a matching value in the employee table. So this is a good example, or good example to understand the left outer join.
            • 143:00 - 143:30 Same if you'll see the right join example, in the result sets all the records from the department they will will be included but from the employee table only those records will be included which has a matching value in the department table. And the right bottom you can see this is an example of a self-join, we are connecting to itself. The table employee is connected to itself. And as we mentioned it is very important
            • 143:30 - 144:00 to provide the table alias if you are using self-join because we cannot have the same table name in both the conditions. So I hope by looking at this example it's more clear to you the basic concept of join. Other than that we just have to follow the syntax and we have to take care about that which table we are placing in the on condition that is defined that which one will be our left table or which one will be our right table. So the placement of table in the query is very important.
            • 144:00 - 144:30 If we are looking for left and right join. If we are considering it as inner join, then the order and placement does not make any sense because we are going to fetch only those records which have the matching values in both the tables. So the placement of tables in the query is important. If we are writing left outer join or left join or right outer join or right join. So let's move to the next example.
            • 144:30 - 145:00 Full outer join. So the full outer join keywords returns all records when there is a match in either left or right table records. If there are rows in table one that do not have matches in table two or their rows in table T2 that do not have matches in table T1, those rows will be listed as well. It means all the rows from the left
            • 145:00 - 145:30 and all the rows from right will be included in the result sets and if there is no matching values that it will be replaced with null keyboard. If you look at the syntax. Syntax is almost similar. We have to just replace the inner join or left outer join with the full outer join here. So it is very easy to work with the joins. If we know the syntax of any one join then it is very easy for us to frame the syntax for other joins also.
            • 145:30 - 146:00 All we have to do is that we have to replace the main keyword, what kind of join we are working with. If it is inner join we have to mention inner join, if it is left then you can mention either left outer join or left join. Only thing which we need to consider for this left and right join is the placement of table on conditions. So this is an example of full outer join. So I'm selecting it as a first name and department from employees T1, full outer join department as T2,
            • 146:00 - 146:30 and then there's a join conditions on department number on department. So though we are getting the results from both of the table, but still we have to provide the matching condition. So if there is no matching condition, then only the null value will be included in the result sets. So it is not that since we are you know, fetching all the rows from both the tables though we should not provide the join condition. So let's see an example of full outer join.
            • 146:30 - 147:00 So we have all the records and if there is no matching values then we'll have the null keyword. So if you'll see we have the seven records here, when I execute left outer join then we have six records. But here we'll be getting the results from both the tables. So there's no matching values for order id five in the employee table. That's why the first two is null here.
            • 147:00 - 147:30 Same way there's no matching really for employee id 103 and 106 in the orders tables. That's why the order id and order date is null for these columns. Again, we can omit the outer keywords from here instead of full outer join, we can simply say full join. So we can always omit outer keyword from all these joins, whether it is left, right or full. So full outer join will return all the rows
            • 147:30 - 148:00 from the employee table and all the rows from the employee table. Whenever the join condition is not met a null value will be included in the result set. So let's understand it with diagram for better clarity. So if you'll see here in the full join example, the entire area is colored because we are fetching all the rows from employee as well as all the rows from department, including the matching values.
            • 148:00 - 148:30 So if there is a matching values that will be included in the result sets. If not, null of will be included. I hope this is clear. Let's move to the next join, cross join. This is also called the Cartesian product and it displays all rows and all columns of both the table. So what do you mean by Cartesian products? Let's understand it. If you'll see in the upper right corner we have the cross join example.
            • 148:30 - 149:00 So one will be multiplied with all the three values, one, two, three from the department table. Same way, value two will be multiplied with all the three values of the department table. Same is the case with employee name three, it will be multiplied with or. So they will be Cartesian product. That is why it is also called as Cartesian product. So some people call it cross join or some people refer to as a Cartesian product. So let's see or understand with this example.
            • 149:00 - 149:30 See the number of rows. we have only six rows and five rows in here. So six into five since it's the Cartesian product. So we'll be getting 30 rows. So each row will be multiplied with all the rows of another table. We have six rules in the employee table and five rows in the order table. That's why we're getting 30 rules in the result sets.
            • 149:30 - 150:00 So this is all about cross join. So we have discussed all joins, right from simple joins, inner join, left join, right outer join or right join and full outer join. All the examples which we have discussed, we have not included any other, you know where clause of group by clause or having clause. So as of now we have not providing any filters. We are just fetching all the rows even in the inner joins
            • 150:00 - 150:30 we are fetching all the rows. But in practical scenario it is not that every time we need to fetch all the records which have a matching value, so we have to provide some conditions or some filtering conditions to get the desired result sets. So let's revisit the inner join example. So we can add a condition, for example where emp dot employee id is greater than 104.
            • 150:30 - 151:00 So only those records will be included. So if you'll see. We have only one employee id which is greater than 104. And which has a matching value with both the tables. If I'll make it 102, then I'll get two values. Because 103 and 106 do not have matching values in both the tables. If I'll skip the where clause
            • 151:00 - 151:30 and how it can skip by using a single line comments. Now we have the four records in my result sets. When including where clause I'm filtering the records and the result sets to two. So we can use where clause, we can use order by clause and on order by clause also it's not that we have to always provide the ascending. We can provide the descending keywords also. And let's see what if I'll instead providing the column names here. What if will provide the asterisk or star.
            • 151:30 - 152:00 Lets execute this. In that case I will be having all the columns from both the tables. When we used to provide the asterisk mark, when we fetching the results from a single table, then only the columns from that tables would be included in the result sets. Since we are creating joins or working on joins and if we'll provide asterisk in the select statement, then all the columns from both the tables will be included in the result sets.
            • 152:00 - 152:30 As per the business requirement, we include all the columns or the required columns from both the tables. Important part here is that as we discuss earlier also, if the column is same in both the tables, then we have to have a prefix of table alias. Or else we will get an error that column is ambiguous between two tables. So far in all the examples which we have discussed,
            • 152:30 - 153:00 or which we have executed in management studio we have considered only two tables, but it is not that we can always join only two tables, if there's a business requirement we can join three tables, four tables and five tables. The syntax is same, only thing is that we need to keep on adding the other tables and the join condition using the on keyword. For beginner level you can start with joining two tables.
            • 153:00 - 153:30 So the important criteria for joining two tables is there should be at least one matching columns between these two tables. Some people say that you joined when there is a foreign key, primary key relationship between two tables. It is good to have primary key foreign for key relationship between the two tables, but it is not mandatory that if the two tables are related using foreign key, then only we can apply the joins. We can very much apply the joins if there is a matching columns between both the columns
            • 153:30 - 154:00 though there might not be any foreign key or even primary key. The result in a result set will be exactly similar if we're joining two tables having foreign key, primary key and other two tables which not have any such relationship. Foreign key, primary key basically helps us in adding constraints. If we have some records in my child table which is referring or which is referencing the record in parent table, if you try to delete some record from the parent table, we'll get an error that that record has been referenced.
            • 154:00 - 154:30 So foreign key, primary key, helps us in achieving referential integrity constraints on our database, but that is not a mandatory conditions to have join in the tables. Built-in functions are used to calculate values and manipulate data. These functions can be used anywhere as expressions. When we say anywhere it means we can use them in the select query, we can use them in where clause,
            • 154:30 - 155:00 we can use them in having clause. So these built-in functions can be used anywhere based upon the business requirement, or based upon the type of functions which we are using. So we broadly categorize the various built-in functions into the following categories as you can see on the screen. So we can divide the built-in functions into conversation functions where we can convert the values from one data type to another data type. We have logical functions, math functions to play around with the data,
            • 155:00 - 155:30 mathematical or operations, we generally use math functions. Aggregate functions, if you want to calculate for example average, we want to calculate sum or total of salary of all the employees. Then we use aggregate functions. A string functions helps us to play around with various strings or characters in our data. Most of the string functions are somewhat similar to the string functions
            • 155:30 - 156:00 which we have in other programming language or the basic programming languages is like CC plus plus, C sharp or Java. Date functions have all the basic functions which we can use to manipulate date or a retrieve date from our database. So let's discuss all of the functions one by one in coming slides. As we discussed that these are the various categories again, conversion functions that support data type casting and converting. Logical functions are scalar functions that perform logical operations.
            • 156:00 - 156:30 These are kind of similar to the math functions, are again the scalar functions which performs calculations usually based on the input values that I've provided as an argument. And most of the times the returns are numeric value. Aggregate functions, as I mentioned we use some views, average, we use maximum of values, so aggregate functions basically perform a calculation on a set of values and they return a single value except for the count.
            • 156:30 - 157:00 So count is also an aggregate functions other than count, all of that aggregate functions ignore null values. In the objective we saw that we are going to discuss about the group by and having clause. So aggregate functions are frequently used with a group by clause of the select statement. All we can say that we use group by clause only with the aggregate functions, or group functions. Some people refers aggregate functions as a group functions, so don't get confused.
            • 157:00 - 157:30 They are one and the same thing. String functions again as scalar functions and the performance an operations on a string input value and return the strings on numerical value, based upon the kind of functions which we are using. Date functions, straightforward it manipulates the dates. So let's start with the conversion functions, as the name itself suggests that, these functions helps us to convert an expressions or a value from one data type to another.
            • 157:30 - 158:00 So we have three commonly used conversion functions, cost, convert and pass. And in the bottom three you can see that we have try_cast, we have try_convert, try_pass. So the top three and bottom three they give the same results. They work in the similar fashion. The only difference here is that the top three functions returns value of specified data type and on success throw errors on failure.
            • 158:00 - 158:30 Whereas the bottom three, they give the null values on failure. So we can relate this try as like how we have the try catch block in other programming language to handle the exception. Same way we used try_cast if you want to get the null values if something wrong happen while calculating the expressions, or while fetching the results. Same is the case with try_convert and try_pass. But if any error happened while using cast converting
            • 158:30 - 159:00 we'll get an exceptions, or we'll get an error. Whereas error can be handled by converting it to the null values. If you use try_cast, try_convert and try_pass. So as you can see on the slide we are converting the value, then as int and we're multiplying by 20. Again, we are converting int, 10 to int. And again we are doing a multiplication of the value
            • 159:00 - 159:30 after conversion with 20. So that what is the difference between cast and convert? Because the end result is almost similar. So both function can be used interchangeably in most of the situations. The only difference is that cast is NC SQL compliant. It follows American National Standard Institute, whereas convert does not follow any such compliance. Let's see an example of these basic operation. So I'll open management studio of SQL,
            • 159:30 - 160:00 let open a new query and let me copy the example. So let me copy both the examples. I increase the font size. So if I'll execute, I'm getting this result. Since we are converting 10 as int and again if you'll see the result of cast function and convert functions is exactly similar. Only difference is in the syntax.
            • 160:00 - 160:30 The syntax of convert function is different from cast function. So one important of point I just want to mention here is that, in select operation we can use mathematical operators like, we can use plus, minus, divide and multiplications. So here after converting 10 into int, we are multiplying it with 20 to get the end result. And this is the alias which we discussed in module two. So we can change it,
            • 160:30 - 161:00 we can change it to any value, we can change it. Let's say I'm writing it to cast result and I can change it to convert result and if I'll execute it I'll get the same results. Cast results and convert result here are alias. These are the alias for the columns. In the model three we saw that we use alias for the table. So let's see that if there's an issue while casting
            • 161:00 - 161:30 or converting a desired value, then we'll get an error when we'll use cast and convert. But we'll get a null value when we'll use try cast and try convert. Let's verify this using an example. So I'm trying to convert character into int. So we'll get an error. That conversion fail when converting the where care value A two data type int. Now let's use try cast.
            • 161:30 - 162:00 So I'll copy this statement. So let's assume I used to try convert and if I'll try to convert a value which is not numeric and if I'll executed it we'll get the incorrect syntax near the keyword try convert. Sorry, I forgot to write select. And if I'll execute it now we'll get null value.
            • 162:00 - 162:30 So instead of error, we are getting a null value if you'll use try convert or try cast. So based upon the business requirement we'll choose either the try convert or convert. Let's move to the next function. Let's discuss about the logical functions. So we have two logical function, choose and if. Logical functions can be used to display one of the several values based on a logical conditions.
            • 162:30 - 163:00 As we have discussed, we have two logical function choose and if. Choose returns as specified index from a list of values. And returns null if the index is zero or greater than the number of items. Or we can say that the choose basically act as index into an error. When an area is composed of the argument that followed the index argument. So as you can see in syntax, we have the choose keyword and in the parenthesis we have index.
            • 163:00 - 163:30 So this is the index which we have to define that what value we want to return. And this val one, value two and we can have up to value n. So let's understand choose by an example. So let me write one example, so that could help us to understand. Choose keyboards, and all these functions are basically, can you see the color code?
            • 163:30 - 164:00 For the keywords, we basically have blue colors, but for this functions we have pink color. So we'll define three. This is the index and then followed by the various values. Let's say I have test as of one value. I have just as another value. Third value I'll be having rest.
            • 164:00 - 164:30 So if I'll execute this statement, I should get the value rest because this index did not start with zero. Please note it down. In the choose function, the index start from one. This is one base index, not the zero based index, like we have in most programming languages. So if I'll execute this statement, I'll get rest because we are instructing the SQL server that we want the third value,
            • 164:30 - 165:00 after the various values available. The choose function basically gives an error. If you try to use the index as the value zero or we'll try to provide the index which is outside this range. So let's understand it by an example. So if I'll provide index zero, if I execute this, I'll get a null value. Or if I'll provide the index
            • 165:00 - 165:30 which is outside the bounds of this error. When I say bound, if it is more than the number of values which we are trying to select from, then again it will return a null value. So this is their are only four values here and I'm giving index five. So since there's no value add the fifth index, it will return a null. It won't give us zero. So choose functions helps us to select from a given range of values, like how we used to fetch the values from an array.
            • 165:30 - 166:00 So let's discuss the other logical function. So here, before we discuss the if, let's see these examples as well. So in the first example where using select choose and we are giving index 2A, B and C. These are the three values. So this will, the first example will return the value B in the results set because we'll count from the index one, as I mentioned, that choose is based on one index and not the zero index. So let's take the case of the second example.
            • 166:00 - 166:30 Here, we have not provided an integer. If our fraction value 1.4, so choose only consider the integer value. In both the cases it will return A as in the result set. So now let's discuss the other logical function. If so, let's focus on this syntax first. So it's followed by if keyword and then we have a boolean expression and then true values and false values.
            • 166:30 - 167:00 So when we exit this function, it returns one of the two values. Either it will then true value or either it will return false value. So the output, whether it is a true or false, depending upon the evolution of boolean expression, which we'll provide in that if function. So if it's a shortened way of writing a case expression, it evaluates a boolean expression fast as the first argument and then returns either of the two arguments based on the results of the evolution.
            • 167:00 - 167:30 So we can even provide the nesting in the if functions. The nesting should be up to 10 levels, similar to the nesting which we can have in the case expression. As it is almost similar to the case expression. So let's see our discuss the example of if logical function. So in this case it will written false because this boolean expression is not satisfying. One is not greater than 10, so it will fetch the result falls in the results set.
            • 167:30 - 168:00 Let's execute this example in management studio. If you write if, if then you have to write the boolean expression than any value. Let's say I'm just writing true and the next venue, if it turns out to be false, let's see example. The example seems to be right.
            • 168:00 - 168:30 Let me copy from here. Okay, so we forward to add the select keywords. Sorry about that. And for I'll execute it will return to false. So since there's no header for the column name, we can provide an alias as well. If I'll make this statement as true, if I'll felt divorce the values here, then I even get through as an output in my result set.
            • 168:30 - 169:00 So, as I mentioned, if works like a case expression and we can nest it and nesting can allowed up to 10 level. So this is all about logical functions. So let's continue with other categories of functions. So let's just goes about the math functions. So math functions can be used to calculate business and engineering calculations. So these are various self-explanatory and we must have used these functions
            • 169:00 - 169:30 during our engineering classes or any other classes where you do any engineering calculation. For example, when we convert it into an absolute positive value then the use ABS functions. If we want to generate a random float values from zero to one, then we use rand function. Seed is an optional value here. If you want to return an exponential value than we use exp function, in most of the mathematical values we need to round up the values when the values are of decimals than we use down functions.
            • 169:30 - 170:00 So round returns and numerical value around it to a specific length of positions that we need to provide in the functions. Floor provides or it returns the largest integer less than or equals to the specified numerical expressions. Then we have square root, square root returns the square root of the specified float value. Saving is just opposite of the flow and it returns the smallest integer,
            • 170:00 - 170:30 greater than or equal to the specified numeric expression. Square again, as we know the square, square of two is four. So like we use the square functions to calculate the square of the specified float value. Power, power basically returns the value of the specified expression to the specified power. So these are the standard mathematical functions. We have used these functions. So here we can see a consolidated examples of all mathematical functions.
            • 170:30 - 171:00 So in the first example we see select ABS minus 10. So here we are using absolute value. So it is converting the negative values to the positive value. And all these keywords are we're using as alias. So we are using ABS as alias for the first column. Rand as we discuss, Rand is basically helps us to get any random values, we can provide the seed as optional. When you use this functions,
            • 171:00 - 171:30 as you can see we are getting at random value here. Exp four it basically helps us to get the explanation value. Floor, we use floor so it will get the value. 4.66 will get the value four here, and floor we'll get the value less than the nearest integer in the ceiling we'll get the values greater than the nearest integer. If I'll use floor 4.66 I'm getting the value four when I'm using ceiling, I'm getting very five here. Square root, the square root of 2.56 is 1.6.
            • 171:30 - 172:00 So this is the value we are getting. Square is just opposed to the square root. So we'll get the square of a digit we should provide in that parenthesis. So we have provided a value four, so we are getting 16 at this result. Power to three, so we are basically giving power three the base value here is the two and three is it's exponential value. To the power three, we'll get eight. It's states, if you own expand this, it's two into two into two. So they're getting eight as it results.
            • 172:00 - 172:30 Round functions is basically it's too round the values and we are using two as a decision value. So we are provided to it is basically rounded up to 2.57. So let's execute few of the examples in management studio for better clarity. Let's use the square function and square root function first. The square root of 16, and always use the select statement or else we'll get an error.
            • 172:30 - 173:00 So I can even do like multiplications of various, I can use where's mathematical functions and then I can multiply it or I can use other operators like plus minus. If I'll execute this, so what I'm doing is I'm taking the square root of 16 that will four, taking square four that is 16. So end results should be 64, yep, so if we get the results. As you can see guys,
            • 173:00 - 173:30 when we don't give the name of the column. The header is blank. So it is good practice to provide the alias. As of now I'm giving a standard result set. If I'll execute it now I'll get 64 it's value. I can't even use other mathematical operator, I can use plus, so we'll provide the sum of these two values. 16 plus four, 20. So I'll get 20 in the result sets.
            • 173:30 - 174:00 I'm getting minus 12 its value. And let's see, can we clutch the functions here? So let me write, select and if I'll use apps function here. So now I should be getting plus 12 because I'm using absolute function so it will convert the negative value into positive values. So we can use, we can club, we can nest the functions. So here in the ABS functions,
            • 174:00 - 174:30 I'm using a security functions and square functions. We can play around with these functions as per our business requirement. Let's use an example of power. Let's use the base value as two. Two to the power four. So the results will be 16. So this is equal to, sorry,
            • 174:30 - 175:00 if I'll expand this power, two is the base and four is the expansion. So I'll get the same result set 16. So this is all about the maths functions. That's moves to another category. Ignores null values. Aggregate functions are frequently used with the group by clause and for a filtering. Like we used to filter the data using where clause. So if you're using group by clause, then we use having keyboard to filter the result set.
            • 175:00 - 175:30 So we have a following aggregate functions. We have average min, sum, count and max. Let's start at average function first. Average returns the average of the values in a group as we discussed null values ignored. So let's take an example of average function. First, let me fetch the values from department table.
            • 175:30 - 176:00 Okay. So I can use the average functions on department number column. So I can write select average and write the column number from department. If I'll execute this, I'll get the average of the values. Let me execute both the queries in one go so we can compare the results. So 25 is the average of 40, plus 30, plus 20,
            • 176:00 - 176:30 10 divided by four. So we can use average function with the distinct keyword. We discuss about the distinct keyword in module two. So distinct keyword helps us to fetch the unique record. If you want to find the average of the distinct values, then we'll provide the distinct keyword before the column name. So let's take another example of the average function.
            • 176:30 - 177:00 Let me get the results from employee table. So as we discuss that average functions ignores the null values. So if I'll try to get the average of salaries. So we have only three rows where the salaries present, rest all the values undone. And then let's see what is the result. Select average,
            • 177:00 - 177:30 provide the name of the column, from employee. So this is the average. So let me execute both the statement in one go, like I did earlier. So you're getting the average of this. So we can use average with the distinct keywords if you want to fetch the results. Okay, let's see whether we can apply the district here.
            • 177:30 - 178:00 So in the department one table, we have the repeated values for the department number. So if we want to ignore that repeated or redundant data or the duplicate data, then I can use the distinct keyboard. If I executed now, I'll get the average as 25. But if I remove the distinct keyword, the result set will be different. Sorry, my bad. I'm using department column.
            • 178:00 - 178:30 I have to change to department one. So let's first see the results that without using the distinct keyword, the results is 30. Now I'll use the keyword distinct. Value is different because I'm just taking the unique values for my result set. So let's move to another aggregate function. Let's discuss the min function. Similar to average, min also ignores the null value
            • 178:30 - 179:00 and if returns the minimum value in the expression. So if I'll see the values in the department one table, and if I try to find the lowest value of the department number, then I have to use the main function. Okay? So out of all the aggregate functions, count is the only one which considers or which takes into account the null values as well. So let's see the example of count. Let's move to management studio.
            • 179:00 - 179:30 So I'll be using employee table 'cause we have lot of null values in those. I'll execute this. So let's take the count of the salary column. Select count. Oh I have to write the column name, employee. Oh I have to write the column name, employee.
            • 179:30 - 180:00 So if I'll execute, I'll get three results. But if I execute star, I'll get nine columns. But if I execute star, I'll get nine columns. Even we can use the distinct operation here, in the count function. So count basically fetch the count of rows from a table.
            • 180:00 - 180:30 So let's move to another aggregate function. We have max. So max is exactly opposite of min. We've already shown an example of minimum. So max, we can use it for numeric as well as with the character data type. If you use for the character data type, it will show the maximum value, or in the sorting order. If you use with the numeric, then of course it will show the maximum of the value. Though let's see, an example of max as well.
            • 180:30 - 181:00 So if I'll use max, we are trying to find the maximum salary from employee table. So this is the maximum salary. And if I try to find the location let me first show you the various location from the department table. So as for the sorting order, we should get Hyderabad, if you'll use max for this column.
            • 181:00 - 181:30 so let me write the query. Select max loc from department table. Select max loc from department table. Then we can provide in alias as location. So we get Hyderabad in my result set. So we have to discuss all aggregate functions. common aggregate functions are average. If you get the average of values,
            • 181:30 - 182:00 min as names suggest, the is the minimum value in the expression. Sum helps us defining of the total for a column. Sum only accepts the numeric value count returns the number of items or rows in a group or in a table. Max returns the maximum value in the expression. So let's move to other category of functions. So these are the various examples, before we move to other functions lets see the examples here. So in one example of shown all the aggregate functions,
            • 182:00 - 182:30 so we can use multiple aggregate functions in a single statement, a single select statement. So in the single select statement, we have used average of salary, minium of salary, maximum of salary, and sum of salary from employee table. Second example is for the count functions. So we will discuss about the group functions and having functions, once we are done with most of the outer box functions. And then we have string functions.
            • 182:30 - 183:00 String functions are against scalar functions and they perform an operations on a string input value. And the return is string or numeric value based upon the type of functions which we are using. When string functions are passed arguments that are not string values, the input type is implicitly converted to a text data type. So these are the various string functions. LTRIM, it basically returns a character expression after it removes leading blanks.
            • 183:00 - 183:30 It basically removes the blanks from the left hand side of the string. We have our RTRIM, it returns the character string after truncating all the trailing blanks, basically it remove the blank from the right hand side of a string. CHAR functions converts an int ASCII code to a character. CHARINDEX find out, searches an expressions for another expressions and returns its starting positions if found.
            • 183:30 - 184:00 STR returns character data converted from numeric data. CONCAT, return a string that is results of concatenating two or more string values. So these functions are almost similar to other string functions which we use in other programming languages. Most of the programming languages, we have trim functions. We have our functions to find out the index of a character. We use a concatenating and operation, this is a very common string functions to concatenate.
            • 184:00 - 184:30 Two strings, or more than two strings. Then we have replace functions. So replace all occurrence of a specified string value with another specific value. We have substring, it returns part of the character or text based upon the length or that start index which we give in. As we can see that syntax of the substring, we have a substring, a keyword followed by the expression like the string from which we will want to find out
            • 184:30 - 185:00 the part of a character. We'll define the start index. And then we'll define the length that from start index till how many characters we want to fetch the substring. Then we have the format functions. We can format strings in the desire format using the culture. Then have left functions. It returns the left part of a character string. The opposite of left is the right functions, which returns the right part of a character string. Reverse, return the reverse order of a string value. Upper functions at converts the string into upper case,
            • 185:00 - 185:30 opposite of which is the lower functions which converts the expressions into lower case. And in the end we have length function or LEN, which basically a returns the number of characters of the specified string and exclude the trailing blanks. So these are the various examples on our slide. so first one is for the replace function. So this is our a string
            • 185:30 - 186:00 and this string, we are replacing CDE with xxx as a replace. As you can see in the results set here for the replace column. The value CDE is replaced with triple x. We have sub string functions in the sub string. We all get out of this ABCDEF, which is our main string from index two and (mumbles) we are getting the sub string. So index two is start from B
            • 186:00 - 186:30 and then up to three character we'll get the sub strings. So we'll get B, C and D in our output. Then we have left. So basically written the left from a character index. So from index two, we are getting the values the values from the left, it is A and B. From the right, we are getting the value of B C D. In the end we have the examples of date and time and format. So here we are provided the various cultural values,
            • 186:30 - 187:00 so forces for a US English, second is for British English and third is for the German. So based upon the info culture, we basically get the different results here. So most of the string functions are pretty much straightforward. So let's discuss about a few of them. So we'll discuss about a reverse, so I'm adding a string, A B C. Again, if I were to write the select statement, it will give me an error
            • 187:00 - 187:30 if I'll try to execute this statement without select. And if I'll executed it now, I'll get the reverse of the string. Always good to provide the alias. Then we have trim on the LTRIM, select LTRIM. So I've added a leading blank spaces in this string
            • 187:30 - 188:00 and if I'll execute this, that leading spaces has been trimmed. Same way I can use RTRIM. If I'll use RTRIM, that only the trailing spaces will be removed, not the leading one. If I execute this, I'll get this result. And if I'll use trim, that will consider for both. I do not have trim here. So LTRIM removes the leading spaces and RTRIM removes
            • 188:00 - 188:30 the trailing spaces. This is all about the string functions. You can practice about the other string functions, they are pretty much straightforward. Let's see an example for the upper and lower functions as well. So if I'll use lower here, I'll get the same result. So if I'll use lower here, I'll get the same result. But if I'll use, or let me convert, let me first write
            • 188:30 - 189:00 the uppercase characters, it's converting to lowercase. And if I'll write the lower case. If I'll use the upper function, it can work it into uppercase. So all other string functions are also self-explanatory. Please try all of them so that you will have an idea and if you will try all of these, you will come to know that if the situations arise you can start using those. So let's move to other functions,
            • 189:00 - 189:30 the date and time functions. So date and time functions are against scalar function that performs and operations on a date and time input value. And returns either a string, numeric or date and time value. So as you can see in the screen, they are various date and time functions. Again, we have SYSDATETIME. It returns a date time value that contains the date and time, its current time stamp, against return at date time value that contains the date and time. Date part basically fetch as the date part
            • 189:30 - 190:00 of a data component. Day, month, year, returns an integer that represents the day, month and year part of the specific date. DATEDIFF returns the number of date or time datepart boundaries that are crossed between two specific dates. And DATEADD functions returns a new date time values by adding an interval to the specific part. So let's see the examples of date and time functions, since date time it returns the system date time.
            • 190:00 - 190:30 It has date component as well as the time component. Current timestamp also gives the current date and time. Date part basically provides if I'll provide year here then it is providing the year of the date part. If I provide here, the DD, it provides the day, if I'll provide MM, it will provide or fetch the value of the month. Date different. So again, if we, here we are providing MM So we are getting the difference of month between these two dates.
            • 190:30 - 191:00 If I'll provide DD then it will provide me the difference of days between the two dates. So DATEADD is that I'm adding two months. So this is how we have to do since we are provided MM. MM specify for months here. If I'll provide the DD then it add two days, since we have provided MM here. So it will add two months to the current date. So let's even example here, DATEPART. Year.
            • 191:00 - 191:30 Now let's say, MM. And then we can provide the date. This providing the month. So 12 months as I'm using December. If I'll change it to October. And I'll execute it again it will show me that value 10. So this is how we use the data part and let's see the DATEADD function.
            • 191:30 - 192:00 So if I'll execute it now. It will add two months. I can also provide DD here. So it will add two days, this is all about the date functions. So now let's discuss about the group by clause and having clause. So as you can see, we are using group by keyword here
            • 192:00 - 192:30 and we're using having keyword here. So let's discuss about the group by and having clause. Lets discuss group by first, the SQL group by clause is used along with the group functions to retrieve data, group according to one or more columns. The important part here is that the group by clause should contain all the columns in the select list, except those used along with the group functions. So let's see an example of group by functions
            • 192:30 - 193:00 for better understanding. Lets move to management studio and we will use department one table for group by clause. Let me first execute this query. So what am I going to do, I'm going to group by the department number. So I'll find select, count of rows from department one. count of rows from department one.
            • 193:00 - 193:30 Then I'll use group by keyword and I want to group the data by department number. So can you see it's grouped, or even I can write the department number and let's me write the alias for this and I'm writing the alias here as
            • 193:30 - 194:00 department number. If I'll execute this I'll get, so we have count four for the department number there are four values for the department number 20. Same way, five values for department number 30. Five values for 40. One values for department number 50. One value for department number 80. So we use group by functions generally in association with aggregate functions. It helps us in grouping the data in a table.
            • 194:00 - 194:30 The important part here is that we have to use all the columns in the group by which are there in a select statement. So if I'll try to include location here, there's one more column locations in that department one table but if you're trying to execute it now I'll get an error, because all the columns other than the aggregate functions should be there and the group by clause. If I'll include the other tables as well
            • 194:30 - 195:00 then the query will be executed successfully. So to in order to execute group by successfully we have to include all the columns which we are including the select statement in the group by clause. And also we can include multiple columns in the group by clause. It is not that we have to use only the single column. So group helps us to group the data in a single table and it is generally used along with
            • 195:00 - 195:30 other aggregate functions. So let's see the example. So here we are basically again grouping by the department number here. So let me fetch the results from the employee table. So here we can group the records again using the department number.
            • 195:30 - 196:00 Or using the job id, so if I were to use for the employee table I'll write select job id, job_id. I'll write select job id, job_id. And then again I can use for example, lets say count, it's not that we have to always use the count aggregate function. We can use other aggregate functions also from employee. We can use other aggregate functions also from employee.
            • 196:00 - 196:30 And then I'll write, group by job id. So this will group the data according to the job. So only for a job id seven we have two rows, for all other job ids we have a single row. So we are clear with the group by, now let's discuss with, lets discuss the having a keyword. So the having clause was added to SQL
            • 196:30 - 197:00 because the where keyword would not be used with the aggregate function. We cannot use a where keyword with this aggregate function. So having applies to the summarize group records whereas where applies to the individual records. So for the summarize record or the group, when we use group by then we have to use having, and if it is the individual records, then we'll use the where clause. If we'll use the having clause, only the groups that meets the having criteria
            • 197:00 - 197:30 will be returned in the result sets. And having keyword requires that we'll use group by in our SQL query. So we can say that having clause is used in combination with the group by clause to restrict the group of returned rows to only those which is matching that conditions or where the conditions is true. So lets see an example.
            • 197:30 - 198:00 So here in this example we are selecting the department number, taking the average salary, minimum salary and the maximum salary and we are finding that if the having the sum of the salary is greater than 3,000 fetches only those results. So lets write, let's see this example in the management studio. And I can write here having salary greater than And I can write here having salary greater than let's say 30,000.
            • 198:00 - 198:30 We have to include the, where the minimum salary, you have to use the aggregate functions in the having clause. Yeah, so we get only two results. So let me first show you the result sets. So we have three rows which are having the value for the salary column, J4 for having salary of 40,000. G5 is blank.
            • 198:30 - 199:00 So we have J6 as 500,000 and then we have the J1 as 30K. So as per our query we should get only the two results. That is J4 and J6 because these are the only two rows which are satisfying the having clause. So having this kind of we used to filter the result sets, but with the aggregate functions we cannot use where command so we are supposed to use having clause. This is it about the various outer box SQL functions.
            • 199:00 - 199:30 And first we'll discuss about the stored procedure. A stored procedure is a set of SQL statements with a name that has been created and stored in the database. So then the execute or when we write SQL statement, but we are not storing those queries. But in store procedure we can write a set of SQL statements and we can execute them and they can stored in a server. So every time I don't have to write SQL queries,
            • 199:30 - 200:00 I can write my business logic and the store procedure. So store procedures can be defined as a set of logical group of SQL statements which are grouped to perform a specific task. So basically in store procedure we write most of our business logic. It's like other programming languages. Store procedures accepts input parameters. They return multiple values by means of out parameters or output parameters.
            • 200:00 - 200:30 They contain programming statements. A store processor can call other store procedures or functions or return status to indicate success or failure. Let's see the syntax of store procedure first. So this is the syntax, we have create keyword. To create a store procedure, we have to write create, followed by a keyword procedure, name of the store procedure which we want to create. If you want to provide any parameter in the store procedure then we'll provide the parameter name.
            • 200:30 - 201:00 If want to create the parameter as output parameter then we have to use the keyword out or output, followed by as keyword and we'll write begin and whatever the statement or competitions we want, we'll write that and the end we have write and keyword. So in the syntax it is mentioned that it is create or alter. So if you want to modify the existing store procedure then we have to use the keyword alter. If we are creating the store procedure first time,
            • 201:00 - 201:30 then we have to use the keyboard create. So alter keyword is used if you want to modify any existing store procedure. Now why we create store procedure when we can write SQL queries. So here are some of the benefits of creating store procedure. All commands in a store procedure are executed as a single batch of code. When we aggregate queries in SQL, generally each query goes as a single batch.
            • 201:30 - 202:00 But when we execute store procedure, though it may have multiple SQL statement, all SQL statement are executed as a single batch of code. So by doing this it reduced the server or client network traffic and improves the performance. Store procedure helps us in achieving strong security in SQL because we can impersonate another user, execute as can be specified to enable impersonating another user to perform certain database task
            • 202:00 - 202:30 without providing direct permissions to the procedure. So it makes our environment more secure. Reuse of code. Store procedures helps us in achieving reusability because as we discussed in the previous slides that we can call another functions or store procedures from one store procedures. Easier maintenance. Changes need to be done within the store procedure, which handles all DB operations and no changes are required
            • 202:30 - 203:00 in client applications. So sometimes we move our business logic to the store procedure. So if any changes are required, we need to modify our business logic and we don't have to change our client applications, or our code. We have to just modify the store procedures and executed again. Also if there is any error we know where exactly to look for and we have for development only one store procedure instead of looking for multiple SQL statements. That is the reason store procedures are easier to maintain.
            • 203:00 - 203:30 Improved performance. All procedures by default are compiled in the database the first time it is executed and it maintains that execution plan for subsequent call. So if we'll execute or if we'll call or run the store procedure again it will take less time because there is already compiled in the database the very first time. So by doing this the performance of applications increase.
            • 203:30 - 204:00 So on the slide we can see an example of store procedure. So we creating a store procedure, so we have writing a first, the create keyword followed by the procedure, sp_GetEmployeeInfo is the name of the store procedure. This store procedure we are passing a parameter employee id who's datatype is int followed with a basic syntax. We are defining the keyword as and begin. And then we are writing the basic query that select employee id, first name, last name,
            • 204:00 - 204:30 manager id, phone number, high date, job id. These are the columns of table employ. And then we are passing that condition. We are filtering the records from employee table by using a where clause and the where clause we are not hard coding any value. We are executing it with an employer id, which is the parameter. So then we'll execute this store procedure, we will pass the parimeter. So let's see few example of the store procedure.
            • 204:30 - 205:00 So let me open management studio. Let me open the examples I already have. So let's create a store procedure without parameter first. It is not that every time when we'll create a store procedure we have to define a parameter. So I'm writing the create keyword followed by the procedure and all result keyword will be highlighted in the blue color. Then providing a name of the store procedure.
            • 205:00 - 205:30 So I can provide any name here. So I'm providing a get details or I can mention it, give it more meaning, get department details. And the store procedure I've simply written, a one select query that select star from department. And I'll execute this query. Command completed successfully means we have successfully created the store procedure in database. Now where to check for the store procedure. So I'll first expand the database under which I am creating the store procedure.
            • 205:30 - 206:00 An important thing guys is that we have to use the database first. That under which database we want to create a store procedure. So always write the name of the database, use keyword followed by a go keyword. Now if we'll try to execute this statement again. I'll get an error that this is already an object name, USP get department details in the database.
            • 206:00 - 206:30 So since I've already created this store procedure, if I'll try to create again, it will give an error. So when you provide a name of the store procedure, please ensure or please check that this the name which you're providing is unique and it does not exist in the database in which you are creating that store procedure. So if I want to check where exactly the stored procedure has been created. I have to expand the programmability folder
            • 206:30 - 207:00 under programmability folder we have a separate folder for the store procedures. Let me refresh it. So here we can see the store procedure DBP USP get department details. So from this object explorer, I can modify the store procedure, I can execute the store procedure or even I can delete it. So to delete it we have to simply click delete here. Again, reconfirm whether we actually want to delete this store procedure. And if there are any dependency of this store procedure,
            • 207:00 - 207:30 we can check it with the store dependency. So when we delete something from our database, it is better to check the dependency if there are any independency, where are the not delete that particular object. As of now we know that there's no dependency. So I'm just clicking okay here and it will delete the store procedure. Since we have deleted the store procedure, and now if I'll execute this statement again, it will be executed successfully
            • 207:30 - 208:00 as there was no store procedure and database and by execution of statement will again create that store procedure. So if I'll refresh this stored procedure again, I'll see the store procedure. Now we have created the store procedure and we'll see how we can execute the store procedure. To execute the store procedure, we have to write one command. So there are various keywords which we can use to run this as store procedure.
            • 208:00 - 208:30 The first one is we have to write this keyword exec followed by the name of the store procedure. So if I'll execute this, it will execute the store procedure and it will return the query or this result set because in the store procedure we have given only one select statement that select star from department and the department table has three columns. So we are getting all the rows because we have not specified any where condition.
            • 208:30 - 209:00 So this is an example of a store procedure without a parameter. Since the store procedure doesn't have any parameter, we are not passing any parameter while executing this as store procedure. So it is not mandatory to provide that he exec keyword while executing the store procedure. Even if you'll provide the name of the store procedure and if we'll execute it, it will fetch the same results. So exec keyword or execute keyword is optional
            • 209:00 - 209:30 while executing the stored procedure. So let me again deleted this store procedure. So while creating the store procedure again, we can either provide this create procedure or we can even provide the short form, that create proc. Even if I'll execute the statement it will be executed successfully. And if I refresh this note, we can see the store procedure has been created successfully.
            • 209:30 - 210:00 While executing again, it is optional, provide the execute keyword. Similarly, while creating the store procedure we can either provide, create proc or create procedures. Now let's see how we can create a store procedure with a parameter. So I'm opening a new query window. Increase the font size for better visibility. So this is an example of a store procedure with a parameter.
            • 210:00 - 210:30 So here we are providing the parameter department number. So here we have department number as a parameter and the data type of this parameter is nvarchar and length is 30. So in the previous example we have written our select statement but without the where clause here I'm providing or I'm filtering the record or rows by using where clause and the where clause I'm checking the department number
            • 210:30 - 211:00 with the parameter which we'll pause while executing the store procedure. So let me create the store procedure first and then we will execute it. The command completed successfully means the store procedure has been created successfully. So let's again refresh this note. Yup, so now when we are executing this store procedure, even like as we saw that we can provide the execute keyword or we can even directly write the name of the store procedure or if you're using the management studio,
            • 211:00 - 211:30 we can right click the store procedure and then we can click execute store procedure. So the execute store procedure will open this window and if there are any parameter it will pass, it will check whether what value we want to pass to this particular parameter. As we know that we have various values of department number, start from 10 to 80, so I'm passing 20 as a value for the department number and I will click okay. The moment I'll click okay I'll get this result.
            • 211:30 - 212:00 So in earlier example, we got all the rows in the result set. So if we do not want to execute the store procedure from the object explorer, then again, we have to write the same command. We have to execute keywords, followed by the name of the store procedure, and then we'll pass the parameter. In our case the parameter is department number.
            • 212:00 - 212:30 So now this will give the desired result. So this is how we create store procedure with parameter and this is how we execute the store procedure which has a parameter in it. And now I feel try to execute this store procedure without providing the parameter. Now let's see what happens. See, you'll receive an error that procedure of function
            • 212:30 - 213:00 USP get detail expect parameters which was not supplied. It means when we created the store processor, we have ensured that the parameter which we are providing in our store procedure is mandatory. Why? Because we have not explicitly or defined that this parameter can accept null value as well. So if you want to make that parameter null, then we have to explicit really provide that null keyword.
            • 213:00 - 213:30 So let me modify the store procedure or let me first delete the store procedure and we'll recreate it again. So I'm just deleting this store procedure. And in order to make our parameters optional instead of mandatory we have to provide the keyword null and I'll execute the statement again to create the store procedure. Now if I'll execute the store procedure, we won't receive an error, but we won't get the value because when we are checking the null value and if I'm not providing any null
            • 213:30 - 214:00 so it will not return any result. But yes, the error is gone. So this is how we make the parameter optional by providing the null keyword. Now let's see how we can create a store procedure with multiple parameters or is it possible to create a store procedure with multiple parameters? Yes, it is very much possible to create a store procedure which accepts multiple parameters.
            • 214:00 - 214:30 So let's see it with an example. Let me open a new query again and we already have an example handy with us. Let me paste it in management studio. So we have this store procedure and in this store procedure, we have a defined two parameters, one is department number and department name. We are make both of these parameters as optional by providing the null keyword.
            • 214:30 - 215:00 So if you want to create or if you want to define multiple parameters in the store procedure, all we have to do is that we have to separate the two parameters with the comma, that's it. Rest everything is same, we have to provide an as keyword after the parameters and then we'll write the store procedure in here, we are again are writing a select statement, but we are adding a where clause to filter the results sets by providing two conditions.
            • 215:00 - 215:30 And we are using logical operators that is and, to combine two conditions. So let me execute these statements to create a new store procedure with multiple parameters. The store procedure has been created successfully. We'll refresh this note. And this is a store procedure. So let me first see the data in our table so that we can provide the right parameters values
            • 215:30 - 216:00 to get the values and the result set. Okay, so I'll pass the parameter, department number as 50 and department name as IT. So all I have to do is, I have to provide the keyword execute, name of the store procedure get details from. Then we have to provide the value for first parameter that is department number, its value.
            • 216:00 - 216:30 So we have decided to pass its value as a 50 and then we'll provide the value for another parameter. Since it is strength, we have to enclose it as a single quotation and now like I'll execute this and we'll get the end result that department name is IT and its located in Mumbai. So this is how we'll execute and the store procedure with multiple parameters. So we write the name of the store procedure
            • 216:30 - 217:00 and followed with the first parameter then write a comma and then the second parameter, and so on. In parameters also in other store procedure. So if you want to execute it from the object explorer, then you have to right click the store procedure and click execute store procedure. And we'll get both the names, we'll pass the value here and we'll click okay. If I'll click okay now, though they won't be any result in the result set. But it won't throw any error because while you're creating the store procedur,
            • 217:00 - 217:30 we have defined that these two parameters can accept null value. So they are not mandatory. These are optional. That is the reason even though we won't provide any value, we won't receive when while exiting the store procedure. Now let's discuss about the output parameter in the store procedure. So if we want to return the value of the parameter, then we have to define an extra keyword that is out or output.
            • 217:30 - 218:00 Both keywords are valid, whether we use out or output against the name of the parameter whose value we want to return. So let's see it with an example. So I'll open a new query. In this store procedure, I have two parameters, one is the department number and one is count. So we have defined key word output, which suggests that this parameter will be the output parameter, so we can pass the value to this parameter. And this parameter will also return the value after execution.
            • 218:00 - 218:30 So we can provide the keyword output or out. There's no difference. The end result will be the same. So lets create it, we'll refresh the note of the store procedure to see the results. Yeah, we have the store procedure. Now in order to execute this, we have to do like this. We have to first declare the count int, followed by the executive name of the store procedure will provide the value. This is how we have to define if it is an output parameter
            • 218:30 - 219:00 and then we are writing the select statement to see the value of the count. So let being execute this, so the counties one because there's only one row with a department number 10. So this is how we use the output or out keyword against the paremeter. Now let's see how we can add comments in the store procedure. So we can add the comments in two ways.
            • 219:00 - 219:30 One is the line comment and one is block comments. So if you need to provide the line comments then we have to use two dash, followed by a statement. And in order to forward slash and then star, and just writing, this is multiparameter, store procedure. Having output parameter.
            • 219:30 - 220:00 Again, write star, and a forward slash. So this is how we defined the comments in a store procedure. Not in the store procedure we can write or define the comments. Anywhere in SQL queries, whether it is a functions or normal SQL statements or it is a store procedure. So line comments or single line, we use two dash, and for block comments we used forward slash and star. Let's see how we can handle the exception
            • 220:00 - 220:30 in the store procedure. So if you have handle the exceptions and your programming languages like CC plus plus or Java or C sharp, then we try catch there and along try catch sometimes we use finally block because finally always execute. So if you want to close some, like we want to close some connections or we want that some statement to execute, no matter whether there's exception or not. Then we write those statements in the final block.
            • 220:30 - 221:00 So we do not have any final block in the store procedure on SQL. Let's see how we can define that try and catch blocks in store procedure with an example. Let me first increase the font size. I'm creating this store procedure, the name DBO.USP try catch test and to write a catch block we have to provide the syntax begin try. Then in the body will write whatever the statement we want to write and then followed by the end try.
            • 221:00 - 221:30 So end try basically ends that try block. After that we'll provide begin catch and in the catch, see what we are doing here is that we have returned a select statement that we are providing what is the error number, what is the severity of this error, what is the state procedure and which line the error isn't in encounter and the error message. So let's create this store procedure first and then we'll refresh this note.
            • 221:30 - 222:00 So we have this store procedure and now this store procedure do not have any parameter. I'll execute this store procedure, execute keyword followed by the name of the store procedure. No parameters, so we are not passing any parameters while executing it. And see since we are dividing by zero it will give an error and it results in infinity and see since it will go to the catch block
            • 222:00 - 222:30 since error has encountered. So we are written the statement in the try block. So in the catch we at handling the exception and while handling the exception we have written a select statement which provide all these values. So the error number is 8134, error severity 16. So these are the predefined the severity levels, so we can check on Google that what the error severity 16 means. Then we have error straight, and which procedure the error has occurred.
            • 222:30 - 223:00 So to give you the name of the procedure, the name of the procedure is USP try catch test. Error line is four, and the error message that we are dividing by a zero. So we will get the message that divide by zero error encountered. So this is how we mentioned try catch block in the store procedure. We have seen various examples of the store procedure. So we have created the store procedure without parameter, with parameter. We have created to a store procedure
            • 223:00 - 223:30 with multiple parameters. We have seen that how we can you know, include comments in a stored procedure using single line comments, or block comments. And we have seen that how we can handle the exception of store procedure. So this exception handling is not only for the store procedure we can handle these exceptions in functions as well. So we can write, try block and followed by a catch block in the catch block. Again, we can write the select statement to show the message that where exactly what the severity level,
            • 223:30 - 224:00 what is the error message. We can even provide the customer error message it's up to us. So let's move to the next topic. So I hope you are clear with the concept of store procedure in SQL. Let's move to the next topic. The next topic is user defined functions. So though SQL server provides list of many predefined functions that are built into the T SQL language. These supplied or outer box functions helps in extending the capabilities of SQL.
            • 224:00 - 224:30 By providing the ability to perform like string manipulations, mathematical calculations, data type conversions by using converter cost functions et cetera. But sometimes these outer box functions or inbuilt functions are not enough and there certain functionalities which is not provided by these functions. So this issue can be easily addressed if we can create some user defined function.
            • 224:30 - 225:00 So like functions and programming language and all programming language we write functions. There are some functions which do not return any values, they are functions which returns a value and we pass parameters. We do not pass parameters while you know calling the functions. So user defined functions in SQL are almost on the same lines of the functions in other programming languages. So user defined functions are compact piece of transact SQL code,
            • 225:00 - 225:30 which can accept parameters like how we pass a parameter in the store procedure. Same way functions can also accept parameters. Functions can perform complex calculations and written either a value or a table. So this written type is basically based upon what kind of functions we are creating or executing. So let's discuss more of the various benefits of user defined functions.
            • 225:30 - 226:00 So again, like store procedure, functions also helps us in achieving the concept of reusability. It will prevent us from writing same logic multiple times. We can dump a set of SQL statement in a function and we can call it as many as times. Like store procedure they also improve the performance because the user defined function reduce the compilation time of SQL query, by catching the execution plan and reusing it.
            • 226:00 - 226:30 Functions that are also easier to maintain because functions help us to separate the complex calculations or the complex business logic from the regular SQL query. So that we can understand and debug the query quicker and better. It again reduce the network traffic because of its catching plan. Functions again can be used in where clause as well. By this we can limit the number of rows
            • 226:30 - 227:00 sent to the client. So we can use functions and select clause and we can use the functions in where clause. Now let's discuss about the structure of the functions, user defined functions are composed of two parts. One is header and one is function body. We'll see in some examples that how we create functions, so the header contains the function name, input parameters. If there are any input parameters because again the parameters are optional whether it was store procedure
            • 227:00 - 227:30 or whether to the user defined function. Along with parameter we have written parameter in for its name and type in the header section. The function body contains the logic and it gives this logic so it contains one or many a SQL statement depending upon what we are writing in the function body. As you can see on the screen, there are if you need to divide the user defined functions and some broad category then we can divide into two broad categories. One is that scalar value functions
            • 227:30 - 228:00 and one is the table valued function. The table value function can again be divided into a line table value functions and multistatement table value functions. Let's move to the next slide. Let's first discuss about what are the scalar functions in SQL? Scalar functions returns a single data value after type defined in the written clause. If it is an inline scalar function, we even don't need a functioning body.
            • 228:00 - 228:30 We use scalar functions when multi statements need to be provided within beginner end block. So let's discuss about the syntax. As I mentioned that the syntax contains header and a body. So the the create alter function, it is basically the header of the functions in the head or we can define the parameters, the written type parameter. And then in the beginning and end we define the function body. What are those SQL statements
            • 228:30 - 229:00 or any competitions or any calculations which you are doing. We basically do it in the body of the function. So if we need to summarize, the scalar functions are functions which returns a single value where written scalar values or single values that can be used anywhere a constant expression can be used. Every function, whether it's a scaler or whether it is like table value functions, every function must return a result
            • 229:00 - 229:30 using the written statement. This is kind of mandatory. So let's see some examples of the scalar functions. So in this example we are creating a function with the name fn_ get department number. So we are creating a parameter employee id of the data type int here. This functions basically returns int data type. Then there's a begin keyword, after begin keyword we are defining the body. In body we are writing select department number
            • 229:30 - 230:00 from employee, where employee id is employee id. Where at written employee id is the parameter, which we'll pass when we'll execute this function or we'll run this function. So in the right hand side, we are executing this functions and we are executing these functions in the where clause. Lets pay attention. In the where clause we are mentioning where department number equals two and then we are calling the function by providing the parameter. So when this function will execute, it will be replaced by the value
            • 230:00 - 230:30 which the function will return. And then that value will be used in the where clause to filter the data. So let's discuss some examples of functions for better clarity. Let me open management studio that we close this queries first. So we'll first create a function, a scalar function without any parameters.
            • 230:30 - 231:00 So this is the name of the function, no parameters. We are not creating any parameters here. And the return type is int. And I'm just returning in the return statement. You have just provided a SQL statement that selects some salary from employee. After executing this, function will be created. This is a scalar function. So we want to verify whether the function has been created successfully. Then we have to refresh our database.
            • 231:00 - 231:30 So we have created this function in employee DB database. I'll refresh that and I'll expand the programmability. In programmability note we have sub note called functions, again functions, we have four notes, table-valued functions, scalar-valued functions, aggregate functions and system functions. If I'll expand the scalability functions, we can see the name of the functions here. So in order to execute this function, we have to write select statement followed by the name of the function.
            • 231:30 - 232:00 If I'll execute, we have to provide the parenthesis. This function will return the sum of the salary from employee table. So let me show you the data which is there in the employee table, so that we verify a result whether we got the right result or not. So if you'll calculate this we'll get 5708. This is the sum of the salary for all the employees. Since we have three employees only.
            • 232:00 - 232:30 So this is how we'll create the functions without any parameter. Let's see how we can create a functions with parameter. So in this function we are providing two parameters, first name and the data type of the parameter is varchar 50, the second parameter is the last name and the data type of second parameters is again varchar, they're they same length as the first parameter.
            • 232:30 - 233:00 Return type is also of the same datatype. And then in the body we are executing the SQL statement. So what we are doing, we are just concatenating. So if it is a mathematical operations, if we provide the plus operator then we'll add the two values. But if it is string of varchar then it will concatenate the string. Space is a function in, it is inbuilt function in SQL, which basically add a space empty space.
            • 233:00 - 233:30 So what we are doing, we are concatenating first name and last name and we are adding a space between the two names to make it more readable. So as you can see, when I hoovering over the space a keyword, it is giving me a message that this is a built-in function. So let me create this function first, function has been created. Again, this is a scalar function, but with parameters. Let me refresh the scalar-valued function notes
            • 233:30 - 234:00 and I can see the function name. Let me execute this function, name of the function and then we have to pass the parameters. So I pass two parameters here, and the name of the second parameter. Why I'm enclosing it in single code because this is a string type. And if you want to add an alias for the column name, we can mention it as full name.
            • 234:00 - 234:30 So if I'll execute it again, we'll get the results you wrote here. So this is how we'll create a functions with multiple parameters and we can call the functions in this select statement or we can, sorry, call in the select statement, right? And we can even call the functions in where clause as we saw in the example in the previous table. Again in the previous example, let me first increase the font size. We can even use the functions in the where clause.
            • 234:30 - 235:00 So how we can use it, let's assume I'm calling this query select star from employee and let me first alter this function. So to alter this function we have to use the alter keyword and instead of sum, I'm just finding the average salary of the employee and I'm executing again. So this is how we modify the function, existing function. Same way we can modify store procedure also. So alter is the keyword which helps us to modifying the existing functions
            • 235:00 - 235:30 as well as existing store procedure. If I have to use the functions in the where clause. So this is how we'll do, let me show you. So I'm writing a query, so what I want to do is that I want to select the employees whose salary is greater than the average salary. So I'll write where clause where salary is greater than, then I'll call the function. So if I execute it now, I'll get only one result because there's only one record
            • 235:30 - 236:00 or one employee who's salary is greater than the average salary of all the employee. So this is how we can include or we can call the function in where clause as well as in the select statement, as per our business requirement. So let's move to the next topic. So we are clear with the scalar functions I believe. So let's move to the next type of function that is the table-valued functions.
            • 236:00 - 236:30 And as I mentioned earlier, we have two types of our table-valued function. One is inline, one is multi-valued. So inline table value functions are a subset of user defined function that returns a table. So scalar functions returns only single value, whereas the inline table value functions returns the entire table. So inline functions, if you remember, we have created view in the first module. So we can use use inline functions if you want achieve
            • 236:30 - 237:00 the functionality of that parameterized view. Inline table valued function can also be used to support parameters in search condition specified in the where clause. So these are the some of the rules which are common for the inline table-valued functions. The return clause contains only the keyword table. Format need not to be defined by the return value. There's no function body do you delimited by begin and an end.
            • 237:00 - 237:30 The return clause contains a single select statement in parenthesis and a table-valued function accepts holy constraints or the local variable arguments. This is the syntax for inline table-valued functions as you can see in the slide. So the return type is table here and we generally have the SQL statement. So this is an example, in the last slide we saw the syntax, this is an example. So here in this example we are creating a function
            • 237:30 - 238:00 get employee info. You're passing the parameter employee id and it is returning the values as a table, not as a single value. And the return statement we are providing the select statement where we are returning the values of employee table and we are filtering the result sets by using the parameter employee id. And this is how we'll execute. So if you'll remember when when we executed the scalar-value function, I did not use select star from,
            • 238:00 - 238:30 we simply mentioned select and the name of the function. But if you're using table-value function then we are using the select star from, because we are kind of as we mentioned, we kind of use it what parameterized view. So if you need to fetch the values from views, then again we use select star from the name of the view. So let's see an example of inline table-valued function. Let me open management studio.
            • 238:30 - 239:00 So this is example of inline functions with no parameter. We can create parameter in the same way we created the parameter or we defined the parameters for the scalar-value functions. So I'm creating a function, top 10 customers. We are returning a table. And in the written statement I'm just writing a select statement, select top 10 from employee, let me execute this to create this function. I'll execute this function. So to execute this I have to mention the select plus,
            • 239:00 - 239:30 select star from and then the name of the function. So I'm getting, so there are only nine rows, so it's just fetching the nine only. So if I can go out and modify it instead of top 10 let me modify to top five. So to modify the function we have to use the alter keyword. So we got the top five results. This is how we create the inline table-valued function.
            • 239:30 - 240:00 So this is an example of the functions without any parameters, if you required we can go ahead create the parameter as well. So to create the parameter we have to define the parameter name here and then we can have to provide the name of, data type of parameter. And then we can write a where clause. Let's say you employee id is, (mumbles) employee id,
            • 240:00 - 240:30 command executed successfully. And now if I were to run this, I'll pass a value to the functions. if I'll execute it will get the values and the result sets who's employee is greater than 1003. I hope this is clear and let's move to the next topic So I'll discuss the next category of table-valued function. That is the multi-statement. So in the inline function we can use a single statement, but in multi-statement table valued function
            • 240:30 - 241:00 we can use multiple statements. So again they also return a table data type so the return clause defines the format of the table. We cannot provide the format and the in the inline table value function. But yes we can provide the format of the table in multi statement table-valued function. That transact-SQL statement in the function body build and insert rows into the return variable defined by the written clause.
            • 241:00 - 241:30 And the rows in certain into the variable are return as the table output of the function. So here we have the syntax for this, to modify we use the alter keywords, to create we use create keywords, name of the function if you wish. We can define the parameters which you can consume in the function body. Written type will always be the table, but here we can define the format which is not available in the inline table-valued function. Let's see an example. So this is an example here. So we are defining the format of the table
            • 241:30 - 242:00 and we are defining like that this is the table will be the retGetEmployeeInfo and we are providing four columns here and we are defining the data type. We're defining the constraint on the table, we are defining whether there's a null constraint or not on those columns. And in the function body we are inserting records in the table and we're fetching from the employee and we're filtering the result set by using the parameter which will pass when we'll execute the function.
            • 242:00 - 242:30 So lets see one more example other than this. So you can use the same example and executed it and try to write the entire thing then it will take time. So I'm skipping the example in management studio, but the basic difference between these two functions table will function is that here we can format the table and we can use multiple statement in the function body. Which is not the options in the inline functions. So we already discussed the benefits of
            • 242:30 - 243:00 user defined functions, modular programming. It saves time because we can write or dump the statements in a function and use it or call it as many as number of times. It's faster executions because of this, it catches the exhibition plan and use it for the subsequent calls and it reduced the network traffic. So these are few of the main benefits of user defined functions. So we discussed the user defined functions
            • 243:00 - 243:30 and I hope you are clear. So we can extend the capability by writing user defined functions and we can achieve the functionality which cannot be fulfilled by outer box or the in-built functions of SQL. Now we'll understand what triggers us, as the name suggests, it's some database object which triggers automatically. How we can say that trigger is a special kind of stored procedure that automatically executes when an event occur in database. So we have various type of triggers.
            • 243:30 - 244:00 Let's first see the syntax of the trigger and then discuss that what are that different types of triggers available in SQL. So we have DML triggers, we have DDL triggers, lets discuss what are the DML triggers, what are the DDL triggers? And then we'll discuss about the syntax. So in both category we can define the triggers into two major types. One is that DDL at triggers, so DDL stands for the data definition language
            • 244:00 - 244:30 which for discussion in the module first where we created few database objects, so those triggers as the name suggests, data definition language they file in response to the DDL command that starts with create or alter or the drop of that database objects. Like if I'll create a table, if I'll create a view, if I'll try to drop a table or try to drop off view, or if you want to alter any table,
            • 244:30 - 245:00 then the DDL triggers will be automatically fired or triggered. The other type of triggers are DML triggers, so they file in response to the data manipulation language commands that start with like if you want to insert some data in the table, if you want to update some records, or if you wish to delete some data from the existing database objects. So based on the commands these triggers get fired.
            • 245:00 - 245:30 If we executing the DDL commands, then DDL triggers will execute and if you're executing the DML commands then they will trigger will get fired. We can further divide the DML triggers into two types, after triggers and instead of triggers. Let's discuss what are these after triggers and instead of triggers. After triggers and instead of triggers, let's see an example of DDL triggers
            • 245:30 - 246:00 and see how they get executed. Let's open studio, open a new query, increase the font for better visibility. Open our example sheet. So let's first create a DDL trigger. So I'm creating a trigger called safety on database for create table, alter table or drop table. So if I'll try to create a table in this database, if its create table, alter table or drop table.
            • 246:00 - 246:30 So it really print a message. To print a message in SQL we basically use print keyword and if it is string we'll enclose as in our single codes, whatever the message we want to print and the rollback as we discussed that is the DCL command. So it will rollback, that changes it won't be saved. So let's execute the statements to create this trigger. That's the trigger has been created successfully. So that's all about triggers. And these are some of the benefits
            • 246:30 - 247:00 it provides alternate matters for implementing referential integrity constraint. So if you want to achieve a referential integrity constraint we have to call, instead of triggers it restrict or controls updates on the database objects and can be used to publish information about the database events. Like the startup and shutdown, so we can call the triggers based on this and we can publish the information's because we don't have to explicitly call, there's no manual intervention. These are auto trigger events.
            • 247:00 - 247:30 So these are some of the benefits of the triggers. Hope you enjoyed this course and happy SQL learning. - [Announcer] Alright, so thank you for the great session, Anil. I hope all of you found it informative. If you have any further queries related to the session, please comment in the comment section below. Until then, that's all from our side today. Thank you and happy learning. I hope you have enjoyed listening to this video. Please be kind enough to like it and you can comment any of your doubts and queries and we will reply them at the earliest.
            • 247:30 - 248:00 Do look out for more videos in our playlist. And subscribed to Edureka channel to learn more. Happy learning.