• Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 215
  • Last Modified:

Is it possible to find the structure of a Global Table which is created in Proc A and referenced in Proc B

I have a global table created in proc A and then referenced in proc b.

I would like to know in Proc B, if the global table has a particular column, how can I do that
Proc A
INSERT INTO #Activity
EXEC dbdetails.dbo.Proc_B
    @TableName = @GlobalTableName_parm, 
    @ServerName = @@SERVERNAME,
    @UpdateFlag = 1,
    @SuccessFlag = @SuccessFlag OUTPUT
 
Proc_B
CREATE PROCEDURE Proc_B
    @TableName  varchar(100),
    @ServerName varchar(50),
    @UpdateFlag int,
    @SuccessFlag tinyint OUTPUT
AS
 
I would like to know the sql that I can excute to verify that @TableName  has a particular column say 'Test'

Open in new window

0
countrymeister
Asked:
countrymeister
  • 3
  • 2
1 Solution
 
randy_knightCommented:
What do you mean by global table?  A global temporary table (i.e. ##table)?
0
 
countrymeisterAuthor Commented:
Yes , the global table is named ##TableA_spid
0
 
randy_knightCommented:
I don't think there is an easy way to do that.  However, an altenative would be to create your global temp tables as hard tables in tempdb (i.e. tempdb.dbo.TableA_spid) and then drop them at the end of your process.  

Then you could used this to find the column:



if exists(select * from tempdb.dbo.syscolumns where id = object_id('TableA_spid' and name = 'test')
    print 'column exists'
else
    print 'column does not exist'

Open in new window

0
 
countrymeisterAuthor Commented:
I am creating the global table as follows
SELECT @GlobalTableName = '##TableA_' + convert(varchar(10),@@spid)

SELECT @EXECSQLText = N'CREATE TABLE ' + @GlobalTableName
( col1, col2....)

I am droping them after I use them

But the following sql does not work to check if the column exists in the global table, where @TableName is the global table

Set @IncludeTaxes = 0
-- Check if the calling proc has passed the test column  to the  proc B
Set @IncludeTaxes = (SELECT Count(*) FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_NAME = @TableName AND COLUMN_NAME = 'Test')
0
 
randy_knightCommented:
Right.  Because INFORMATION_SCHEMA.COLUMNS won't have info on temporary tables.  What I am saying is create a "permanent" table in tempdb like this:

SELECT @GlobalTableName = 'TableA_' + convert(varchar(10),@@spid)

Then it will be in syscolumsn and the DSV above.
0

Featured Post

Industry Leaders: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

  • 3
  • 2
Tackle projects and never again get stuck behind a technical roadblock.
Join Now