CREATE TABLE admins
(
id integer NOT NULL AUTO_INCREMENT,
id_parent integer,
login VARCHAR(20) NOT NULL,
password VARCHAR(32) NOT NULL,
email VARCHAR(50) NOT NULL,
avatar BLOB,
CONSTRAINT pk_admins PRIMARY KEY (id),
CONSTRAINT u_login UNIQUE (login),
CONSTRAINT u_email UNIQUE (email)
)
ENGINE=InnoDB DEFAULT CHARSET=cp1251;
собственно в этой таблице не должно быть двух и более записей имеющих id_parent = NULL, тоесть должна быть только одна запись имеющая id_parent равным NULL, но id_parent не NULL может иметь одинаковое значение для нескольких записей.
По сути есть ТОЛЬКО один суперадмин (id_parent = NULL), создающий всех остальных, а те могут создавать следующих.
Еще нужен CONSTRAINT, чтобы при удалении простого админа производные принимали его бывший id_parent.
Удаление суперадмина ведет к удалению всех админов.