2016-10-26 24 views
1

私はMySQL DB上に3つのテーブルを作成してそれらを設定したいと思いますが、例外があります。ここでは、次のとおりです。私のMySQLテーブルを作成できません

重複エントリ「1」キー「unique_idx」

ためたぶん誰かが私が間違っduing午前私の何を伝えることができますか?

InitialDB:

DROP TABLE IF EXISTS user_roles; 
DROP TABLE IF EXISTS contacts; 
DROP TABLE IF EXISTS users; 

CREATE TABLE IF NOT EXISTS users 
(
    id   INTEGER AUTO_INCREMENT, 
    login  VARCHAR(45) NOT NULL, 
    password VARCHAR(45) NOT NULL, 
    full_name VARCHAR(100) NOT NULL, 
    PRIMARY KEY (id) 
); 
CREATE UNIQUE INDEX users_unique_login_idx ON users (login); 

CREATE TABLE IF NOT EXISTS user_roles 
(
    user_id INTEGER NOT NULL, 
    role VARCHAR(45), 
    CONSTRAINT user_roles_idx UNIQUE (user_id, role), 
    FOREIGN KEY (user_id) REFERENCES users (id) ON DELETE CASCADE 
); 

CREATE TABLE IF NOT EXISTS contacts (
    id   INTEGER AUTO_INCREMENT, 
    user_id  INTEGER NOT NULL, 
    first_name VARCHAR(45) NOT NULL, 
    last_name VARCHAR(45) NOT NULL, 
    patronymic VARCHAR(45) NOT NULL, 
    mobile_phone_number VARCHAR(15), 
    home_phone_number VARCHAR(15), 
    address VARCHAR(45), 
    email VARCHAR(30), 
    PRIMARY KEY (id), 
    FOREIGN KEY (user_id) REFERENCES users (id) ON DELETE CASCADE 
); 
CREATE UNIQUE INDEX unique_idx ON contacts (user_id); 

PopulatorDB:

DELETE FROM lardi.users; 
DELETE FROM lardi.user_roles; 
DELETE FROM lardi.contacts; 

INSERT INTO lardi.users 
    (login,password,full_name) VALUES 
    ('Bill', '112233', 'user'), 
    ('John', '112233', 'user'), 
    ('Mark', '112233', 'user'); 

INSERT INTO lardi.user_roles 
    (role,user_id) VALUES 
    ('USER_ROLE',1), 
    ('USER_ROLE',2), 
    ('ADMIN_ROLE',3); 

INSERT INTO lardi.contacts 
(first_name, last_name, patronymic, mobile_phone_number, home_phone_number, address, email, user_id) VALUES 
    ('Bill','Gates','','+380(66)1234567','','USA','[email protected]', 1), 
    ('Mark','Zukenberg','','+380(66)9876543','+380(44)1122334','USA','[email protected]', 1), 
    ('Barak','Obama','','+380(99)1234567','','USA','[email protected]', 1), 
    ('Michel','Obama','','+380(99)9876543','','USA','[email protected]', 1), 
    ('David','Camaron','','+380(50)5557799','+380(44)0000009','UK','[email protected]', 2), 
    ('Steve','Jobs','','+380(00)1100999','','USA','[email protected]', 2), 
    ('Tim','Kuk','','+380(00)2244888','','USA','[email protected]', 2), 
    ('Jim','Carry','','+380(69)8881188','+380(44)1111119','USA','[email protected]', 3), 
    ('David','Backham','','+380(67)90000001','','UK','[email protected]', 3); 

助けてくれてありがとう。

答えて

1

CREATE UNIQUE INDEX unique_idx ON contacts (user_id); 

contactsuser_idがユニークで独自のインデックスを削除します。次に、あなたのcontacts表はuser_idに一意のインデックスを持つuser_id

+0

はい、おかげで、それwarksをlardi.contacts。 –

+0

最初にこの回答を追加しました – Kushan

1
CREATE UNIQUE INDEX unique_idx ON contacts (user_id); 

に重複したデータを挿入することはできません。

同じユーザーIDの連絡先を挿入しようとしています。

+0

はい、ありがとうございます。それは実際に動作します。あなたは私のお尻を救った –

0

あなたがユニークである必要がありunique_idxを持っていますが、INSERT INTOで重複した値を保存するには、

関連する問題