blob: a709eb7446c5d015f7327f03c95cfbcfb5ae39d2 [file] [log] [blame]
-- Licensed to the Apache Software Foundation (ASF) under one or more
-- contributor license agreements. See the NOTICE file distributed with
-- this work for additional information regarding copyright ownership.
-- The ASF licenses this file to You under the Apache License, Version 2.0
-- (the "License"); you may not use this file except in compliance with
-- the License. You may obtain a copy of the License at
--
-- http://www.apache.org/licenses/LICENSE-2.0
--
-- Unless required by applicable law or agreed to in writing, software
-- distributed under the License is distributed on an "AS IS" BASIS,
-- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-- See the License for the specific language governing permissions and
-- limitations under the License.
drop procedure if exists create_unique_constraint_on_name_service_zone;
delimiter ;;
create procedure create_unique_constraint_on_name_service_zone() begin
/* check tables exist or not */
if exists (select * from information_schema.columns where table_schema=database() and table_name = 'x_policy' and column_name in('service','name','zone_id')) then
/* check unique constraint exist on service and name column or not */
if exists (select * from information_schema.table_constraints where table_schema=database() and table_name = 'x_policy' and constraint_name='x_policy_UK_name_service') then
ALTER TABLE x_policy DROP INDEX x_policy_UK_name_service;
end if;
if not exists (select * from information_schema.table_constraints where table_schema=database() and table_name = 'x_policy' and constraint_name='x_policy_UK_name_service_zone') then
ALTER TABLE x_policy ADD UNIQUE INDEX x_policy_UK_name_service_zone(name(180),service,zone_id);
end if;
end if;
end;;
delimiter ;
call create_unique_constraint_on_name_service_zone();
drop procedure if exists create_unique_constraint_on_name_service_zone;