Solved

drop index does not work for unique keys

Posted on 2010-08-19
8
284 Views
Last Modified: 2012-05-10
what is the reason DROP index syntax is disabled for deleting unique keys (non PKs)

thanks
0
Comment
Question by:anushahanna
[X]
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
  • 4
  • 3
8 Comments
 
LVL 143

Assisted Solution

by:Guy Hengel [angelIII / a3]
Guy Hengel [angelIII / a3] earned 425 total points
ID: 33474819
this is because the PK is relying on the underlying index for it's function.

imagine you had a 2GB table with a primary key, but no index on that column.
the primary key constraint would have to do a full table scan for each insert & update for that field value !!!
0
 
LVL 18

Assisted Solution

by:Cluskitt
Cluskitt earned 75 total points
ID: 33474894
If you want to drop the index (possibly for rebuilding it), then drop the constraint first.
0
 
LVL 6

Author Comment

by:anushahanna
ID: 33475442
>>this is because the PK is relying on the underlying index for it's function.

even if PK and UK are both different? (example PK is on Col1 and UK is on Col3..)
0
Free learning courses: Active Directory Deep Dive

Get a firm grasp on your IT environment when you learn Active Directory best practices with Veeam! Watch all, or choose any amount, of this three-part webinar series to improve your skills. From the basics to virtualization and backup, we got you covered.

 
LVL 143

Accepted Solution

by:
Guy Hengel [angelIII / a3] earned 425 total points
ID: 33475652
if you have a PK and a UK, you will also have 2 indexes, 1 index per UK or PK constraint.
for the rest, it's the same situation: the database engine will not allow to drop the index.
0
 
LVL 6

Author Comment

by:anushahanna
ID: 33476646
are you saying PK will be relying on the unique index, regardless if they are the same or 2 diff indexes?
0
 
LVL 6

Author Comment

by:anushahanna
ID: 33476973
will DROP INDEX syntax work sometimes and othertimes not, for UNIQUE Indexes?
0
 
LVL 143

Assisted Solution

by:Guy Hengel [angelIII / a3]
Guy Hengel [angelIII / a3] earned 425 total points
ID: 33479687
>are you saying PK will be relying on the unique index, regardless if they are the same or 2 diff indexes?

no. let me clarify:
when you create a PK, sql server will create automatically create a index, for that PK constraint. and it will not let you drop that index.

when you create a UC (unique constraint), sql server will create automatically create a index, for that UC constraint. and it will not let you drop that index.

when you create whatever index, they will NOT be used for any PK or UC, and sql will let your drop that index without issues
this includes also unique indexes, as they are not created by a constraint as such

0
 
LVL 6

Author Comment

by:anushahanna
ID: 33484609
thanks angelIII, for the helpful explanation.
0

Featured Post

Comparison of Amazon Drive, Google Drive, OneDrive

What is Best for Backup: Amazon Drive, Google Drive or MS OneDrive? In this free whitepaper we look at their performance, pricing, and platform availability to help you decide which cloud drive is right for your situation. Download and read the results of our testing for free!

Question has a verified solution.

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

Introduction In my previous article (http://www.experts-exchange.com/Microsoft/Development/MS-SQL-Server/SSIS/A_9150-Loading-XML-Using-SSIS.html) I showed you how the XML Source component can be used to load XML files into a SQL Server database, us…
International Data Corporation (IDC) prognosticates that before the current the year gets over disbursing on IT framework products to be sent in cloud environs will be $37.1B.
This video shows, step by step, how to configure Oracle Heterogeneous Services via the Generic Gateway Agent in order to make a connection from an Oracle session and access a remote SQL Server database table.
Viewers will learn how to use the INSERT statement to insert data into their tables. It will also introduce the NULL statement, to show them what happens when no value is giving for any given column.

752 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