<?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%2FTransact_SQL%2FDynamic_SQL</id>
		<title>SQL Server/T-SQL/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%2FTransact_SQL%2FDynamic_SQL"/>
		<link rel="alternate" type="text/html" href="http://sqle.ru/index.php?title=SQL_Server/T-SQL/Transact_SQL/Dynamic_SQL&amp;action=history"/>
		<updated>2026-04-06T13:22:50Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://sqle.ru/index.php?title=SQL_Server/T-SQL/Transact_SQL/Dynamic_SQL&amp;diff=5684&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/Transact_SQL/Dynamic_SQL&amp;diff=5684&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://sqle.ru/index.php?title=SQL_Server/T-SQL/Transact_SQL/Dynamic_SQL&amp;diff=5685&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/Transact_SQL/Dynamic_SQL&amp;diff=5685&amp;oldid=prev"/>
				<updated>2010-05-26T10:20:06Z</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;==Build and call dynamic 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;
 &lt;br /&gt;
&lt;br /&gt;
8&amp;gt; CREATE TABLE authors(&lt;br /&gt;
9&amp;gt;    au_id          varchar(11),&lt;br /&gt;
10&amp;gt;    au_lname       varchar(40)       NOT NULL,&lt;br /&gt;
11&amp;gt;    au_fname       varchar(20)       NOT NULL,&lt;br /&gt;
12&amp;gt;    phone          char(12)          NOT NULL DEFAULT (&amp;quot;UNKNOWN&amp;quot;),&lt;br /&gt;
13&amp;gt;    address        varchar(40)           NULL,&lt;br /&gt;
14&amp;gt;    city           varchar(20)           NULL,&lt;br /&gt;
15&amp;gt;    state          char(2)               NULL,&lt;br /&gt;
16&amp;gt;    zip            char(5)               NULL,&lt;br /&gt;
17&amp;gt;    contract       bit               NOT NULL&lt;br /&gt;
18&amp;gt; )&lt;br /&gt;
19&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&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt;&lt;br /&gt;
4&amp;gt; CREATE PROC add_author&lt;br /&gt;
5&amp;gt; @au_id char(11),&lt;br /&gt;
6&amp;gt; @au_lname varchar(20),&lt;br /&gt;
7&amp;gt; @au_fname varchar(20),&lt;br /&gt;
8&amp;gt; @tabname varchar(30) AS&lt;br /&gt;
9&amp;gt;&lt;br /&gt;
10&amp;gt; BEGIN&lt;br /&gt;
11&amp;gt;     DECLARE @insert_stmt varchar(255)&lt;br /&gt;
12&amp;gt;     SELECT @insert_stmt=&amp;quot;INSERT &amp;quot; + @tabname + &amp;quot; (au_id,&lt;br /&gt;
13~         au_lname, au_fname, contract) VALUES (&amp;quot;&amp;quot;&amp;quot; + @au_id +&lt;br /&gt;
14&amp;gt;         &amp;quot;&amp;quot;&amp;quot;,&amp;quot;&amp;quot;&amp;quot; + @au_lname + &amp;quot;&amp;quot;&amp;quot;,&amp;quot;&amp;quot;&amp;quot; + @au_fname + &amp;quot;&amp;quot;&amp;quot;, 1)&amp;quot;&lt;br /&gt;
15&amp;gt;     &lt;br /&gt;
16&amp;gt;     EXECUTE (@insert_stmt)&lt;br /&gt;
17&amp;gt; END&lt;br /&gt;
18&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; EXEC add_author &amp;quot;999-99-1234&amp;quot;, &amp;quot;Pike&amp;quot;, &amp;quot;Neil&amp;quot;, &amp;quot;authors&amp;quot;&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt; drop PROC add_author;&lt;br /&gt;
4&amp;gt; GO&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&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Create dynamic sql from user name and date==&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;
3&amp;gt;&lt;br /&gt;
4&amp;gt; DECLARE @sqlstring varchar(100)&lt;br /&gt;
5&amp;gt; SELECT @sqlstring = &amp;quot;SELECT * FROM &amp;quot; + LTRIM(user_name()) +&lt;br /&gt;
6&amp;gt;                     CONVERT(char(2),DATEPART(dd, GETDATE()))&lt;br /&gt;
7&amp;gt; EXEC (@sqlstring)&lt;br /&gt;
8&amp;gt; GO&lt;br /&gt;
Msg 208, Level 16, State 1, Server J\SQLEXPRESS, Line 1&lt;br /&gt;
Invalid object name &amp;quot;dbo17&amp;quot;.&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Use aggregate function in 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;
 &lt;br /&gt;
&lt;br /&gt;
4&amp;gt; CREATE TABLE Orders (&lt;br /&gt;
5&amp;gt;      OrderID int IDENTITY (1, 1) NOT NULL ,&lt;br /&gt;
6&amp;gt;      CustomerID nchar (5) NULL ,&lt;br /&gt;
7&amp;gt;      EmployeeID int NULL ,&lt;br /&gt;
8&amp;gt;      OrderDate datetime NULL ,&lt;br /&gt;
9&amp;gt;      RequiredDate datetime NULL ,&lt;br /&gt;
10&amp;gt;     ShippedDate datetime NULL ,&lt;br /&gt;
11&amp;gt;     ShipVia int NULL ,&lt;br /&gt;
12&amp;gt;     Freight money NULL DEFAULT (0),&lt;br /&gt;
13&amp;gt;     ShipName nvarchar (40) NULL ,&lt;br /&gt;
14&amp;gt;     ShipAddress nvarchar (60) NULL ,&lt;br /&gt;
15&amp;gt;     ShipCity nvarchar (15) NULL ,&lt;br /&gt;
16&amp;gt;     ShipRegion nvarchar (15) NULL ,&lt;br /&gt;
17&amp;gt;     ShipPostalCode nvarchar (10) NULL ,&lt;br /&gt;
18&amp;gt;     ShipCountry nvarchar (15) NULL&lt;br /&gt;
19&amp;gt; )&lt;br /&gt;
20&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(805);&lt;br /&gt;
8&amp;gt;&lt;br /&gt;
9&amp;gt; SET @schemaname = N&amp;quot;dbo&amp;quot;;&lt;br /&gt;
10&amp;gt; SET @tablename  = N&amp;quot;Orders&amp;quot;;&lt;br /&gt;
11&amp;gt; SET @colname    = N&amp;quot;CustomerID&amp;quot;;&lt;br /&gt;
12&amp;gt; SET @sql = N&amp;quot;SELECT COUNT(DISTINCT &amp;quot;&lt;br /&gt;
13&amp;gt;   + QUOTENAME(@colname) + N&amp;quot;) FROM &amp;quot;&lt;br /&gt;
14&amp;gt;   + QUOTENAME(@schemaname)&lt;br /&gt;
15&amp;gt;   + N&amp;quot;.&amp;quot;&lt;br /&gt;
16&amp;gt;   + QUOTENAME(@tablename)&lt;br /&gt;
17&amp;gt;   + N&amp;quot;;&amp;quot;;&lt;br /&gt;
18&amp;gt;&lt;br /&gt;
19&amp;gt; EXEC(@sql);&lt;br /&gt;
20&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&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Using a dynamic sql statement in &amp;quot;Insert...select&amp;quot;==&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;
2&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(805),&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;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; INSERT INTO #T&lt;br /&gt;
22&amp;gt;   EXEC(@sql);&lt;br /&gt;
23&amp;gt; SET @cnt = (SELECT cnt FROM #T);&lt;br /&gt;
24&amp;gt; SELECT @cnt;&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 #T;&lt;br /&gt;
3&amp;gt; GO&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;
 &amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>