开发者

How does MySQL handle compound unique indexes with limited lengths?

开发者 https://www.devze.com 2023-03-29 04:50 出处:网络
Assuming two columns in a MySQL (MyISAM) table: title VARCHAR(1500) url VARCHAR(155) I want to create a composite unique index on both columns. I know of the limiting length feature for too long co

Assuming two columns in a MySQL (MyISAM) table:

title VARCHAR(1500)
url VARCHAR(155)

I want to create a composite unique index on both columns. I know of the limiting length feature for too long columns (like my title column). How does it play with compound indexes?

What I want is something like:

|--- url_value ---| + |--开发者_运维知识库- title_value ---|
|--------155------| + |--------rest-------| <-- This should be the key length

By that I mean the key should have maximum length (I am using utf8 as encoding so I am limited to 333 characters allowed per column for unique indexes), where all 155 characters of column url and 178 characters of column title should be respected in the unique index. Sorry for the bad English. I tried to explain as well as I could. So bear with me if it seems confusing and I gladly will provide more information, if necessary.


I'm not exactly sure what your question is, so this may not really answer it, but one option for enforcing uniqueness on long fields like that is to instead enforce a unique constraint on a hash of the long fields, using MD5, or any other hashing algorithm that suits your needs. So...

title VARCHAR(1500)
url VARCHAR(155)
title_md5 VARCHAR(16)

You could create a trigger that automatically populates title_md5 every time title is updated. Then you put your unique index on (url,title_md5).

Of course this has some drawbacks. There is more overhead in the actual table--although much of that can be offset by the smaller/more efficient index. Also, indexing title_md5 doesn't make searching the actual title column any faster, so you may need a "duplicate" index on title, if you need to do searching on that.

0

精彩评论

暂无评论...
验证码 换一张
取 消