{"id":61,"date":"2011-07-22T12:33:44","date_gmt":"2011-07-22T12:33:44","guid":{"rendered":"https:\/\/sqlserverlearner.azurewebsites.net\/2011\/07\/22\/difference-between-set-and-select\/"},"modified":"2011-07-22T12:33:44","modified_gmt":"2011-07-22T12:33:44","slug":"difference-between-set-and-select","status":"publish","type":"post","link":"https:\/\/sqlserverlearner.com\/2011\/07\/22\/difference-between-set-and-select\/","title":{"rendered":"Difference Between SET and SELECT"},"content":{"rendered":"

SET and SELECT statements are similar in many ways but what are the major differences between them?<\/strong><\/p>\n

This post explains the main differences between set and select statements.<\/p>\n

Select Statement:<\/strong>
\n[sql]
\nDECLARE @i INT
\nSELECT @i = 10
\n[\/sql]<\/p>\n

SET Statement:<\/strong>
\n[sql]
\nDECLARE @i INT
\nSET @i = 10
\n[\/sql]<\/p>\n

\n1)<\/strong> SET is ANSI Standard<\/strong> for value assignment to variables but SELECT is not an ANSI Standard for variable assignment.<\/p>\n

2)<\/strong> SET can be used to assign value to one variable at a time but select can be used to assign values to multiple variables in a single select statement.<\/p>\n

The below query using SELECT is valid:
\n[sql]
\nDECLARE @i INT,
\n @j INT,
\n @k INT<\/p>\n

SELECT @i = 10,@j = 20,@k = 30
\n[\/sql]
\nOutput:
\nCommand(s) completed successfully.<\/em><\/p>\n

The below query using SET is not valid:
\n[sql]
\nDECLARE @i INT,
\n @j INT,
\n @k INT<\/p>\n

SET @i = 10,@j = 20,@k = 30
\n[\/sql]
\nIt gives error:
\n
\nMsg 102, Level 15, State 1, Line 5
\nIncorrect syntax near ‘,’.
\n<\/font><\/p>\n

3)<\/strong> When an output of a query is used to assign values to a variable then SET Statement would fail and give an error if multiple rows are returned by the query but the select statement would assign the last result of the query to the the variable.<\/p>\n

The below query using select will execute successfully:
\n[sql]
\nDECLARE @i INT<\/p>\n

SELECT @i = n FROM (VALUES (10),(20),(30)) AS List(n)<\/p>\n

SELECT @i
\n[\/sql]
\nOutput:
\n———–
\n30<\/p>\n

(1 row(s) affected)<\/em><\/p>\n

The below query using set will fail:
\n[sql]
\nDECLARE @i INT<\/p>\n

SET @i = (SELECT n FROM (VALUES (10),(20),(30)) AS List(n))
\n[\/sql] <\/p>\n

Error:
\n
\nMsg 512, Level 16, State 1, Line 5
\nSubquery returned more than 1 value. This is not permitted when the subquery follows =, !=, <, , >= or when the subquery is used as an expression.
\n<\/font><\/p>\n

4)<\/strong> If the variable is initially assigned a value following is the behavior of variable assignment using set and select.
\nSet – Assigns null if the query does not return any rows.
\nSelect – Retains the initially assigned value and does not assign null if the query does not return any rows.<\/p>\n

The output of the below statement will be 1
\n[sql]
\nDECLARE @i INT<\/p>\n

SET @i = 1<\/p>\n

SELECT @i = n FROM (VALUES (10),(20),(30)) AS List(n) WHERE 1=2<\/p>\n

SELECT @i
\n[\/sql]<\/p>\n

Output:
\n
\n———–
\n1<\/p>\n

(1 row(s) affected)<\/em><\/p>\n

The output of the below statement will be NULL
\n[sql]
\nDECLARE @i INT<\/p>\n

SET @i = 1<\/p>\n

SET @i = (SELECT n FROM (VALUES (10),(20),(30)) AS List(n) WHERE 1=2)<\/p>\n

SELECT @i
\n[\/sql]<\/p>\n

Output:
\n———–
\nNULL<\/p>\n

(1 row(s) affected)<\/em><\/p>\n

5)<\/strong> Select has better performance over set when used for assigning values to multiple variables at the same time.<\/p>\n

Assigning values to multiple variables using Select:
\n[sql]
\nDECLARE @i INT,
\n @j INT,
\n @k INT<\/p>\n

SELECT @i = 10,@j = 20,@k = 30
\n[\/sql]<\/p>\n

Assigning values to multiple variables using SET:
\n[sql]
\nDECLARE @i INT,
\n @j INT,
\n @k INT<\/p>\n

SET @i = 10
\nSET @j = 20
\nSET @k = 30
\n[\/sql]<\/p>\n

\n6)<\/strong> There are many other differences with respect to syntax and uses of SET and Select.
\nThis post is mainly tuned for value assignment to variables using SET and Select.<\/p>\n","protected":false},"excerpt":{"rendered":"

SET and SELECT statements are similar in many ways but what are the major differences between them? This post explains the main differences between set and select statements. Select Statement: [sql] DECLARE @i INT SELECT @i = 10 [\/sql] SET Statement: [sql] DECLARE @i INT SET @i = 10 [\/sql] 1) SET is ANSI Standard…<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[41,3],"tags":[173,174,175,176,177,178],"class_list":["post-61","post","type-post","status-publish","format-standard","hentry","category-sql-server-basics","category-sqlserverpedia-syndication","tag-advantages-of-select-over-set","tag-advantages-of-set-over-select","tag-differences-between-set-and-select","tag-set-vs-select","tag-what-to-use-set-or-select","tag-why-set-why-select"],"_links":{"self":[{"href":"https:\/\/sqlserverlearner.com\/wp-json\/wp\/v2\/posts\/61","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/sqlserverlearner.com\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/sqlserverlearner.com\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/sqlserverlearner.com\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/sqlserverlearner.com\/wp-json\/wp\/v2\/comments?post=61"}],"version-history":[{"count":0,"href":"https:\/\/sqlserverlearner.com\/wp-json\/wp\/v2\/posts\/61\/revisions"}],"wp:attachment":[{"href":"https:\/\/sqlserverlearner.com\/wp-json\/wp\/v2\/media?parent=61"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/sqlserverlearner.com\/wp-json\/wp\/v2\/categories?post=61"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/sqlserverlearner.com\/wp-json\/wp\/v2\/tags?post=61"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}