Историята
Това беше първият ми отговор на Stackoverflow. Оттогава много се промениха, особено оттеглянето и премахването на mysql API. Дори ако все още сте на php 5.6, mysql_* api не трябва да се използва. Сега PDO или mysqli са единствените опции за избор. ЗНП е по-добре по много причини.
Кеширани ли са подготвените оператори при зареждане на страници?
Същият подготвен оператор няма да се използва между зарежданията на страницата. Всеки път трябва да се приготвя. Ако притискането на всяка голяма милисекунда има значение, съхранената процедура може да е добра идея (ако приемем, че имате сложна заявка).
За големи вмъквания (хиляди редове) Вероятно може да се постигне по-голям тласък чрез изхвърляне на вашите данни в текстов файл и зареждането му с LOAD DATA IN FILE . Това е много по-бързо от поредица от вмъквания.
Оригиналния отговор
Истината е, че понякога mysqli е по-бърз, а друг път mysql api е по-бърз. Но разликата е наистина малка. Ако погледнете някой от тестовете за производителност в мрежата, разликата наистина е само 10 - 20 милисекунди. Най-добрият начин за повишаване на производителността е да оптимизирате дизайна на таблицата.
Много от тестовете, които „доказват“, че по-старият API е по-бърз, забравят, че за максимална сигурност трябва да се извика mysql_real_escape_string() за всяка променлива, използвана в заявката.
Заявките се кешират от сървъра, ако и само ако данните за всички таблици, използвани в заявката, са останали непроменени.
Изчакайте друга актуализация с действителни числа