日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

Oracle與MySQL刪除字段時對索引和約束的處理

瀏覽:258日期:2023-11-23 09:18:07

不知道有多少人清楚的知道,在Oracle中,如果一個復合索引,假定索引(a,b,c)三個字段,刪除了(包括unused)其中一個字段,Oracle會怎么處理這個索引。同樣,如果是約束,Oracle又怎么處理?

用Oracle為例子,我又拿mysql做了一個對比,看看mysql是怎么處理這個問題的。我這里不討論誰好誰差,只是希望大家知道其中的差別與細節(jié)而已。

我們先看Oracle的例子,我們創(chuàng)建一個表,然后在上面創(chuàng)建一個約束,創(chuàng)建一個索引:

SQL10G>createtabletest(aint,bint,cint);

Tablecreated.

SQL10G>altertabletestaddconstraintpk_testprimarykey(a,b);

Tablealtered.

SQL10G>createindexind_testontest(b,c);

Indexcreated.

然后,我們檢查剛才創(chuàng)建的約束與索引

SQL10G>selectt.constraint_name,c.constraint_type,t.column_name,t.position,c.status,c.validated

2fromuser_cons_columnst,user_constraintsc

3wherec.constraint_name=t.constraint_name

4andc.constraint_type!='C'

5andt.table_name='TEST'

6orderbyconstraint_name,position;

CONSTRAINT_NAMECCOLUMN_NAMEPOSITIONSTATUSVALIDATED

------------------------------------------------------------

PK_TESTPA1ENABLEDVALIDATED

PK_TESTPB2ENABLEDVALIDATED

SQL10G>selectt.index_name,t.column_name,t.column_position,i.status

2fromuser_ind_columnst,user_indexesi

3wheret.index_name=i.index_name

4andt.table_name='TEST'

5*orderbyindex_name,column_position

INDEX_NAMECOLUMN_NAMECOLUMN_POSITIONSTATUS

-------------------------------------------------

IND_TESTB1VALID

IND_TESTC2VALID

現(xiàn)在,我們先刪除索引上的字段,其實并沒有物理刪除,只是設置為unused:

SQL10G>ALTERTABLEtestSETUNUSED(c);

Tablealtered.

SQL10G>selectt.index_name,t.column_name,t.column_position,i.status

2fromuser_ind_columnst,user_indexesi

3wheret.index_name=i.index_name

4andt.table_name='TEST'

5orderbyindex_name,column_position;

norowsselected

發(fā)現(xiàn)了什么,索引也刪除了。那我們再刪除約束上的字段呢?

SQL10G>ALTERTABLEtestSETUNUSED(b);

ALTERTABLEtestSETUNUSED(b)

*

ERRORatline1:

ORA-12991:columnisreferencedinamulti-columnconstraint

SQL10G>ALTERTABLEtestSETUNUSED(b)CASCADECONSTRAINTS;

Tablealtered.

SQL10G>selectt.constraint_name,c.constraint_type,t.column_name,t.position,c.status,c.validated

2fromuser_cons_columnst,user_constraintsc

3wherec.constraint_name=t.constraint_name

4andc.constraint_type!='C'

5andt.table_name='TEST'

6orderbyconstraint_name,position;

norowsselected

我們可以看到,正常的刪除會報一個錯誤,如果我們指定了cascade,將會把對應的約束也刪除。

我們看完了Oracle的處理過程,再看看mysql是這么處理刪除索引上字段這個事情的

mysql>createtabletest(aint,bint,cint);

QueryOK,0rowsaffected(0.72sec)

mysql>altertabletestaddprimarykey(a,b);

QueryOK,0rowsaffected(0.27sec)

Records:0Duplicates:0Warnings:0

mysql>createindexind_testontest(b,c);

QueryOK,0rowsaffected(0.32sec)

Records:0Duplicates:0Warnings:0

我們執(zhí)行同樣的操作,先刪除復合索引中的一個字段,然后刪除約束中的一個字段。

mysql>altertabletestdropc;

QueryOK,0rowsaffected(0.58sec)

Records:0Duplicates:0Warnings:0

mysql>showindexfromtest;

+-------+------------+----------+-----------+

|Table|Non_unique|Key_name|Seq_in_index|Column_name|Collation|

+-------+------------+----------+-----------+

|test|0|PRIMARY|1|a|A|

|test|0|PRIMARY|2|b|A|

|test|1|ind_test|1|b|A|

+-------+------------+----------+-----------+

3rowsinset(0.06sec)

mysql>altertabletestdropb;

QueryOK,0rowsaffected(0.28sec)

Records:0Duplicates:0Warnings:0

mysql>showindexfromtest;

+-------+------------+----------+-----------+

|Table|Non_unique|Key_name|Seq_in_index|Column_name|Collation|

+-------+------------+----------+-----------+

|test|0|PRIMARY|1|a|A|

+-------+------------+----------+-----------+

1rowinset(0.03sec)

可以看到,mysql的處理方式是有差別的,mysql僅僅是把字段從索引中拿掉,而不是刪除該索引。

本文的意思,就是想提醒大家,平常在做columns刪除的時候,包括unused,一定要小心,是否有復合索引包含了該字段,否則,一不小心把索引刪除了,可能將引發(fā)大的錯誤。

日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产精品一区二区三区av| 开心激情综合| 亚洲小说欧美另类婷婷| 国产精品99一区二区三| 老牛国内精品亚洲成av人片| 青青草国产精品亚洲专区无| 亚洲一区av| 日本精品一区二区三区在线观看视频| 久久大逼视频| 久久国产乱子精品免费女| 日韩一区二区三区高清在线观看| 成人日韩在线观看| 久久中文字幕二区| 亚洲一区日韩| 亚洲3区在线| 国产成人免费视频网站视频社区| 国产亚洲一区二区手机在线观看| 午夜av成人| 亚洲欧洲另类| 奇米狠狠一区二区三区| 91嫩草亚洲精品| 欧美日韩精品一本二本三本| 日本aⅴ亚洲精品中文乱码| 免费一区二区三区在线视频| 色老板在线视频一区二区| 日韩精品一区二区三区免费观影| 亚洲欧美视频| 乱一区二区av| 久久最新视频| 精品五月天堂| 亚洲tv在线| 欧洲精品一区二区三区| 婷婷成人av| 亚洲不卡av不卡一区二区| 日韩av资源网| 午夜精品免费| 精品理论电影在线| 午夜在线一区二区| 日韩一区二区在线免费| 日本高清久久| 国产99精品一区| 欧美一级久久| 日韩精品一区第一页| av资源亚洲| 国产一区国产二区国产三区| 日本va欧美va精品| 亚洲在线观看| 亚洲一本视频| 国产精品福利在线观看播放| 日韩精品三区四区| 亚洲手机视频| 日韩在线看片| 一区二区三区四区日本视频| 久久狠狠亚洲综合| 日韩精品免费一区二区夜夜嗨 | 国产精品一区二区精品视频观看 | 日本va欧美va瓶| 99riav1国产精品视频| 久久av网站| 国产探花在线精品一区二区| 日本a级不卡| 青青国产精品| 国产美女精品视频免费播放软件| 日本少妇精品亚洲第一区| 日本一区二区三区视频在线看| 亚洲欧洲日韩精品在线| 亚欧洲精品视频在线观看| 日韩精品高清不卡| 国产欧美日韩亚洲一区二区三区| 国产精品一区二区中文字幕| 国产精品宾馆| 国产精品国产三级国产在线观看| 欧美国产偷国产精品三区| 国产精品tv| 超碰99在线| 一区在线免费| 国产精品大片| 91精品国产调教在线观看| 亚洲免费中文| 精品国产中文字幕第一页| 中文字幕在线看片| 午夜一区在线| 麻豆精品视频在线观看免费| 久久久国产精品一区二区中文| 久久精品二区三区| 人人爱人人干婷婷丁香亚洲| 超碰在线99| 水蜜桃久久夜色精品一区的特点 | 青草av.久久免费一区| 精品国产乱码久久久久久樱花| 一区二区三区视频免费观看| 亚洲精品无播放器在线播放| 久久av日韩| 免费观看在线综合色| 麻豆91精品视频| 欧美aa国产视频| 精品久久国产一区| 三级久久三级久久久| 色老板在线视频一区二区| 欧美在线看片| 亚洲天堂久久| 黄色网一区二区| 日韩中出av| 黄色在线一区| 午夜精品成人av| 久久久久伊人| 国产日韩高清一区二区三区在线| 亚洲精品电影| 久久三级福利| 日韩一区二区在线免费| 国产亚洲高清在线观看| 麻豆91精品| 亚洲午夜精品久久久久久app| 国产一区二区亚洲| 国产精品美女午夜爽爽| 狠狠色综合网| 国产精品7m凸凹视频分类| 成人国产精品久久| 国产精品va| 国产精品17p| 久久精品一区| 精品国产乱码久久久久久1区2匹| 日本aⅴ亚洲精品中文乱码| 四虎精品一区二区免费| 中文字幕一区二区三区日韩精品 | 欧美天堂视频| 首页国产精品| 日韩在线观看一区| 日韩在线看片| 日韩在线观看| 久久久久久美女精品| 999久久久精品国产| 久久久久久久久久久妇女| 日本美女一区| 西西人体一区二区| 婷婷精品在线| 欧美天堂一区| 精品91福利视频| 黄色在线网站噜噜噜| 久久精品免费一区二区三区| 国产在线欧美| 视频一区二区三区中文字幕| 一二三区精品| 欧美成人精品午夜一区二区| 国产欧美一区二区精品久久久| 久久超碰99| 国产麻豆久久| 日本不卡一区二区| 国产精品毛片一区二区在线看| 99久久夜色精品国产亚洲1000部| 尤物在线精品| 日本免费在线视频不卡一不卡二| 久久精品二区亚洲w码 | 国产亚洲观看| 久久一区二区三区电影| 中文字幕乱码亚洲无线精品一区| 国产精品大片免费观看| www在线观看黄色| 午夜在线视频观看日韩17c| 久久精品人人| 丝袜诱惑制服诱惑色一区在线观看 | 精品视频国产| 久久夜色精品| 日本不良网站在线观看| 日本一不卡视频| 女人天堂亚洲aⅴ在线观看| 久久精品国产亚洲一区二区三区| 美女日韩在线中文字幕| 国产欧洲在线| 青青草国产成人99久久| 欧美日韩激情| 国产精品久久久久蜜臀 | 欧美亚洲激情| 国产不卡一区| 国产精品欧美在线观看| 香蕉成人久久| 亚洲天堂一区二区| 国产中文字幕一区二区三区| 日日夜夜免费精品视频| 狠狠色狠狠色综合日日tαg| 日韩电影免费在线观看| 国产日产精品_国产精品毛片 | 欧美日韩视频免费看| 丝袜美腿高跟呻吟高潮一区| 久久久精品久久久久久96| 精品资源在线| 国内揄拍国内精品久久| 国产日韩一区二区三区在线播放| 综合国产在线| 日韩精品导航| 亚洲视频电影在线| 国产精品人人爽人人做我的可爱| 免费在线欧美黄色| 日本欧美韩国一区三区| 婷婷视频一区二区三区| 日韩综合小视频| 欧美一级网址| 国产探花在线精品| 亚洲深夜福利在线观看| 男人操女人的视频在线观看欧美|