Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people, just like you, are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
Solved

How do you change a column name of a  table in an SQL Server 2005 database?

Posted on 2008-06-17
5
685 Views
Last Modified: 2008-06-28
I just successfully migrated the backend of an Access 2000 database into SQL Server 2005. Some of the column names in a couple of the tables were altered in the migration process and need to be changed. How do you alter a column name of a Table in a SQL Server 2005 database?  Thanks,
0
Comment
Question by:PDSWSS
  • 2
  • 2
5 Comments
 
LVL 6

Accepted Solution

by:
J_Carter earned 250 total points
ID: 21808318
This example renames the contact title column in the customers table to title.

EXEC sp_rename 'customers.[contact title]', 'title', 'COLUMN'
0
 
LVL 8

Assisted Solution

by:Yiogi
Yiogi earned 250 total points
ID: 21808400
Either from the sql server management studio, or just write the sql code to do it. Either as J Carter said or with the plain good old way:
ALTER TABLE TableName CHANGE PreviousColumnName NewColumnName VarChar(50)

Note that VarChar(50) is just your datatype. You could put whatever you need there.

Should you need to simply change the datatype you could do:
ALTER TABLE TableName MODIFY ColumnName VarChar(20)
0
 

Author Comment

by:PDSWSS
ID: 21808518
Thanks for your quick responses -

It appears that SQL renamed 6 consecutive columns with the same name. However, the data appears to be in the correct order if the columns had their correct names.
According to your instructions I would need to rename 5 of these 6 columns with a different name before
I could change them each to the correct name since this command couldn't distinguish between 6 columns with the same name.  Is there a better way to do this?  Thanks,
0
 
LVL 8

Expert Comment

by:Yiogi
ID: 21811587
Are you sure they have the exact same name? I don't think that's allowed and most likely it wouldn't let you rename in such a case. It will never let you create a table with columns that have the same name. can you script the table as create and post it here?

Thanks.
0
 

Author Comment

by:PDSWSS
ID: 21816535
After looking more closely I see I was mistaken - they are very similar but not exactly the same.
As soon as I get a chance I will try your alter column title suggestions.

Thanks,
0

Featured Post

Complete VMware vSphere® ESX(i) & Hyper-V Backup

Capture your entire system, including the host, with patented disk imaging integrated with VMware VADP / Microsoft VSS and RCT. RTOs is as low as 15 seconds with Acronis Active Restore™. You can enjoy unlimited P2V/V2V migrations from any source (even from a different hypervisor)

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

In this article we will get to know that how can we recover deleted data if it happens accidently. We really can recover deleted rows if we know the time when data is deleted by using the transaction log.
It’s been over a month into 2017, and there is already a sophisticated Gmail phishing email making it rounds. New techniques and tactics, have given hackers a way to authentically impersonate your contacts.How it Works The attack works by targeti…
In Microsoft Access, learn different ways of passing a string value within a string argument. Also learn what a “Type Mis-match” error is about.
With Microsoft Access, learn how to start a database in different ways and produce different start-up actions allowing you to use a single database to perform multiple tasks. Specify a start-up form through options: Specify an Autoexec macro: Us…

790 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question