<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>http://sqle.ru/index.php?action=history&amp;feed=atom&amp;title=SQL_Server%2FT-SQL_Tutorial%2FTransact_SQL%2FDynamic_SQL</id>
		<title>SQL Server/T-SQL Tutorial/Transact SQL/Dynamic SQL - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://sqle.ru/index.php?action=history&amp;feed=atom&amp;title=SQL_Server%2FT-SQL_Tutorial%2FTransact_SQL%2FDynamic_SQL"/>
		<link rel="alternate" type="text/html" href="http://sqle.ru/index.php?title=SQL_Server/T-SQL_Tutorial/Transact_SQL/Dynamic_SQL&amp;action=history"/>
		<updated>2026-04-04T21:24:38Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://sqle.ru/index.php?title=SQL_Server/T-SQL_Tutorial/Transact_SQL/Dynamic_SQL&amp;diff=6340&amp;oldid=prev</id>
		<title> в 13:46, 26 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://sqle.ru/index.php?title=SQL_Server/T-SQL_Tutorial/Transact_SQL/Dynamic_SQL&amp;diff=6340&amp;oldid=prev"/>
				<updated>2010-05-26T13:46:16Z</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://sqle.ru/index.php?title=SQL_Server/T-SQL_Tutorial/Transact_SQL/Dynamic_SQL&amp;diff=6341&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://sqle.ru/index.php?title=SQL_Server/T-SQL_Tutorial/Transact_SQL/Dynamic_SQL&amp;diff=6341&amp;oldid=prev"/>
				<updated>2010-05-26T10:22:40Z</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;== A stored procedure with dynamic execution.==&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;
4&amp;gt;&lt;br /&gt;
5&amp;gt;&lt;br /&gt;
6&amp;gt; CREATE TABLE authors(&lt;br /&gt;
7&amp;gt;    au_id          varchar(11),&lt;br /&gt;
8&amp;gt;    au_lname       varchar(40)       NOT NULL,&lt;br /&gt;
9&amp;gt;    au_fname       varchar(20)       NOT NULL,&lt;br /&gt;
10&amp;gt;    phone          char(12)          NOT NULL DEFAULT (&amp;quot;UNKNOWN&amp;quot;),&lt;br /&gt;
11&amp;gt;    address        varchar(40)           NULL,&lt;br /&gt;
12&amp;gt;    city           varchar(20)           NULL,&lt;br /&gt;
13&amp;gt;    state          char(2)               NULL,&lt;br /&gt;
14&amp;gt;    zip            char(5)               NULL,&lt;br /&gt;
15&amp;gt;    contract       bit               NOT NULL&lt;br /&gt;
16&amp;gt; )&lt;br /&gt;
17&amp;gt; GO&lt;br /&gt;
1&amp;gt; insert authors values(&amp;quot;1&amp;quot;,  &amp;quot;Joe&amp;quot;,   &amp;quot;Abra&amp;quot;,   &amp;quot;111 111-1111&amp;quot;, &amp;quot;6 St.&amp;quot;, &amp;quot;Berkeley&amp;quot;,  &amp;quot;CA&amp;quot;, &amp;quot;11111&amp;quot;, 1)&lt;br /&gt;
2&amp;gt; insert authors values(&amp;quot;2&amp;quot;,  &amp;quot;Jack&amp;quot;,  &amp;quot;Majo&amp;quot;,   &amp;quot;222 222-2222&amp;quot;, &amp;quot;3 St.&amp;quot;, &amp;quot;Oakland&amp;quot; ,  &amp;quot;CA&amp;quot;, &amp;quot;22222&amp;quot;, 1)&lt;br /&gt;
3&amp;gt; insert authors values(&amp;quot;3&amp;quot;,  &amp;quot;Pink&amp;quot;,  &amp;quot;Cherry&amp;quot;, &amp;quot;333 333-3333&amp;quot;, &amp;quot;5 Ln.&amp;quot;, &amp;quot;Vancouver&amp;quot;, &amp;quot;BC&amp;quot;, &amp;quot;33333&amp;quot;, 1)&lt;br /&gt;
4&amp;gt; insert authors values(&amp;quot;4&amp;quot;,  &amp;quot;Blue&amp;quot;,  &amp;quot;Albert&amp;quot;, &amp;quot;444 444-4444&amp;quot;, &amp;quot;7 Av.&amp;quot;, &amp;quot;Vancouver&amp;quot;, &amp;quot;BC&amp;quot;, &amp;quot;44444&amp;quot;, 1)&lt;br /&gt;
5&amp;gt; insert authors values(&amp;quot;5&amp;quot;,  &amp;quot;Red&amp;quot;,   &amp;quot;Anne&amp;quot;,   &amp;quot;555 555-5555&amp;quot;, &amp;quot;6 Av.&amp;quot;, &amp;quot;Regina&amp;quot;,    &amp;quot;SK&amp;quot;, &amp;quot;55555&amp;quot;, 1)&lt;br /&gt;
6&amp;gt; insert authors values(&amp;quot;6&amp;quot;,  &amp;quot;Black&amp;quot;, &amp;quot;Michel&amp;quot;, &amp;quot;666 666-6666&amp;quot;, &amp;quot;3 Pl.&amp;quot;, &amp;quot;Regina&amp;quot;,    &amp;quot;SK&amp;quot;, &amp;quot;66666&amp;quot;, 1)&lt;br /&gt;
7&amp;gt; insert authors values(&amp;quot;7&amp;quot;,  &amp;quot;White&amp;quot;, &amp;quot;Sylvia&amp;quot;, &amp;quot;777 777-7777&amp;quot;, &amp;quot;1 Pl.&amp;quot;, &amp;quot;Rockville&amp;quot;, &amp;quot;MD&amp;quot;, &amp;quot;77777&amp;quot;, 1)&lt;br /&gt;
8&amp;gt; insert authors values(&amp;quot;8&amp;quot;,  &amp;quot;Yellow&amp;quot;,&amp;quot;Heather&amp;quot;,&amp;quot;888 888-8888&amp;quot;, &amp;quot;3 Pu&amp;quot;,  &amp;quot;Vacaville&amp;quot;, &amp;quot;CA&amp;quot;, &amp;quot;88888&amp;quot;, 0)&lt;br /&gt;
9&amp;gt; insert authors values(&amp;quot;9&amp;quot;,  &amp;quot;Gold&amp;quot;,  &amp;quot;Dep&amp;quot;,    &amp;quot;999 999-9999&amp;quot;, &amp;quot;5 Av.&amp;quot;, &amp;quot;Oakland&amp;quot;,   &amp;quot;CA&amp;quot;, &amp;quot;99999&amp;quot;, 0)&lt;br /&gt;
10&amp;gt; insert authors values(&amp;quot;10&amp;quot;, &amp;quot;Siler&amp;quot;, &amp;quot;Dean&amp;quot;,   &amp;quot;000 000-0000&amp;quot;, &amp;quot;4 Av.&amp;quot;, &amp;quot;Oakland&amp;quot;,   &amp;quot;CA&amp;quot;, &amp;quot;00000&amp;quot;, 1)&lt;br /&gt;
11&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&amp;gt;&lt;br /&gt;
2&amp;gt;     CREATE PROC prExecute&lt;br /&gt;
3&amp;gt;     @chvExec varchar(255)&lt;br /&gt;
4&amp;gt;     AS&lt;br /&gt;
5&amp;gt;     EXEC (@chvExec)&lt;br /&gt;
6&amp;gt;     GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;     DECLARE @chvDoThis varchar(255)&lt;br /&gt;
3&amp;gt;     SELECT @chvDoThis = &amp;quot;DELETE AUTHORS&amp;quot;&lt;br /&gt;
4&amp;gt;     EXEC prExecute @chvDoThis&lt;br /&gt;
5&amp;gt;&lt;br /&gt;
6&amp;gt;&lt;br /&gt;
7&amp;gt;     drop PROC prExecute  ;&lt;br /&gt;
8&amp;gt;     GO&lt;br /&gt;
(10 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;     drop table authors;&lt;br /&gt;
3&amp;gt;     GO&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Build a dynamic sql statement from schema name, table name and column name==&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;
3&amp;gt; CREATE TABLE Orders (&lt;br /&gt;
4&amp;gt;      OrderID int IDENTITY (1, 1) NOT NULL ,&lt;br /&gt;
5&amp;gt;      CustomerID nchar (5) NULL ,&lt;br /&gt;
6&amp;gt;      EmployeeID int NULL ,&lt;br /&gt;
7&amp;gt;      OrderDate datetime NULL ,&lt;br /&gt;
8&amp;gt;      RequiredDate datetime NULL ,&lt;br /&gt;
9&amp;gt;      ShippedDate datetime NULL ,&lt;br /&gt;
10&amp;gt;     ShipVia int NULL ,&lt;br /&gt;
11&amp;gt;     Freight money NULL DEFAULT (0),&lt;br /&gt;
12&amp;gt;     ShipName nvarchar (40) NULL ,&lt;br /&gt;
13&amp;gt;     ShipAddress nvarchar (60) NULL ,&lt;br /&gt;
14&amp;gt;     ShipCity nvarchar (15) NULL ,&lt;br /&gt;
15&amp;gt;     ShipRegion nvarchar (15) NULL ,&lt;br /&gt;
16&amp;gt;     ShipPostalCode nvarchar (10) NULL ,&lt;br /&gt;
17&amp;gt;     ShipCountry nvarchar (15) NULL&lt;br /&gt;
18&amp;gt; )&lt;br /&gt;
19&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; DECLARE&lt;br /&gt;
4&amp;gt;   @schemaname AS NVARCHAR(128),&lt;br /&gt;
5&amp;gt;   @tablename  AS NVARCHAR(128),&lt;br /&gt;
6&amp;gt;   @colname    AS NVARCHAR(128),&lt;br /&gt;
7&amp;gt;   @sql        AS NVARCHAR(825),&lt;br /&gt;
8&amp;gt;   @cnt       AS INT;&lt;br /&gt;
9&amp;gt;&lt;br /&gt;
10&amp;gt; SET @schemaname = N&amp;quot;dbo&amp;quot;;&lt;br /&gt;
11&amp;gt; SET @tablename  = N&amp;quot;Orders&amp;quot;;&lt;br /&gt;
12&amp;gt; SET @colname    = N&amp;quot;CustomerID&amp;quot;;&lt;br /&gt;
13&amp;gt; SET @sql = N&amp;quot;INSERT INTO #T(cnt) SELECT COUNT(DISTINCT &amp;quot;&lt;br /&gt;
14&amp;gt;   + QUOTENAME(@colname) + N&amp;quot;) FROM &amp;quot;&lt;br /&gt;
15&amp;gt;   + QUOTENAME(@schemaname)&lt;br /&gt;
16&amp;gt;   + N&amp;quot;.&amp;quot;&lt;br /&gt;
17&amp;gt;   + QUOTENAME(@tablename)&lt;br /&gt;
18&amp;gt;   + N&amp;quot;;&amp;quot;;&lt;br /&gt;
19&amp;gt;&lt;br /&gt;
20&amp;gt; CREATE TABLE #T(cnt INT);&lt;br /&gt;
21&amp;gt; EXEC(@sql);&lt;br /&gt;
22&amp;gt; SET @cnt = (SELECT cnt FROM #T);&lt;br /&gt;
23&amp;gt; SELECT @cnt;&lt;br /&gt;
24&amp;gt; DROP TABLE #T;&lt;br /&gt;
25&amp;gt; GO&lt;br /&gt;
-----------&lt;br /&gt;
          0&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop table orders;&lt;br /&gt;
3&amp;gt; GO&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Change database dynamically==&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;
4&amp;gt; USE Northwind;&lt;br /&gt;
5&amp;gt; DECLARE @db AS NVARCHAR(258);&lt;br /&gt;
6&amp;gt; SET @db = QUOTENAME(N&amp;quot;pubs&amp;quot;);&lt;br /&gt;
7&amp;gt; EXEC(N&amp;quot;USE &amp;quot; + @db + N&amp;quot;; EXEC(&amp;quot;&amp;quot;SELECT DB_NAME();&amp;quot;&amp;quot;);&amp;quot;);&lt;br /&gt;
8&amp;gt; GO&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== create a dynamic sql statement and save it in a varchar type variable==&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;
3&amp;gt; CREATE TABLE Employees (&lt;br /&gt;
4&amp;gt;      EmployeeID int NOT NULL ,&lt;br /&gt;
5&amp;gt;      LastName nvarchar (20) NOT NULL ,&lt;br /&gt;
6&amp;gt;      FirstName nvarchar (10) NOT NULL ,&lt;br /&gt;
7&amp;gt;      Title nvarchar (30) NULL ,&lt;br /&gt;
8&amp;gt;      TitleOfCourtesy nvarchar (25) NULL ,&lt;br /&gt;
9&amp;gt;      BirthDate datetime NULL ,&lt;br /&gt;
10&amp;gt;     HireDate datetime NULL ,&lt;br /&gt;
11&amp;gt;     Address nvarchar (60) NULL ,&lt;br /&gt;
12&amp;gt;     City nvarchar (15) NULL ,&lt;br /&gt;
13&amp;gt;     Region nvarchar (15) NULL ,&lt;br /&gt;
14&amp;gt;     PostalCode nvarchar (10) NULL ,&lt;br /&gt;
15&amp;gt;     Country nvarchar (15) NULL ,&lt;br /&gt;
16&amp;gt;     HomePhone nvarchar (24) NULL ,&lt;br /&gt;
17&amp;gt;     Extension nvarchar (4) NULL ,&lt;br /&gt;
18&amp;gt;     Photo image NULL ,&lt;br /&gt;
19&amp;gt;     Notes ntext NULL ,&lt;br /&gt;
20&amp;gt;     ReportsTo int NULL ,&lt;br /&gt;
21&amp;gt;     PhotoPath nvarchar (255) NULL&lt;br /&gt;
22&amp;gt;&lt;br /&gt;
23&amp;gt; )&lt;br /&gt;
24&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt;    DECLARE @InVar   varchar(200)&lt;br /&gt;
4&amp;gt;&lt;br /&gt;
5&amp;gt;    SET @InVar = &amp;quot;DECLARE @OutVar varchar(50)&lt;br /&gt;
6~                 SELECT @OutVar = FirstName FROM Employees WHERE EmployeeID = 1&lt;br /&gt;
7~                 SELECT &amp;quot;&amp;quot;The Value Is &amp;quot;&amp;quot; + @OutVar&amp;quot;&lt;br /&gt;
8&amp;gt;&lt;br /&gt;
9&amp;gt;    EXEC (@Invar)&lt;br /&gt;
10&amp;gt;    GO&lt;br /&gt;
---------------------------------------------------------------&lt;br /&gt;
NULL&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;    drop table Employees;&lt;br /&gt;
3&amp;gt;    GO&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Pass parameters into dynamic sql statement==&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;
11&amp;gt;&lt;br /&gt;
12&amp;gt; CREATE TABLE Orders (&lt;br /&gt;
13&amp;gt;     OrderID int IDENTITY (1, 1) NOT NULL ,&lt;br /&gt;
14&amp;gt;     CustomerID nchar (5) NULL ,&lt;br /&gt;
15&amp;gt;     EmployeeID int NULL ,&lt;br /&gt;
16&amp;gt;     OrderDate datetime NULL ,&lt;br /&gt;
17&amp;gt;     RequiredDate datetime NULL ,&lt;br /&gt;
18&amp;gt;     ShippedDate datetime NULL ,&lt;br /&gt;
19&amp;gt;     ShipVia int NULL ,&lt;br /&gt;
20&amp;gt;     Freight money NULL DEFAULT (0),&lt;br /&gt;
21&amp;gt;     ShipName nvarchar (40) NULL ,&lt;br /&gt;
22&amp;gt;     ShipAddress nvarchar (60) NULL ,&lt;br /&gt;
23&amp;gt;     ShipCity nvarchar (15) NULL ,&lt;br /&gt;
24&amp;gt;     ShipRegion nvarchar (15) NULL ,&lt;br /&gt;
25&amp;gt;     ShipPostalCode nvarchar (10) NULL ,&lt;br /&gt;
26&amp;gt;     ShipCountry nvarchar (15) NULL&lt;br /&gt;
27&amp;gt; )&lt;br /&gt;
28&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt;&lt;br /&gt;
4&amp;gt; DECLARE @i AS INT;&lt;br /&gt;
5&amp;gt; SET @i = 10248;&lt;br /&gt;
6&amp;gt;&lt;br /&gt;
7&amp;gt; DECLARE @sql AS NVARCHAR(46);&lt;br /&gt;
8&amp;gt; SET @sql = &amp;quot;SELECT * FROM dbo.Orders WHERE OrderID = @oid;&amp;quot;;&lt;br /&gt;
9&amp;gt;&lt;br /&gt;
10&amp;gt; EXEC sp_executesql&lt;br /&gt;
11&amp;gt;   @stmt = @sql,&lt;br /&gt;
12&amp;gt;   @params = N&amp;quot;@oid AS INT&amp;quot;,&lt;br /&gt;
13&amp;gt;   @oid = @i;&lt;br /&gt;
14&amp;gt; GO&lt;br /&gt;
OrderID     CustomerID EmployeeID  OrderDate               RequiredDate            ShippedDate             ShipVia     Freight               ShipName                                 ShipAddress&lt;br /&gt;
                                           ShipCity        ShipRegion      ShipPostalCode ShipCountry&lt;br /&gt;
----------- ---------- ----------- ----------------------- ----------------------- ----------------------- ----------- --------------------- ---------------------------------------- ------------------&lt;br /&gt;
------------------------------------------ --------------- --------------- -------------- ---------------&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop table orders;&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
1&amp;gt;&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== SELECT query with a variable for the table name so that condition determines which table the result set is based on.==&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;
4&amp;gt;&lt;br /&gt;
5&amp;gt; CREATE TABLE sales(&lt;br /&gt;
6&amp;gt;    stor_id        char(4)           NOT NULL,&lt;br /&gt;
7&amp;gt;    ord_num        varchar(20)       NOT NULL,&lt;br /&gt;
8&amp;gt;    ord_date       datetime          NOT NULL,&lt;br /&gt;
9&amp;gt;    qty            smallint          NOT NULL,&lt;br /&gt;
10&amp;gt;    payterms       varchar(12)       NOT NULL,&lt;br /&gt;
11&amp;gt;    title_id       varchar(80)&lt;br /&gt;
12&amp;gt; )&lt;br /&gt;
13&amp;gt; GO&lt;br /&gt;
1&amp;gt; insert sales values(&amp;quot;1&amp;quot;, &amp;quot;QA7442.3&amp;quot;, &amp;quot;09/13/94&amp;quot;, 75, &amp;quot;ON Billing&amp;quot;,&amp;quot;1&amp;quot;)&lt;br /&gt;
2&amp;gt; insert sales values(&amp;quot;2&amp;quot;, &amp;quot;D4482&amp;quot;,    &amp;quot;09/14/94&amp;quot;, 10, &amp;quot;Net 60&amp;quot;,    &amp;quot;1&amp;quot;)&lt;br /&gt;
3&amp;gt; insert sales values(&amp;quot;3&amp;quot;, &amp;quot;N914008&amp;quot;,  &amp;quot;09/14/94&amp;quot;, 20, &amp;quot;Net 30&amp;quot;,    &amp;quot;2&amp;quot;)&lt;br /&gt;
4&amp;gt; insert sales values(&amp;quot;4&amp;quot;, &amp;quot;N914014&amp;quot;,  &amp;quot;09/14/94&amp;quot;, 25, &amp;quot;Net 30&amp;quot;,    &amp;quot;3&amp;quot;)&lt;br /&gt;
5&amp;gt; insert sales values(&amp;quot;5&amp;quot;, &amp;quot;423LL922&amp;quot;, &amp;quot;09/14/94&amp;quot;, 15, &amp;quot;ON Billing&amp;quot;,&amp;quot;3&amp;quot;)&lt;br /&gt;
6&amp;gt; insert sales values(&amp;quot;6&amp;quot;, &amp;quot;423LL930&amp;quot;, &amp;quot;09/14/94&amp;quot;, 10, &amp;quot;ON Billing&amp;quot;,&amp;quot;2&amp;quot;)&lt;br /&gt;
7&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&amp;gt;&lt;br /&gt;
2&amp;gt;     DECLARE @chvTable VARCHAR(30),&lt;br /&gt;
3&amp;gt;             @chvSQL VARCHAR(255)&lt;br /&gt;
4&amp;gt;     IF getdate() &amp;gt; &amp;quot;7/1/1997&amp;quot;&lt;br /&gt;
5&amp;gt;     SELECT @chvTable = &amp;quot;sales&amp;quot;&lt;br /&gt;
6&amp;gt;     ELSE&lt;br /&gt;
7&amp;gt;     SELECT @chvTable = &amp;quot;authors&amp;quot;&lt;br /&gt;
8&amp;gt;     SELECT @chvSQL = &amp;quot;SELECT * FROM &amp;quot; + @chvTable&lt;br /&gt;
9&amp;gt;     EXEC (@chvSQL)&lt;br /&gt;
10&amp;gt;     GO&lt;br /&gt;
stor_id ord_num              ord_date                qty    payterms     title_id&lt;br /&gt;
------- -------------------- ----------------------- ------ ------------ --------------------------------------------------------------------------------&lt;br /&gt;
1       QA7442.3             1994-09-13 00:00:00.000     75 ON Billing   1&lt;br /&gt;
2       D4482                1994-09-14 00:00:00.000     10 Net 60       1&lt;br /&gt;
3       N914008              1994-09-14 00:00:00.000     20 Net 30       2&lt;br /&gt;
4       N914014              1994-09-14 00:00:00.000     25 Net 30       3&lt;br /&gt;
5       423LL922             1994-09-14 00:00:00.000     15 ON Billing   3&lt;br /&gt;
6       423LL930             1994-09-14 00:00:00.000     10 ON Billing   2&lt;br /&gt;
(6 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; drop table sales;&lt;br /&gt;
3&amp;gt; GO&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Simple SELECT query that uses a variable for the field to sequence the result set.==&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;
4&amp;gt;&lt;br /&gt;
5&amp;gt;&lt;br /&gt;
6&amp;gt; CREATE TABLE authors(&lt;br /&gt;
7&amp;gt;    au_id          varchar(11),&lt;br /&gt;
8&amp;gt;    au_lname       varchar(40)       NOT NULL,&lt;br /&gt;
9&amp;gt;    au_fname       varchar(20)       NOT NULL,&lt;br /&gt;
10&amp;gt;    phone          char(12)          NOT NULL DEFAULT (&amp;quot;UNKNOWN&amp;quot;),&lt;br /&gt;
11&amp;gt;    address        varchar(40)           NULL,&lt;br /&gt;
12&amp;gt;    city           varchar(20)           NULL,&lt;br /&gt;
13&amp;gt;    state          char(2)               NULL,&lt;br /&gt;
14&amp;gt;    zip            char(5)               NULL,&lt;br /&gt;
15&amp;gt;    contract       bit               NOT NULL&lt;br /&gt;
16&amp;gt; )&lt;br /&gt;
17&amp;gt; GO&lt;br /&gt;
1&amp;gt; insert authors values(&amp;quot;1&amp;quot;,  &amp;quot;Joe&amp;quot;,   &amp;quot;Abra&amp;quot;,   &amp;quot;111 111-1111&amp;quot;, &amp;quot;6 St.&amp;quot;, &amp;quot;Berkeley&amp;quot;,  &amp;quot;CA&amp;quot;, &amp;quot;11111&amp;quot;, 1)&lt;br /&gt;
2&amp;gt; insert authors values(&amp;quot;2&amp;quot;,  &amp;quot;Jack&amp;quot;,  &amp;quot;Majo&amp;quot;,   &amp;quot;222 222-2222&amp;quot;, &amp;quot;3 St.&amp;quot;, &amp;quot;Oakland&amp;quot; ,  &amp;quot;CA&amp;quot;, &amp;quot;22222&amp;quot;, 1)&lt;br /&gt;
3&amp;gt; insert authors values(&amp;quot;3&amp;quot;,  &amp;quot;Pink&amp;quot;,  &amp;quot;Cherry&amp;quot;, &amp;quot;333 333-3333&amp;quot;, &amp;quot;5 Ln.&amp;quot;, &amp;quot;Vancouver&amp;quot;, &amp;quot;BC&amp;quot;, &amp;quot;33333&amp;quot;, 1)&lt;br /&gt;
4&amp;gt; insert authors values(&amp;quot;4&amp;quot;,  &amp;quot;Blue&amp;quot;,  &amp;quot;Albert&amp;quot;, &amp;quot;444 444-4444&amp;quot;, &amp;quot;7 Av.&amp;quot;, &amp;quot;Vancouver&amp;quot;, &amp;quot;BC&amp;quot;, &amp;quot;44444&amp;quot;, 1)&lt;br /&gt;
5&amp;gt; insert authors values(&amp;quot;5&amp;quot;,  &amp;quot;Red&amp;quot;,   &amp;quot;Anne&amp;quot;,   &amp;quot;555 555-5555&amp;quot;, &amp;quot;6 Av.&amp;quot;, &amp;quot;Regina&amp;quot;,    &amp;quot;SK&amp;quot;, &amp;quot;55555&amp;quot;, 1)&lt;br /&gt;
6&amp;gt; insert authors values(&amp;quot;6&amp;quot;,  &amp;quot;Black&amp;quot;, &amp;quot;Michel&amp;quot;, &amp;quot;666 666-6666&amp;quot;, &amp;quot;3 Pl.&amp;quot;, &amp;quot;Regina&amp;quot;,    &amp;quot;SK&amp;quot;, &amp;quot;66666&amp;quot;, 1)&lt;br /&gt;
7&amp;gt; insert authors values(&amp;quot;7&amp;quot;,  &amp;quot;White&amp;quot;, &amp;quot;Sylvia&amp;quot;, &amp;quot;777 777-7777&amp;quot;, &amp;quot;1 Pl.&amp;quot;, &amp;quot;Rockville&amp;quot;, &amp;quot;MD&amp;quot;, &amp;quot;77777&amp;quot;, 1)&lt;br /&gt;
8&amp;gt; insert authors values(&amp;quot;8&amp;quot;,  &amp;quot;Yellow&amp;quot;,&amp;quot;Heather&amp;quot;,&amp;quot;888 888-8888&amp;quot;, &amp;quot;3 Pu&amp;quot;,  &amp;quot;Vacaville&amp;quot;, &amp;quot;CA&amp;quot;, &amp;quot;88888&amp;quot;, 0)&lt;br /&gt;
9&amp;gt; insert authors values(&amp;quot;9&amp;quot;,  &amp;quot;Gold&amp;quot;,  &amp;quot;Dep&amp;quot;,    &amp;quot;999 999-9999&amp;quot;, &amp;quot;5 Av.&amp;quot;, &amp;quot;Oakland&amp;quot;,   &amp;quot;CA&amp;quot;, &amp;quot;99999&amp;quot;, 0)&lt;br /&gt;
10&amp;gt; insert authors values(&amp;quot;10&amp;quot;, &amp;quot;Siler&amp;quot;, &amp;quot;Dean&amp;quot;,   &amp;quot;000 000-0000&amp;quot;, &amp;quot;4 Av.&amp;quot;, &amp;quot;Oakland&amp;quot;,   &amp;quot;CA&amp;quot;, &amp;quot;00000&amp;quot;, 1)&lt;br /&gt;
11&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&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt;     DECLARE @chvOrderBy VARCHAR(30),&lt;br /&gt;
4&amp;gt;&lt;br /&gt;
5&amp;gt;             @chvSQL VARCHAR(255)&lt;br /&gt;
6&amp;gt;&lt;br /&gt;
7&amp;gt;     SELECT @chvOrderBy = &amp;quot;au_lname&amp;quot;&lt;br /&gt;
8&amp;gt;&lt;br /&gt;
9&amp;gt;     SELECT @chvSQL = &amp;quot;SELECT * FROM authors ORDER BY &amp;quot; + @chvOrderBy&lt;br /&gt;
10&amp;gt;&lt;br /&gt;
11&amp;gt;     EXEC (@chvSQL)&lt;br /&gt;
12&amp;gt;&lt;br /&gt;
13&amp;gt;     GO&lt;br /&gt;
au_id       au_lname                                 au_fname             phone        address                                  city                 state zip   contract&lt;br /&gt;
----------- ---------------------------------------- -------------------- ------------ ---------------------------------------- -------------------- ----- ----- --------&lt;br /&gt;
6           Black                                    Michel               666 666-6666 3 Pl.                                    Regina               SK    66666        1&lt;br /&gt;
4           Blue                                     Albert               444 444-4444 7 Av.                                    Vancouver            BC    44444        1&lt;br /&gt;
9           Gold                                     Dep                  999 999-9999 5 Av.                                    Oakland              CA    99999        0&lt;br /&gt;
2           Jack                                     Majo                 222 222-2222 3 St.                                    Oakland              CA    22222        1&lt;br /&gt;
1           Joe                                      Abra                 111 111-1111 6 St.                                    Berkeley             CA    11111        1&lt;br /&gt;
3           Pink                                     Cherry               333 333-3333 5 Ln.                                    Vancouver            BC    33333        1&lt;br /&gt;
5           Red                                      Anne                 555 555-5555 6 Av.                                    Regina               SK    55555        1&lt;br /&gt;
10          Siler                                    Dean                 000 000-0000 4 Av.                                    Oakland              CA    00000        1&lt;br /&gt;
7           White                                    Sylvia               777 777-7777 1 Pl.                                    Rockville            MD    77777        1&lt;br /&gt;
8           Yellow                                   Heather              888 888-8888 3 Pu                                     Vacaville            CA    88888        0&lt;br /&gt;
(10 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; drop table authors;&lt;br /&gt;
4&amp;gt; GO&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Using Stored Procedure to create dynamic sql statement==&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;
4&amp;gt;&lt;br /&gt;
5&amp;gt;&lt;br /&gt;
6&amp;gt; CREATE TABLE sales(&lt;br /&gt;
7&amp;gt;    stor_id        char(4)           NOT NULL,&lt;br /&gt;
8&amp;gt;    ord_num        varchar(20)       NOT NULL,&lt;br /&gt;
9&amp;gt;    ord_date       datetime          NOT NULL,&lt;br /&gt;
10&amp;gt;    qty            smallint          NOT NULL,&lt;br /&gt;
11&amp;gt;    payterms       varchar(12)       NOT NULL,&lt;br /&gt;
12&amp;gt;    title_id       varchar(80)&lt;br /&gt;
13&amp;gt; )&lt;br /&gt;
14&amp;gt; GO&lt;br /&gt;
1&amp;gt; insert sales values(&amp;quot;1&amp;quot;, &amp;quot;QA7442.3&amp;quot;, &amp;quot;09/13/94&amp;quot;, 75, &amp;quot;ON Billing&amp;quot;,&amp;quot;1&amp;quot;)&lt;br /&gt;
2&amp;gt; insert sales values(&amp;quot;2&amp;quot;, &amp;quot;D4482&amp;quot;,    &amp;quot;09/14/94&amp;quot;, 10, &amp;quot;Net 60&amp;quot;,    &amp;quot;1&amp;quot;)&lt;br /&gt;
3&amp;gt; insert sales values(&amp;quot;3&amp;quot;, &amp;quot;N914008&amp;quot;,  &amp;quot;09/14/94&amp;quot;, 20, &amp;quot;Net 30&amp;quot;,    &amp;quot;2&amp;quot;)&lt;br /&gt;
4&amp;gt; insert sales values(&amp;quot;4&amp;quot;, &amp;quot;N914014&amp;quot;,  &amp;quot;09/14/94&amp;quot;, 25, &amp;quot;Net 30&amp;quot;,    &amp;quot;3&amp;quot;)&lt;br /&gt;
5&amp;gt; insert sales values(&amp;quot;5&amp;quot;, &amp;quot;423LL922&amp;quot;, &amp;quot;09/14/94&amp;quot;, 15, &amp;quot;ON Billing&amp;quot;,&amp;quot;3&amp;quot;)&lt;br /&gt;
6&amp;gt; insert sales values(&amp;quot;6&amp;quot;, &amp;quot;423LL930&amp;quot;, &amp;quot;09/14/94&amp;quot;, 10, &amp;quot;ON Billing&amp;quot;,&amp;quot;2&amp;quot;)&lt;br /&gt;
7&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&amp;gt;&lt;br /&gt;
2&amp;gt;     CREATE PROCEDURE SalesQtys&lt;br /&gt;
3&amp;gt;         @chvOrderBy VARCHAR(30) = &amp;quot;qty&amp;quot;,&lt;br /&gt;
4&amp;gt;         @chvSortType VARCHAR(4) = &amp;quot;ASC&amp;quot;&lt;br /&gt;
5&amp;gt;     AS&lt;br /&gt;
6&amp;gt;     DECLARE @chvSQL VARCHAR(255)&lt;br /&gt;
7&amp;gt;     SELECT @chvSQL = &amp;quot;SELECT stor_id, ord_num, title_id, qty&amp;quot;&lt;br /&gt;
8&amp;gt;     SELECT @chvSQL = @chvSQL + &amp;quot; FROM Sales&amp;quot;&lt;br /&gt;
9&amp;gt;     SELECT @chvSQL = @chvSQL + &amp;quot; ORDER BY &amp;quot; + @chvOrderBy + &amp;quot; &amp;quot; + @chvSortType&lt;br /&gt;
10&amp;gt;     EXEC (@chvSQL)&lt;br /&gt;
11&amp;gt;     GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;     SalesQtys @chvOrderBy = &amp;quot;stor_id&amp;quot;, @chvSortType = &amp;quot;DESC&amp;quot;&lt;br /&gt;
3&amp;gt;     GO&lt;br /&gt;
stor_id ord_num              title_id                                                                         qty&lt;br /&gt;
------- -------------------- -------------------------------------------------------------------------------- ------&lt;br /&gt;
6       423LL930             2                                                                                    10&lt;br /&gt;
5       423LL922             3                                                                                    15&lt;br /&gt;
4       N914014              3                                                                                    25&lt;br /&gt;
3       N914008              2                                                                                    20&lt;br /&gt;
2       D4482                1                                                                                    10&lt;br /&gt;
1       QA7442.3             1                                                                                    75&lt;br /&gt;
(6 rows affected)&lt;br /&gt;
1&amp;gt;     SalesQtys&lt;br /&gt;
2&amp;gt;     GO&lt;br /&gt;
stor_id ord_num              title_id                                                                         qty&lt;br /&gt;
------- -------------------- -------------------------------------------------------------------------------- ------&lt;br /&gt;
2       D4482                1                                                                                    10&lt;br /&gt;
6       423LL930             2                                                                                    10&lt;br /&gt;
5       423LL922             3                                                                                    15&lt;br /&gt;
3       N914008              2                                                                                    20&lt;br /&gt;
4       N914014              3                                                                                    25&lt;br /&gt;
1       QA7442.3             1                                                                                    75&lt;br /&gt;
(6 rows affected)&lt;br /&gt;
1&amp;gt;     SalesQtys @chvOrderBy = &amp;quot;title_id&amp;quot;&lt;br /&gt;
2&amp;gt;     GO&lt;br /&gt;
stor_id ord_num              title_id                                                                         qty&lt;br /&gt;
------- -------------------- -------------------------------------------------------------------------------- ------&lt;br /&gt;
1       QA7442.3             1                                                                                    75&lt;br /&gt;
2       D4482                1                                                                                    10&lt;br /&gt;
3       N914008              2                                                                                    20&lt;br /&gt;
6       423LL930             2                                                                                    10&lt;br /&gt;
4       N914014              3                                                                                    25&lt;br /&gt;
5       423LL922             3                                                                                    15&lt;br /&gt;
(6 rows affected)&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; drop table sales;&lt;br /&gt;
4&amp;gt; GO&amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>