Прежде всего, сохраните свой лист Excel как CSV.
Далее.Создайте таблицу чёрных дыр для чтения данных в:
DROP TABLE IF EXISTS `test`.`import_excel`;
CREATE TABLE `test`.`import_excel` (
`A` int(10) unsigned NOT NULL,
`B` varchar(45) NOT NULL,
`C` varchar(45) NOT NULL,
`D` varchar(45) NOT NULL,
`E` varchar(45) NOT NULL,
.....
`BB` varchar(45) NOT NULL
) ENGINE=BLACKHOLE DEFAULT CHARSET=latin1;
Создайте простую таблицу счетчиков с одной строкой.
DROP TABLE IF EXISTS `test`.`counter`;
CREATE TABLE `test`.`counter` (
id int(10) unsigned NOT NULL PRIMARY KEY,
`count` int(10) unsigned NOT NULL,
`max_count` int(10) unsigned NOT NULL
) ENGINE=MEMORY DEFAULT CHARSET=latin1;
REPLACE INTO counter VALUES (1,0,(203-5));
Создайте триггер на таблице чёрных дыр
DELIMITER $$
CREATE TRIGGER ai_import_excel_each AFTER INSERT ON import_excel FOR EACH ROW
BEGIN
DECLARE rows_left integer;
SELECT max_count - (`count` + 1) INTO rows_left FROM counter WHERE id = 1;
IF rows_left > 0 THEN BEGIN
//count the row_number you're in.
UPDATE counter SET `count` = `count` + 1 WHERE id = 1;
//Interpret the data and insert it into the proper tables.
//This is just an example
INSERT INTO real_table (a,b,c) VALUES (new.a, new.b, new.c);
INSERT INTO real_table2 (a,b,c) VALUES (NULLIF(new.d,''), new.e, new.c);
//You can change the data in anyway you like.
END; END IF;
END $$
DELIMITER ;
Наконец, импортируйте строки с 5 по 203. В таблицу import_excel
.
LOAD DATA INFILE 'c:/excel.csv' INTO TABLE import_excel
FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '"'
LINES TERMINATED BY '\r\n'
IGNORE 4 LINES;
Первые 4 строки будут игнорироваться LOAD DATA INFILE
, последние строки будут удалены триггером.