<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>http://www.sqle.ru/index.php?action=history&amp;feed=atom&amp;title=SQL_Server%2FT-SQL%2FSelect_Query%2FEXISTS</id>
		<title>SQL Server/T-SQL/Select Query/EXISTS - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://www.sqle.ru/index.php?action=history&amp;feed=atom&amp;title=SQL_Server%2FT-SQL%2FSelect_Query%2FEXISTS"/>
		<link rel="alternate" type="text/html" href="http://www.sqle.ru/index.php?title=SQL_Server/T-SQL/Select_Query/EXISTS&amp;action=history"/>
		<updated>2026-05-24T05:43:05Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://www.sqle.ru/index.php?title=SQL_Server/T-SQL/Select_Query/EXISTS&amp;diff=6000&amp;oldid=prev</id>
		<title> в 13:46, 26 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://www.sqle.ru/index.php?title=SQL_Server/T-SQL/Select_Query/EXISTS&amp;diff=6000&amp;oldid=prev"/>
				<updated>2010-05-26T13:46:06Z</updated>
		
		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr style=&quot;vertical-align: top;&quot; lang=&quot;ru&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;← Предыдущая&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;Версия 13:46, 26 мая 2010&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; style=&quot;text-align: center;&quot; lang=&quot;ru&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(нет различий)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
			</entry>

	<entry>
		<id>http://www.sqle.ru/index.php?title=SQL_Server/T-SQL/Select_Query/EXISTS&amp;diff=6001&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://www.sqle.ru/index.php?title=SQL_Server/T-SQL/Select_Query/EXISTS&amp;diff=6001&amp;oldid=prev"/>
				<updated>2010-05-26T10:20:54Z</updated>
		
		<summary type="html">&lt;p&gt;1 версия&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Новая страница&lt;/b&gt;&lt;/p&gt;&lt;div&gt;==Checks for existing Product record==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
&lt;br /&gt;
12&amp;gt;&lt;br /&gt;
13&amp;gt; create table employee(&lt;br /&gt;
14&amp;gt;     ID          int,&lt;br /&gt;
15&amp;gt;     name        nvarchar (10),&lt;br /&gt;
16&amp;gt;     salary      int,&lt;br /&gt;
17&amp;gt;     start_date  datetime,&lt;br /&gt;
18&amp;gt;     city        nvarchar (10),&lt;br /&gt;
19&amp;gt;     region      char (1))&lt;br /&gt;
20&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
3&amp;gt;               values (1,  &amp;quot;Jason&amp;quot;, 40420,  &amp;quot;02/01/94&amp;quot;, &amp;quot;New York&amp;quot;, &amp;quot;W&amp;quot;)&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
1&amp;gt; insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
2&amp;gt;               values (2,  &amp;quot;Robert&amp;quot;,14420,  &amp;quot;01/02/95&amp;quot;, &amp;quot;Vancouver&amp;quot;,&amp;quot;N&amp;quot;)&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
1&amp;gt; insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
2&amp;gt;               values (3,  &amp;quot;Celia&amp;quot;, 24020,  &amp;quot;12/03/96&amp;quot;, &amp;quot;Toronto&amp;quot;,  &amp;quot;W&amp;quot;)&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
1&amp;gt; insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
2&amp;gt;               values (4,  &amp;quot;Linda&amp;quot;, 40620,  &amp;quot;11/04/97&amp;quot;, &amp;quot;New York&amp;quot;, &amp;quot;N&amp;quot;)&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
1&amp;gt; insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
2&amp;gt;               values (5,  &amp;quot;David&amp;quot;, 80026,  &amp;quot;10/05/98&amp;quot;, &amp;quot;Vancouver&amp;quot;,&amp;quot;W&amp;quot;)&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
1&amp;gt; insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
2&amp;gt;               values (6,  &amp;quot;James&amp;quot;, 70060,  &amp;quot;09/06/99&amp;quot;, &amp;quot;Toronto&amp;quot;,  &amp;quot;N&amp;quot;)&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
1&amp;gt; insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
2&amp;gt;               values (7,  &amp;quot;Alison&amp;quot;,90620,  &amp;quot;08/07/00&amp;quot;, &amp;quot;New York&amp;quot;, &amp;quot;W&amp;quot;)&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
1&amp;gt; insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
2&amp;gt;               values (8,  &amp;quot;Chris&amp;quot;, 26020,  &amp;quot;07/08/01&amp;quot;, &amp;quot;Vancouver&amp;quot;,&amp;quot;N&amp;quot;)&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
1&amp;gt; insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
2&amp;gt;               values (9,  &amp;quot;Mary&amp;quot;,  60020,  &amp;quot;06/09/02&amp;quot;, &amp;quot;Toronto&amp;quot;,  &amp;quot;W&amp;quot;)&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; select * from employee&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
ID          name       salary      start_date              city       region&lt;br /&gt;
----------- ---------- ----------- ----------------------- ---------- ------&lt;br /&gt;
          1 Jason            40420 1994-02-01 00:00:00.000 New York   W&lt;br /&gt;
          2 Robert           14420 1995-01-02 00:00:00.000 Vancouver  N&lt;br /&gt;
          3 Celia            24020 1996-12-03 00:00:00.000 Toronto    W&lt;br /&gt;
          4 Linda            40620 1997-11-04 00:00:00.000 New York   N&lt;br /&gt;
          5 David            80026 1998-10-05 00:00:00.000 Vancouver  W&lt;br /&gt;
          6 James            70060 1999-09-06 00:00:00.000 Toronto    N&lt;br /&gt;
          7 Alison           90620 2000-08-07 00:00:00.000 New York   W&lt;br /&gt;
          8 Chris            26020 2001-07-08 00:00:00.000 Vancouver  N&lt;br /&gt;
          9 Mary             60020 2002-06-09 00:00:00.000 Toronto    W&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; -- Creating a Stored Procedure&lt;br /&gt;
3&amp;gt;&lt;br /&gt;
4&amp;gt;&lt;br /&gt;
5&amp;gt; /* Checks for existing Product record&lt;br /&gt;
6~    If exists, updates the record.  If not,&lt;br /&gt;
7~    inserts new record&lt;br /&gt;
8~ */&lt;br /&gt;
9&amp;gt; CREATE PROCEDURE spInsertOrUpdateEmployee&lt;br /&gt;
10&amp;gt;     -- Input parameters --&lt;br /&gt;
11&amp;gt;     @Name nVarChar(50),&lt;br /&gt;
12&amp;gt;     @City nVarChar(25),&lt;br /&gt;
13&amp;gt;     @Salary Money&lt;br /&gt;
14&amp;gt; AS&lt;br /&gt;
15&amp;gt;     IF EXISTS(SELECT * From Employee Where Name = @Name)&lt;br /&gt;
16&amp;gt;        UPDATE Employee SET City = @City, Salary = @Salary&lt;br /&gt;
17&amp;gt;        WHERE Name = @Name&lt;br /&gt;
18&amp;gt;     ELSE&lt;br /&gt;
19&amp;gt;        INSERT INTO Employee (Name, City, Salary)&lt;br /&gt;
20&amp;gt;        SELECT @Name, @City, @Salary&lt;br /&gt;
21&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; EXEC spInsertOrUpdateEmployee @Name=&amp;quot;a&amp;quot;,@City=&amp;quot;b&amp;quot;,@Salary=999&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
1&amp;gt; EXEC spInsertOrUpdateEmployee @Name=&amp;quot;Mary&amp;quot;,@City=&amp;quot;b&amp;quot;,@Salary=999&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; select * FROM employee&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
ID          name       salary      start_date              city       region&lt;br /&gt;
----------- ---------- ----------- ----------------------- ---------- ------&lt;br /&gt;
          1 Jason            40420 1994-02-01 00:00:00.000 New York   W&lt;br /&gt;
          2 Robert           14420 1995-01-02 00:00:00.000 Vancouver  N&lt;br /&gt;
          3 Celia            24020 1996-12-03 00:00:00.000 Toronto    W&lt;br /&gt;
          4 Linda            40620 1997-11-04 00:00:00.000 New York   N&lt;br /&gt;
          5 David            80026 1998-10-05 00:00:00.000 Vancouver  W&lt;br /&gt;
          6 James            70060 1999-09-06 00:00:00.000 Toronto    N&lt;br /&gt;
          7 Alison           90620 2000-08-07 00:00:00.000 New York   W&lt;br /&gt;
          8 Chris            26020 2001-07-08 00:00:00.000 Vancouver  N&lt;br /&gt;
          9 Mary               999 2002-06-09 00:00:00.000 b          W&lt;br /&gt;
       NULL a                  999                    NULL b          NULL&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop procedure spInsertOrUpdateEmployee&lt;br /&gt;
3&amp;gt; drop table employee&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==EXISTS function can be used to represent the ANY and ALL operators==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
35&amp;gt;&lt;br /&gt;
36&amp;gt;&lt;br /&gt;
37&amp;gt;&lt;br /&gt;
38&amp;gt; CREATE TABLE employee  (emp_no    INTEGER NOT NULL,&lt;br /&gt;
39&amp;gt;                         emp_fname CHAR(20) NOT NULL,&lt;br /&gt;
40&amp;gt;                         emp_lname CHAR(20) NOT NULL,&lt;br /&gt;
41&amp;gt;                         dept_no   CHAR(4) NULL)&lt;br /&gt;
42&amp;gt;&lt;br /&gt;
43&amp;gt; insert into employee values(1,  &amp;quot;Matthew&amp;quot;, &amp;quot;Smith&amp;quot;,    &amp;quot;d3&amp;quot;)&lt;br /&gt;
44&amp;gt; insert into employee values(2,  &amp;quot;Ann&amp;quot;,     &amp;quot;Jones&amp;quot;,    &amp;quot;d3&amp;quot;)&lt;br /&gt;
45&amp;gt; insert into employee values(3,  &amp;quot;John&amp;quot;,    &amp;quot;Barrimore&amp;quot;,&amp;quot;d1&amp;quot;)&lt;br /&gt;
46&amp;gt; insert into employee values(4,  &amp;quot;James&amp;quot;,   &amp;quot;James&amp;quot;,    &amp;quot;d2&amp;quot;)&lt;br /&gt;
47&amp;gt; insert into employee values(5,  &amp;quot;Elsa&amp;quot;,    &amp;quot;Bertoni&amp;quot;,  &amp;quot;d2&amp;quot;)&lt;br /&gt;
48&amp;gt; insert into employee values(6,  &amp;quot;Elke&amp;quot;,    &amp;quot;Hansel&amp;quot;,   &amp;quot;d2&amp;quot;)&lt;br /&gt;
49&amp;gt; insert into employee values(7,  &amp;quot;Sybill&amp;quot;,  &amp;quot;Moser&amp;quot;,    &amp;quot;d1&amp;quot;)&lt;br /&gt;
50&amp;gt;&lt;br /&gt;
51&amp;gt; select * from employee&lt;br /&gt;
52&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
emp_no      emp_fname            emp_lname            dept_no&lt;br /&gt;
----------- -------------------- -------------------- -------&lt;br /&gt;
          1 Matthew              Smith                d3&lt;br /&gt;
          2 Ann                  Jones                d3&lt;br /&gt;
          3 John                 Barrimore            d1&lt;br /&gt;
          4 James                James                d2&lt;br /&gt;
          5 Elsa                 Bertoni              d2&lt;br /&gt;
          6 Elke                 Hansel               d2&lt;br /&gt;
          7 Sybill               Moser                d1&lt;br /&gt;
(7 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; CREATE TABLE department(dept_no   CHAR(4) NOT NULL,&lt;br /&gt;
4&amp;gt;                         dept_name CHAR(25) NOT NULL,&lt;br /&gt;
5&amp;gt;                         location  CHAR(30) NULL)&lt;br /&gt;
6&amp;gt;&lt;br /&gt;
7&amp;gt; insert into department values (&amp;quot;d1&amp;quot;, &amp;quot;developer&amp;quot;,   &amp;quot;Dallas&amp;quot;)&lt;br /&gt;
8&amp;gt; insert into department values (&amp;quot;d2&amp;quot;, &amp;quot;tester&amp;quot;,      &amp;quot;Seattle&amp;quot;)&lt;br /&gt;
9&amp;gt; insert into department values (&amp;quot;d3&amp;quot;, &amp;quot;marketing&amp;quot;,  &amp;quot;Dallas&amp;quot;)&lt;br /&gt;
10&amp;gt;&lt;br /&gt;
11&amp;gt; select * from department&lt;br /&gt;
12&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
dept_no dept_name                 location&lt;br /&gt;
------- ------------------------- ------------------------------&lt;br /&gt;
d1      developer                 Dallas&lt;br /&gt;
d2      tester                    Seattle&lt;br /&gt;
d3      marketing                 Dallas&lt;br /&gt;
(3 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; CREATE TABLE works_on        (emp_no       INTEGER NOT NULL,&lt;br /&gt;
3&amp;gt;                         project_no    CHAR(4) NOT NULL,&lt;br /&gt;
4&amp;gt;                         job CHAR (15) NULL,&lt;br /&gt;
5&amp;gt;                         enter_date    DATETIME NULL)&lt;br /&gt;
6&amp;gt;&lt;br /&gt;
7&amp;gt; insert into works_on values (1, &amp;quot;p1&amp;quot;, &amp;quot;analyst&amp;quot;, &amp;quot;1997.10.1&amp;quot;)&lt;br /&gt;
8&amp;gt; insert into works_on values (1, &amp;quot;p3&amp;quot;, &amp;quot;manager&amp;quot;, &amp;quot;1999.1.1&amp;quot;)&lt;br /&gt;
9&amp;gt; insert into works_on values (2, &amp;quot;p2&amp;quot;, &amp;quot;clerk&amp;quot;,   &amp;quot;1998.2.15&amp;quot;)&lt;br /&gt;
10&amp;gt; insert into works_on values (2, &amp;quot;p2&amp;quot;,  NULL,     &amp;quot;1998.6.1&amp;quot;)&lt;br /&gt;
11&amp;gt; insert into works_on values (3, &amp;quot;p2&amp;quot;,  NULL,     &amp;quot;1997.12.15&amp;quot;)&lt;br /&gt;
12&amp;gt; insert into works_on values (4, &amp;quot;p3&amp;quot;, &amp;quot;analyst&amp;quot;, &amp;quot;1998.10.15&amp;quot;)&lt;br /&gt;
13&amp;gt; insert into works_on values (5, &amp;quot;p1&amp;quot;, &amp;quot;manager&amp;quot;, &amp;quot;1998.4.15&amp;quot;)&lt;br /&gt;
14&amp;gt; insert into works_on values (6, &amp;quot;p1&amp;quot;,  NULL,     &amp;quot;1998.8.1&amp;quot;)&lt;br /&gt;
15&amp;gt; insert into works_on values (7, &amp;quot;p2&amp;quot;, &amp;quot;clerk&amp;quot;,   &amp;quot;1999.2.1&amp;quot;)&lt;br /&gt;
16&amp;gt; insert into works_on values (8, &amp;quot;p3&amp;quot;, &amp;quot;clerk&amp;quot;,   &amp;quot;1997.11.15&amp;quot;)&lt;br /&gt;
17&amp;gt; insert into works_on values (7, &amp;quot;p1&amp;quot;, &amp;quot;clerk&amp;quot;,   &amp;quot;1998.1.4&amp;quot;)&lt;br /&gt;
18&amp;gt;&lt;br /&gt;
19&amp;gt; select * from works_on&lt;br /&gt;
20&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
emp_no      project_no job             enter_date&lt;br /&gt;
----------- ---------- --------------- -----------------------&lt;br /&gt;
          1 p1         analyst         1997-10-01 00:00:00.000&lt;br /&gt;
          1 p3         manager         1999-01-01 00:00:00.000&lt;br /&gt;
          2 p2         clerk           1998-02-15 00:00:00.000&lt;br /&gt;
          2 p2         NULL            1998-06-01 00:00:00.000&lt;br /&gt;
          3 p2         NULL            1997-12-15 00:00:00.000&lt;br /&gt;
          4 p3         analyst         1998-10-15 00:00:00.000&lt;br /&gt;
          5 p1         manager         1998-04-15 00:00:00.000&lt;br /&gt;
          6 p1         NULL            1998-08-01 00:00:00.000&lt;br /&gt;
          7 p2         clerk           1999-02-01 00:00:00.000&lt;br /&gt;
          8 p3         clerk           1997-11-15 00:00:00.000&lt;br /&gt;
          7 p1         clerk           1998-01-04 00:00:00.000&lt;br /&gt;
(11 rows affected)&lt;br /&gt;
1&amp;gt; -- EXISTS function can be used to represent the ANY and ALL operators&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; SELECT emp_fname, emp_lname FROM employee WHERE EXISTS&lt;br /&gt;
4&amp;gt;        (SELECT *  FROM works_on WHERE project_no = &amp;quot;p1&amp;quot;&lt;br /&gt;
5&amp;gt;          AND employee.emp_no = works_on.emp_no)&lt;br /&gt;
6&amp;gt; GO&lt;br /&gt;
emp_fname            emp_lname&lt;br /&gt;
-------------------- --------------------&lt;br /&gt;
Matthew              Smith&lt;br /&gt;
Elsa                 Bertoni&lt;br /&gt;
Elke                 Hansel&lt;br /&gt;
Sybill               Moser&lt;br /&gt;
(4 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop table department&lt;br /&gt;
3&amp;gt; drop table employee&lt;br /&gt;
4&amp;gt; drop table works_on&lt;br /&gt;
5&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==NOT EXISTS function==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; CREATE TABLE employee  (emp_no    INTEGER NOT NULL,&lt;br /&gt;
3&amp;gt;                         emp_fname CHAR(20) NOT NULL,&lt;br /&gt;
4&amp;gt;                         emp_lname CHAR(20) NOT NULL,&lt;br /&gt;
5&amp;gt;                         dept_no   CHAR(4) NULL)&lt;br /&gt;
6&amp;gt;&lt;br /&gt;
7&amp;gt; insert into employee values(1,  &amp;quot;Matthew&amp;quot;, &amp;quot;Smith&amp;quot;,    &amp;quot;d3&amp;quot;)&lt;br /&gt;
8&amp;gt; insert into employee values(2,  &amp;quot;Ann&amp;quot;,     &amp;quot;Jones&amp;quot;,    &amp;quot;d3&amp;quot;)&lt;br /&gt;
9&amp;gt; insert into employee values(3,  &amp;quot;John&amp;quot;,    &amp;quot;Barrimore&amp;quot;,&amp;quot;d1&amp;quot;)&lt;br /&gt;
10&amp;gt; insert into employee values(4,  &amp;quot;James&amp;quot;,   &amp;quot;James&amp;quot;,    &amp;quot;d2&amp;quot;)&lt;br /&gt;
11&amp;gt; insert into employee values(5,  &amp;quot;Elsa&amp;quot;,    &amp;quot;Bertoni&amp;quot;,  &amp;quot;d2&amp;quot;)&lt;br /&gt;
12&amp;gt; insert into employee values(6,  &amp;quot;Elke&amp;quot;,    &amp;quot;Hansel&amp;quot;,   &amp;quot;d2&amp;quot;)&lt;br /&gt;
13&amp;gt; insert into employee values(7,  &amp;quot;Sybill&amp;quot;,  &amp;quot;Moser&amp;quot;,    &amp;quot;d1&amp;quot;)&lt;br /&gt;
14&amp;gt;&lt;br /&gt;
15&amp;gt; select * from employee&lt;br /&gt;
16&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
emp_no      emp_fname            emp_lname            dept_no&lt;br /&gt;
----------- -------------------- -------------------- -------&lt;br /&gt;
          1 Matthew              Smith                d3&lt;br /&gt;
          2 Ann                  Jones                d3&lt;br /&gt;
          3 John                 Barrimore            d1&lt;br /&gt;
          4 James                James                d2&lt;br /&gt;
          5 Elsa                 Bertoni              d2&lt;br /&gt;
          6 Elke                 Hansel               d2&lt;br /&gt;
          7 Sybill               Moser                d1&lt;br /&gt;
(7 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; CREATE TABLE department(dept_no   CHAR(4) NOT NULL,&lt;br /&gt;
4&amp;gt;                         dept_name CHAR(25) NOT NULL,&lt;br /&gt;
5&amp;gt;                         location  CHAR(30) NULL)&lt;br /&gt;
6&amp;gt;&lt;br /&gt;
7&amp;gt; insert into department values (&amp;quot;d1&amp;quot;, &amp;quot;developer&amp;quot;,   &amp;quot;Dallas&amp;quot;)&lt;br /&gt;
8&amp;gt; insert into department values (&amp;quot;d2&amp;quot;, &amp;quot;tester&amp;quot;,      &amp;quot;Seattle&amp;quot;)&lt;br /&gt;
9&amp;gt; insert into department values (&amp;quot;d3&amp;quot;, &amp;quot;marketing&amp;quot;,  &amp;quot;Dallas&amp;quot;)&lt;br /&gt;
10&amp;gt;&lt;br /&gt;
11&amp;gt; select * from department&lt;br /&gt;
12&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
dept_no dept_name                 location&lt;br /&gt;
------- ------------------------- ------------------------------&lt;br /&gt;
d1      developer                 Dallas&lt;br /&gt;
d2      tester                    Seattle&lt;br /&gt;
d3      marketing                 Dallas&lt;br /&gt;
(3 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; -- NOT EXISTS function.&lt;br /&gt;
3&amp;gt;&lt;br /&gt;
4&amp;gt; SELECT emp_lname FROM employee WHERE NOT EXISTS&lt;br /&gt;
5&amp;gt;        (SELECT * FROM department WHERE employee.dept_no = department.dept_no&lt;br /&gt;
6&amp;gt;          AND location = &amp;quot;Seattle&amp;quot;)&lt;br /&gt;
7&amp;gt; GO&lt;br /&gt;
emp_lname&lt;br /&gt;
--------------------&lt;br /&gt;
Smith&lt;br /&gt;
Jones&lt;br /&gt;
Barrimore&lt;br /&gt;
Moser&lt;br /&gt;
(4 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop table employee&lt;br /&gt;
3&amp;gt; drop table department&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Use NOT EXISTS to represent the ALL operator==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
&lt;br /&gt;
26&amp;gt;&lt;br /&gt;
27&amp;gt; CREATE TABLE employee  (emp_no    INTEGER NOT NULL,&lt;br /&gt;
28&amp;gt;                         emp_fname CHAR(20) NOT NULL,&lt;br /&gt;
29&amp;gt;                         emp_lname CHAR(20) NOT NULL,&lt;br /&gt;
30&amp;gt;                         dept_no   CHAR(4) NULL)&lt;br /&gt;
31&amp;gt;&lt;br /&gt;
32&amp;gt; insert into employee values(1,  &amp;quot;Matthew&amp;quot;, &amp;quot;Smith&amp;quot;,    &amp;quot;d3&amp;quot;)&lt;br /&gt;
33&amp;gt; insert into employee values(2,  &amp;quot;Ann&amp;quot;,     &amp;quot;Jones&amp;quot;,    &amp;quot;d3&amp;quot;)&lt;br /&gt;
34&amp;gt; insert into employee values(3,  &amp;quot;John&amp;quot;,    &amp;quot;Barrimore&amp;quot;,&amp;quot;d1&amp;quot;)&lt;br /&gt;
35&amp;gt; insert into employee values(4,  &amp;quot;James&amp;quot;,   &amp;quot;James&amp;quot;,    &amp;quot;d2&amp;quot;)&lt;br /&gt;
36&amp;gt; insert into employee values(5,  &amp;quot;Elsa&amp;quot;,    &amp;quot;Bertoni&amp;quot;,  &amp;quot;d2&amp;quot;)&lt;br /&gt;
37&amp;gt; insert into employee values(6,  &amp;quot;Elke&amp;quot;,    &amp;quot;Hansel&amp;quot;,   &amp;quot;d2&amp;quot;)&lt;br /&gt;
38&amp;gt; insert into employee values(7,  &amp;quot;Sybill&amp;quot;,  &amp;quot;Moser&amp;quot;,    &amp;quot;d1&amp;quot;)&lt;br /&gt;
39&amp;gt;&lt;br /&gt;
40&amp;gt; select * from employee&lt;br /&gt;
41&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
emp_no      emp_fname            emp_lname            dept_no&lt;br /&gt;
----------- -------------------- -------------------- -------&lt;br /&gt;
          1 Matthew              Smith                d3&lt;br /&gt;
          2 Ann                  Jones                d3&lt;br /&gt;
          3 John                 Barrimore            d1&lt;br /&gt;
          4 James                James                d2&lt;br /&gt;
          5 Elsa                 Bertoni              d2&lt;br /&gt;
          6 Elke                 Hansel               d2&lt;br /&gt;
          7 Sybill               Moser                d1&lt;br /&gt;
(7 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; CREATE TABLE works_on        (emp_no       INTEGER NOT NULL,&lt;br /&gt;
3&amp;gt;                         project_no    CHAR(4) NOT NULL,&lt;br /&gt;
4&amp;gt;                         job CHAR (15) NULL,&lt;br /&gt;
5&amp;gt;                         enter_date    DATETIME NULL)&lt;br /&gt;
6&amp;gt;&lt;br /&gt;
7&amp;gt; insert into works_on values (1, &amp;quot;p1&amp;quot;, &amp;quot;analyst&amp;quot;, &amp;quot;1997.10.1&amp;quot;)&lt;br /&gt;
8&amp;gt; insert into works_on values (1, &amp;quot;p3&amp;quot;, &amp;quot;manager&amp;quot;, &amp;quot;1999.1.1&amp;quot;)&lt;br /&gt;
9&amp;gt; insert into works_on values (2, &amp;quot;p2&amp;quot;, &amp;quot;clerk&amp;quot;,   &amp;quot;1998.2.15&amp;quot;)&lt;br /&gt;
10&amp;gt; insert into works_on values (2, &amp;quot;p2&amp;quot;,  NULL,     &amp;quot;1998.6.1&amp;quot;)&lt;br /&gt;
11&amp;gt; insert into works_on values (3, &amp;quot;p2&amp;quot;,  NULL,     &amp;quot;1997.12.15&amp;quot;)&lt;br /&gt;
12&amp;gt; insert into works_on values (4, &amp;quot;p3&amp;quot;, &amp;quot;analyst&amp;quot;, &amp;quot;1998.10.15&amp;quot;)&lt;br /&gt;
13&amp;gt; insert into works_on values (5, &amp;quot;p1&amp;quot;, &amp;quot;manager&amp;quot;, &amp;quot;1998.4.15&amp;quot;)&lt;br /&gt;
14&amp;gt; insert into works_on values (6, &amp;quot;p1&amp;quot;,  NULL,     &amp;quot;1998.8.1&amp;quot;)&lt;br /&gt;
15&amp;gt; insert into works_on values (7, &amp;quot;p2&amp;quot;, &amp;quot;clerk&amp;quot;,   &amp;quot;1999.2.1&amp;quot;)&lt;br /&gt;
16&amp;gt; insert into works_on values (8, &amp;quot;p3&amp;quot;, &amp;quot;clerk&amp;quot;,   &amp;quot;1997.11.15&amp;quot;)&lt;br /&gt;
17&amp;gt; insert into works_on values (7, &amp;quot;p1&amp;quot;, &amp;quot;clerk&amp;quot;,   &amp;quot;1998.1.4&amp;quot;)&lt;br /&gt;
18&amp;gt;&lt;br /&gt;
19&amp;gt; select * from works_on&lt;br /&gt;
20&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
emp_no      project_no job             enter_date&lt;br /&gt;
----------- ---------- --------------- -----------------------&lt;br /&gt;
          1 p1         analyst         1997-10-01 00:00:00.000&lt;br /&gt;
          1 p3         manager         1999-01-01 00:00:00.000&lt;br /&gt;
          2 p2         clerk           1998-02-15 00:00:00.000&lt;br /&gt;
          2 p2         NULL            1998-06-01 00:00:00.000&lt;br /&gt;
          3 p2         NULL            1997-12-15 00:00:00.000&lt;br /&gt;
          4 p3         analyst         1998-10-15 00:00:00.000&lt;br /&gt;
          5 p1         manager         1998-04-15 00:00:00.000&lt;br /&gt;
          6 p1         NULL            1998-08-01 00:00:00.000&lt;br /&gt;
          7 p2         clerk           1999-02-01 00:00:00.000&lt;br /&gt;
          8 p3         clerk           1997-11-15 00:00:00.000&lt;br /&gt;
          7 p1         clerk           1998-01-04 00:00:00.000&lt;br /&gt;
(11 rows affected)&lt;br /&gt;
1&amp;gt; --Use NOT EXISTS to represent the ALL operator.&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; SELECT DISTINCT job FROM works_on WHERE NOT EXISTS&lt;br /&gt;
4&amp;gt;        (SELECT * FROM employee WHERE works_on.emp_no &amp;gt; employee.emp_no)&lt;br /&gt;
5&amp;gt; GO&lt;br /&gt;
job&lt;br /&gt;
---------------&lt;br /&gt;
analyst&lt;br /&gt;
manager&lt;br /&gt;
(2 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop table works_on&lt;br /&gt;
3&amp;gt; drop table employee&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Using EXISTS Operator for a subquery==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; create table employee(&lt;br /&gt;
3&amp;gt;     ID          int,&lt;br /&gt;
4&amp;gt;     name        nvarchar (10),&lt;br /&gt;
5&amp;gt;     salary      int )&lt;br /&gt;
6&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; create table job(&lt;br /&gt;
3&amp;gt;     ID              int,&lt;br /&gt;
4&amp;gt;     title nvarchar  (10),&lt;br /&gt;
5&amp;gt;     averageSalary   int)&lt;br /&gt;
6&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; insert into employee (ID, name, salary) values (1,  &amp;quot;Jason&amp;quot;, 1234)&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into employee (ID, name, salary) values (2,  &amp;quot;Robert&amp;quot;, 4321)&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into employee (ID, name, salary) values (3,  &amp;quot;Celia&amp;quot;, 5432)&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into employee (ID, name, salary) values (4,  &amp;quot;Linda&amp;quot;, 3456)&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into employee (ID, name, salary) values (5,  &amp;quot;David&amp;quot;, 7654)&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into employee (ID, name, salary) values (6,  &amp;quot;James&amp;quot;, 4567)&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into employee (ID, name, salary) values (7,  &amp;quot;Alison&amp;quot;, 8744)&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into employee (ID, name, salary) values (8,  &amp;quot;Chris&amp;quot;, 9875)&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into employee (ID, name, salary) values (9,  &amp;quot;Mary&amp;quot;, 2345)&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; insert into job(ID, title, averageSalary) values(1,&amp;quot;Developer&amp;quot;,3000)&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into job(ID, title, averageSalary) values(2,&amp;quot;Tester&amp;quot;, 4000)&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into job(ID, title, averageSalary) values(3,&amp;quot;Designer&amp;quot;, 5000)&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; insert into job(ID, title, averageSalary) values(4,&amp;quot;Programmer&amp;quot;, 6000)&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; select * from employee;&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
ID          name       salary&lt;br /&gt;
----------- ---------- -----------&lt;br /&gt;
          1 Jason             1234&lt;br /&gt;
          2 Robert            4321&lt;br /&gt;
          3 Celia             5432&lt;br /&gt;
          4 Linda             3456&lt;br /&gt;
          5 David             7654&lt;br /&gt;
          6 James             4567&lt;br /&gt;
          7 Alison            8744&lt;br /&gt;
          8 Chris             9875&lt;br /&gt;
          9 Mary              2345&lt;br /&gt;
(9 rows affected)&lt;br /&gt;
1&amp;gt; select * from job;&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
ID          title      averageSalary&lt;br /&gt;
----------- ---------- -------------&lt;br /&gt;
          1 Developer           3000&lt;br /&gt;
          2 Tester              4000&lt;br /&gt;
          3 Designer            5000&lt;br /&gt;
          4 Programmer          6000&lt;br /&gt;
(4 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; -- The EXISTS Operator&lt;br /&gt;
4&amp;gt;&lt;br /&gt;
5&amp;gt; SELECT ID, Name&lt;br /&gt;
6&amp;gt; FROM Employee e&lt;br /&gt;
7&amp;gt; WHERE NOT EXISTS&lt;br /&gt;
8&amp;gt;    (SELECT ID&lt;br /&gt;
9&amp;gt;            FROM job j&lt;br /&gt;
10&amp;gt;            WHERE j.ID = e.ID)&lt;br /&gt;
11&amp;gt; GO&lt;br /&gt;
ID          Name&lt;br /&gt;
----------- ----------&lt;br /&gt;
          5 David&lt;br /&gt;
          6 James&lt;br /&gt;
          7 Alison&lt;br /&gt;
          8 Chris&lt;br /&gt;
          9 Mary&lt;br /&gt;
(5 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop table employee;&lt;br /&gt;
3&amp;gt; drop table job;&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>