<?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_Tutorial%2FProcedure_Function%2FUtility_Procedure</id>
		<title>SQL Server/T-SQL Tutorial/Procedure Function/Utility Procedure - История изменений</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_Tutorial%2FProcedure_Function%2FUtility_Procedure"/>
		<link rel="alternate" type="text/html" href="http://www.sqle.ru/index.php?title=SQL_Server/T-SQL_Tutorial/Procedure_Function/Utility_Procedure&amp;action=history"/>
		<updated>2026-05-24T11:50:18Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://www.sqle.ru/index.php?title=SQL_Server/T-SQL_Tutorial/Procedure_Function/Utility_Procedure&amp;diff=7043&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_Tutorial/Procedure_Function/Utility_Procedure&amp;diff=7043&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://www.sqle.ru/index.php?title=SQL_Server/T-SQL_Tutorial/Procedure_Function/Utility_Procedure&amp;diff=7044&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_Tutorial/Procedure_Function/Utility_Procedure&amp;diff=7044&amp;oldid=prev"/>
				<updated>2010-05-26T10:25:07Z</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 script that creates a stored procedure that copies a table==&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;
14&amp;gt;&lt;br /&gt;
15&amp;gt; create table Billings (&lt;br /&gt;
16&amp;gt;     BankerID           INTEGER,&lt;br /&gt;
17&amp;gt;     BillingNumber      INTEGER,&lt;br /&gt;
18&amp;gt;     BillingDate        datetime,&lt;br /&gt;
19&amp;gt;     BillingTotal       INTEGER,&lt;br /&gt;
20&amp;gt;     TermsID            INTEGER,&lt;br /&gt;
21&amp;gt;     BillingDueDate     datetime ,&lt;br /&gt;
22&amp;gt;     PaymentTotal       INTEGER,&lt;br /&gt;
23&amp;gt;     CreditTotal        INTEGER&lt;br /&gt;
24&amp;gt;&lt;br /&gt;
25&amp;gt; );&lt;br /&gt;
26&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; INSERT INTO Billings VALUES (1, 1, &amp;quot;2005-01-22&amp;quot;, 165, 1,&amp;quot;2005-04-22&amp;quot;,123,321);&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (2, 2, &amp;quot;2001-02-21&amp;quot;, 165, 1,&amp;quot;2002-02-22&amp;quot;,123,321.);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (3, 3, &amp;quot;2003-05-02&amp;quot;, 165, 1,&amp;quot;2005-04-12&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (4, 4, &amp;quot;1999-03-12&amp;quot;, 165, 1,&amp;quot;2005-04-18&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (5, 5, &amp;quot;2000-04-23&amp;quot;, 165, 1,&amp;quot;2005-04-17&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (6, 6, &amp;quot;2001-06-14&amp;quot;, 165, 1,&amp;quot;2005-04-18&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (7, 7, &amp;quot;2002-07-15&amp;quot;, 165, 1,&amp;quot;2005-04-19&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (8, 8, &amp;quot;2003-08-16&amp;quot;, 165, 1,&amp;quot;2005-04-20&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (9, 9, &amp;quot;2004-09-17&amp;quot;, 165, 1,&amp;quot;2005-04-21&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (0, 0, &amp;quot;2005-10-18&amp;quot;, 165, 1,&amp;quot;2005-04-22&amp;quot;,123,321);&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; create table BillingCopy (&lt;br /&gt;
3&amp;gt;     BankerID           INTEGER,&lt;br /&gt;
4&amp;gt;     BillingNumber      INTEGER,&lt;br /&gt;
5&amp;gt;     BillingDate        datetime,&lt;br /&gt;
6&amp;gt;     BillingTotal       INTEGER,&lt;br /&gt;
7&amp;gt;     TermsID            INTEGER,&lt;br /&gt;
8&amp;gt;     BillingDueDate     datetime ,&lt;br /&gt;
9&amp;gt;     PaymentTotal       INTEGER,&lt;br /&gt;
10&amp;gt;     CreditTotal        INTEGER&lt;br /&gt;
11&amp;gt;&lt;br /&gt;
12&amp;gt; );&lt;br /&gt;
13&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; IF OBJECT_ID(&amp;quot;spCopyBillings&amp;quot;) IS NOT NULL&lt;br /&gt;
3&amp;gt;     DROP PROC spCopyBillings&lt;br /&gt;
4&amp;gt; GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt; CREATE PROC spCopyBillings&lt;br /&gt;
3&amp;gt; AS&lt;br /&gt;
4&amp;gt;     IF OBJECT_ID(&amp;quot;BillingCopy&amp;quot;) IS NOT NULL&lt;br /&gt;
5&amp;gt;         DROP TABLE BillingCopy&lt;br /&gt;
6&amp;gt;     SELECT *&lt;br /&gt;
7&amp;gt;     INTO BillingCopy&lt;br /&gt;
8&amp;gt;     FROM Billings&lt;br /&gt;
9&amp;gt;&lt;br /&gt;
10&amp;gt; drop table BillingCopy;&lt;br /&gt;
11&amp;gt; drop table Billings;&lt;br /&gt;
12&amp;gt; GO&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== A stored procedure that tests for a valid foreign key==&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;
13&amp;gt; create table Billings (&lt;br /&gt;
14&amp;gt;     BankerID           INTEGER,&lt;br /&gt;
15&amp;gt;     BillingNumber      INTEGER,&lt;br /&gt;
16&amp;gt;     BillingDate        datetime,&lt;br /&gt;
17&amp;gt;     BillingTotal       INTEGER,&lt;br /&gt;
18&amp;gt;     TermsID            INTEGER,&lt;br /&gt;
19&amp;gt;     BillingDueDate     datetime ,&lt;br /&gt;
20&amp;gt;     PaymentTotal       INTEGER,&lt;br /&gt;
21&amp;gt;     CreditTotal        INTEGER&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; INSERT INTO Billings VALUES (1, 1, &amp;quot;2005-01-22&amp;quot;, 165, 1,&amp;quot;2005-04-22&amp;quot;,123,321);&lt;br /&gt;
3&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (2, 2, &amp;quot;2001-02-21&amp;quot;, 165, 1,&amp;quot;2002-02-22&amp;quot;,123,321.);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (3, 3, &amp;quot;2003-05-02&amp;quot;, 165, 1,&amp;quot;2005-04-12&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (4, 4, &amp;quot;1999-03-12&amp;quot;, 165, 1,&amp;quot;2005-04-18&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (5, 5, &amp;quot;2000-04-23&amp;quot;, 165, 1,&amp;quot;2005-04-17&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (6, 6, &amp;quot;2001-06-14&amp;quot;, 165, 1,&amp;quot;2005-04-18&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (7, 7, &amp;quot;2002-07-15&amp;quot;, 165, 1,&amp;quot;2005-04-19&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (8, 8, &amp;quot;2003-08-16&amp;quot;, 165, 1,&amp;quot;2005-04-20&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (9, 9, &amp;quot;2004-09-17&amp;quot;, 165, 1,&amp;quot;2005-04-21&amp;quot;,123,321);&lt;br /&gt;
2&amp;gt; GO&lt;br /&gt;
(1 rows affected)&lt;br /&gt;
1&amp;gt; INSERT INTO Billings VALUES (0, 0, &amp;quot;2005-10-18&amp;quot;, 165, 1,&amp;quot;2005-04-22&amp;quot;,123,321);&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; CREATE PROC spInsertBilling&lt;br /&gt;
4&amp;gt;        @BankerID    int,           @BillingNumber  varchar(50),&lt;br /&gt;
5&amp;gt;        @BillingDate smalldatetime, @BillingTotal   money,&lt;br /&gt;
6&amp;gt;        @TermsID     int,           @BillingDueDate smalldatetime&lt;br /&gt;
7&amp;gt; AS&lt;br /&gt;
8&amp;gt; IF EXISTS(SELECT * FROM Bankers WHERE BankerID = @BankerID)&lt;br /&gt;
9&amp;gt;     BEGIN&lt;br /&gt;
10&amp;gt;         INSERT Billings (BankerID)&lt;br /&gt;
11&amp;gt;         VALUES (@BankerID)&lt;br /&gt;
12&amp;gt;     END&lt;br /&gt;
13&amp;gt; ELSE&lt;br /&gt;
14&amp;gt;     BEGIN&lt;br /&gt;
15&amp;gt;         RAISERROR(&amp;quot;Not a valid BankerID!&amp;quot;,1,1)&lt;br /&gt;
16&amp;gt;         RETURN -100&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; drop PROC spInsertBilling;&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 Billings;&lt;br /&gt;
4&amp;gt; GO&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Create procedure to drop foreign key==&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;&lt;br /&gt;
7&amp;gt;     CREATE PROCEDURE prDropForeignKeys&lt;br /&gt;
8&amp;gt;         @chvReferencedTable VARCHAR(30)&lt;br /&gt;
9&amp;gt;     AS&lt;br /&gt;
10&amp;gt;     DECLARE @chvTableWithForeignKey VARCHAR(30),&lt;br /&gt;
11&amp;gt;             @chvForeignKey VARCHAR(30),&lt;br /&gt;
12&amp;gt;             @chvSQL VARCHAR(255)&lt;br /&gt;
13&amp;gt;     DECLARE cuFKs CURSOR&lt;br /&gt;
14&amp;gt;         FOR&lt;br /&gt;
15&amp;gt;         SELECT tb.name,&lt;br /&gt;
16&amp;gt;                fk.name&lt;br /&gt;
17&amp;gt;         FROM ((sysobjects tb INNER JOIN sysreferences r ON tb.id = r.fkeyid)&lt;br /&gt;
18&amp;gt;             INNER JOIN sysobjects fk ON r.constid = fk.id)&lt;br /&gt;
19&amp;gt;             INNER JOIN sysobjects refd_tb ON refd_tb.id = r.rkeyid&lt;br /&gt;
20&amp;gt;         WHERE refd_tb.name = @chvReferencedTable&lt;br /&gt;
21&amp;gt;     OPEN cuFKs&lt;br /&gt;
22&amp;gt;     FETCH NEXT FROM cuFKs INTO&lt;br /&gt;
23&amp;gt;         @chvTableWithForeignKey, @chvForeignKey&lt;br /&gt;
24&amp;gt;     WHILE (@@fetch_status &amp;lt;&amp;gt; -1)&lt;br /&gt;
25&amp;gt;         BEGIN&lt;br /&gt;
26&amp;gt;             SELECT @chvSQL = &amp;quot;ALTER TABLE &amp;quot; + @chvTableWithForeignKey&lt;br /&gt;
27&amp;gt;                              + &amp;quot; DROP CONSTRAINT &amp;quot; + @chvForeignKey&lt;br /&gt;
28&amp;gt;             EXEC (@chvSQL)&lt;br /&gt;
29&amp;gt;             FETCH NEXT FROM cuFKs INTO&lt;br /&gt;
30&amp;gt;                 @chvTableWithForeignKey, @chvForeignKey&lt;br /&gt;
31&amp;gt;         END&lt;br /&gt;
32&amp;gt;     DEALLOCATE cuFKs&lt;br /&gt;
33&amp;gt;     GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;     drop PROCEDURE prDropForeignKeys;&lt;br /&gt;
3&amp;gt;     GO&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== Spelling single digits.==&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 PROC pr_single @chrDigit CHAR(1), @chrSd VARCHAR(6) OUTPUT&lt;br /&gt;
6&amp;gt;     AS&lt;br /&gt;
7&amp;gt;     IF @chrDigit = &amp;quot;1&amp;quot;&lt;br /&gt;
8&amp;gt;         BEGIN&lt;br /&gt;
9&amp;gt;              SELECT @chrSd = &amp;quot;One&amp;quot;&lt;br /&gt;
10&amp;gt;         RETURN&lt;br /&gt;
11&amp;gt;         END&lt;br /&gt;
12&amp;gt;     ELSE&lt;br /&gt;
13&amp;gt;     IF @chrDigit = &amp;quot;2&amp;quot;&lt;br /&gt;
14&amp;gt;         BEGIN&lt;br /&gt;
15&amp;gt;              SELECT @chrSd = &amp;quot;Two&amp;quot;&lt;br /&gt;
16&amp;gt;          RETURN&lt;br /&gt;
17&amp;gt;         END&lt;br /&gt;
18&amp;gt;     ELSE&lt;br /&gt;
19&amp;gt;     IF @chrDigit = &amp;quot;3&amp;quot;&lt;br /&gt;
20&amp;gt;         BEGIN&lt;br /&gt;
21&amp;gt;              SELECT @chrSd = &amp;quot;Three&amp;quot;&lt;br /&gt;
22&amp;gt;          RETURN&lt;br /&gt;
23&amp;gt;         END&lt;br /&gt;
24&amp;gt;     ELSE&lt;br /&gt;
25&amp;gt;     IF @chrDigit = &amp;quot;4&amp;quot;&lt;br /&gt;
26&amp;gt;         BEGIN&lt;br /&gt;
27&amp;gt;              SELECT @chrSd = &amp;quot;Four&amp;quot;&lt;br /&gt;
28&amp;gt;          RETURN&lt;br /&gt;
29&amp;gt;         END&lt;br /&gt;
30&amp;gt;     ELSE&lt;br /&gt;
31&amp;gt;     IF @chrDigit = &amp;quot;5&amp;quot;&lt;br /&gt;
32&amp;gt;         BEGIN&lt;br /&gt;
33&amp;gt;              SELECT @chrSd = &amp;quot;Five&amp;quot;&lt;br /&gt;
34&amp;gt;          RETURN&lt;br /&gt;
35&amp;gt;         END&lt;br /&gt;
36&amp;gt;     ELSE&lt;br /&gt;
37&amp;gt;     IF @chrDigit = &amp;quot;6&amp;quot;&lt;br /&gt;
38&amp;gt;         BEGIN&lt;br /&gt;
39&amp;gt;              SELECT @chrSd = &amp;quot;Six&amp;quot;&lt;br /&gt;
40&amp;gt;          RETURN&lt;br /&gt;
41&amp;gt;         END&lt;br /&gt;
42&amp;gt;     ELSE&lt;br /&gt;
43&amp;gt;     IF @chrDigit = &amp;quot;7&amp;quot;&lt;br /&gt;
44&amp;gt;         BEGIN&lt;br /&gt;
45&amp;gt;              SELECT @chrSd = &amp;quot;Seven&amp;quot;&lt;br /&gt;
46&amp;gt;          RETURN&lt;br /&gt;
47&amp;gt;         END&lt;br /&gt;
48&amp;gt;     ELSE&lt;br /&gt;
49&amp;gt;     IF @chrDigit = &amp;quot;8&amp;quot;&lt;br /&gt;
50&amp;gt;         BEGIN&lt;br /&gt;
51&amp;gt;              SELECT @chrSd = &amp;quot;Eight&amp;quot;&lt;br /&gt;
52&amp;gt;          RETURN&lt;br /&gt;
53&amp;gt;         END&lt;br /&gt;
54&amp;gt;     ELSE&lt;br /&gt;
55&amp;gt;     IF @chrDigit = &amp;quot;9&amp;quot;&lt;br /&gt;
56&amp;gt;         BEGIN&lt;br /&gt;
57&amp;gt;              SELECT @chrSd = &amp;quot;Nine&amp;quot;&lt;br /&gt;
58&amp;gt;          RETURN&lt;br /&gt;
59&amp;gt;         END&lt;br /&gt;
60&amp;gt;     ELSE&lt;br /&gt;
61&amp;gt;          SELECT @chrSd = &amp;quot;&amp;quot;&lt;br /&gt;
62&amp;gt;     GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;     DROP PROC pr_single&lt;br /&gt;
3&amp;gt;     GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;&lt;br /&gt;
3&amp;gt;&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
== uses system tables to determine the datatype of a field.==&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;&lt;br /&gt;
4&amp;gt;&lt;br /&gt;
5&amp;gt;     CREATE PROCEDURE prNeedsQuotes&lt;br /&gt;
6&amp;gt;         @chvTable VARCHAR(30),&lt;br /&gt;
7&amp;gt;         @chvField VARCHAR(30),&lt;br /&gt;
8&amp;gt;         @chvNeedsQuotes CHAR(1) OUTPUT&lt;br /&gt;
9&amp;gt;     AS&lt;br /&gt;
10&amp;gt;         DECLARE @chvDataType VARCHAR(30), @intUserType INT&lt;br /&gt;
11&amp;gt;     SELECT @chvDataType = LOWER(st.name), @intUserType = st.usertype&lt;br /&gt;
12&amp;gt;         FROM (sysObjects so INNER JOIN sysColumns sc ON so.id = sc.id)&lt;br /&gt;
13&amp;gt;             INNER JOIN sysTypes st ON sc.usertype = st.usertype&lt;br /&gt;
14&amp;gt;         WHERE so.type = &amp;quot;U&amp;quot;&lt;br /&gt;
15&amp;gt;             AND so.name = @chvTable&lt;br /&gt;
16&amp;gt;             AND sc.name = @chvField&lt;br /&gt;
17&amp;gt;     IF @intUserType &amp;gt; 100&lt;br /&gt;
18&amp;gt;             BEGIN&lt;br /&gt;
19&amp;gt;                 SELECT @chvDataType = LOWER(st2.name)&lt;br /&gt;
20&amp;gt;                 FROM sysTypes st1 INNER JOIN sysTypes st2 ON st1.Type = st2.Type&lt;br /&gt;
21&amp;gt;                 WHERE st2.userType &amp;lt; 100&lt;br /&gt;
22&amp;gt;                   AND st2.userType NOT IN (18, 80)&lt;br /&gt;
23&amp;gt;                   AND st1.usertype = @intUserType&lt;br /&gt;
24&amp;gt;             END&lt;br /&gt;
25&amp;gt;     SELECT @chvNeedsQuotes =&lt;br /&gt;
26&amp;gt;             CASE @chvDataType&lt;br /&gt;
27&amp;gt;                 WHEN &amp;quot;char&amp;quot; THEN &amp;quot;y&amp;quot;&lt;br /&gt;
28&amp;gt;                 WHEN &amp;quot;datetime&amp;quot; THEN &amp;quot;y&amp;quot;&lt;br /&gt;
29&amp;gt;                 WHEN &amp;quot;datetimn&amp;quot; THEN &amp;quot;y&amp;quot;&lt;br /&gt;
30&amp;gt;                 WHEN &amp;quot;smalldatetime&amp;quot; THEN &amp;quot;y&amp;quot;&lt;br /&gt;
31&amp;gt;                 WHEN &amp;quot;text&amp;quot; THEN &amp;quot;y&amp;quot;&lt;br /&gt;
32&amp;gt;                 WHEN &amp;quot;timestamp&amp;quot; THEN &amp;quot;y&amp;quot;&lt;br /&gt;
33&amp;gt;                 WHEN &amp;quot;varchar&amp;quot; THEN &amp;quot;y&amp;quot;&lt;br /&gt;
34&amp;gt;                 ELSE &amp;quot;n&amp;quot;&lt;br /&gt;
35&amp;gt;             END&lt;br /&gt;
36&amp;gt;     GO&lt;br /&gt;
1&amp;gt;&lt;br /&gt;
2&amp;gt;     drop PROCEDURE prNeedsQuotes ;&lt;br /&gt;
3&amp;gt;     GO&amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>