powered by simpleCommunicator - 2.0.61     © 2026 Programmizd 02
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Форумы / PHP, Perl, Python [игнор отключен] [закрыт для гостей] / Функция
14 сообщений из 14, страница 1 из 1
Функция
    #32749292
Spooki
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Привет всем!

Хотел узнать, какую из этих функций лучше использовать

эту mysql_connect()
или эту mysql_pconnect()

и почему?
...
Рейтинг: 0 / 0
Функция
    #32749410
*
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
*
Гость
Прежде, чем задавать вопрос, неплохо бы заглядывать в мануал. Хотя бы ради приличия.
mysql_connect
mysql_pconnect
Постоянные соединения с базами данных
...
Рейтинг: 0 / 0
Функция
    #32750352
Spooki
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Да ты чё, ух ты!

А то я не в курсе, вопрос был, какая лучше? А их различия я знаю.
...
Рейтинг: 0 / 0
Функция
    #32750436
*
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
*
Гость
Да я уже понял, что ты не в курсе, а кроме того, либо не любишь читать, либо не умеешь думать, предпочитая жить на всём готовеньком. Постоянные соединения с базами данных
...
Рейтинг: 0 / 0
Функция
    #32750637
Spooki
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Вообщем-то суть не ясна.

Типа лучше не юзать mysql_pconnect, а то много чего не будет, да и вообще все нафиг заблокируется и отвалится к чертям в месте с сервером и компом.
...
Рейтинг: 0 / 0
Функция
    #32751061
*
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
*
Гость
По моему всё предельно ясно - во-первых, всё зависит от задач и от того, как установлен PHP - если как CGI - никакой разницы между connect и pconnect нет, если как модуль Apache или xSAPI - pconnect "удерживает" соединение и не "пересоединяется" при каждом запросе (минусы такого подхода описаны там же, в мане - "если скрипт блокирует таблицу и по каким-либо причинам не может ее освободить, при использовании постоянного соединения все последующие скрипты, которые используют это соединение будут блокированы бесконечно долго" и "открытые транзакции, если они не были закрыты до завершения работы скрипта, будут продолжены в следующем скрипте, использующем это же постоянное соединение", плюс - "если затраты на установку соединения велики, постоянные соединения могут вам существенно помочь" за счёт снижения затрат на установку соединения с базой + физически, насколько я понимаю, мы имеем лишь одно соединение с БД - поэтому если есть ограничение на количество одновременно открытых соединений - это позволяет "нарваться" на лимит гораздо позже - могу ошибаться, может я неправильно трактую ман). В общем, "Фактически, постоянные соединения не предоставляют никакой функциональности, которая была бы невозможна в непостоянных аналогичных соединениях" и решать вопрос эффективности того или иного способа надо в зависимости от стоящих задач, "индивидуально" ;)
...
Рейтинг: 0 / 0
Функция
    #32751214
Spooki
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Итог:

Эта функция нах не нужна.
Ибо!
Если будите её юзать, то кранты вашему приложению рано или поздно все равно придет)
...
Рейтинг: 0 / 0
Функция
    #32751253
taj
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
* все правильно тебе расписал, и ссылки дал хорошие, но выводы не совсем верные ;)
Если бы одна функция была бы однозначно лучше другой, то другой бы просто не было (если речь не идет о backward compatibility какой-нить).
...
Рейтинг: 0 / 0
Функция
    #32751263
*
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
*
Гость
taj , а как же 'решать вопрос эффективности того или иного способа надо в зависимости от стоящих задач, "индивидуально" ;)' ;)
...
Рейтинг: 0 / 0
Функция
    #32751504
*
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
*
Гость
Кстати, до кучи, возможно будет интересно почитать топик на xpoint е.
...
Рейтинг: 0 / 0
Функция
    #32751611
Фотография Alex Rootoff
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
taj, а как же превосходство sizeof() над count()?
Spooki, юзал я функцию не раз и кранты моим скриптам не наставали, наоборот я економил время в тех случаях, где процедура конекта к базе данных занимала немало времени. Но в большынстве слечаев связка Mysql+php+apache работает чень быстро и устойчивое соединение не требуется.


With best regards Alex Rootoff
...
Рейтинг: 0 / 0
Функция
    #32753210
taj
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
* taj , а как же 'решать вопрос эффективности того или иного способа надо в зависимости от стоящих задач, "индивидуально" ;)' ;)Гм? Недопонял :) Я имел в виду что выводы автора топика насчет ненужности - не совсем верные. А с тобой по поводу индивидуальности я согласен - например, лавировать при ограниченном кол-ве соединений с сервером, когда они, соединения, осуществляются с одной тачки с одинаковыми credentials.

Alex Rootofftaj, а как же превосходство sizeof() над count()? PHP Manualsizeof
sizeof -- Alias of count()
Description
This function is an alias of count().
...
Рейтинг: 0 / 0
Функция
    #32753834
*
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
*
Гость
Alex Rootofftaj, а как же превосходство sizeof() над count()? taj Речь, видимо, о несколько древней статье Оптимизация программ на PHP . Если кому интересно - может доказать или опровергнуть данное в этой статье утверждение, например, при помощи Профайлера для скриптов на PHP
...
Рейтинг: 0 / 0
Функция
    #32757287
taj
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Статья интересная, уважаю людей, которые не ленятся копаться, доискиваться до чего-то нетривиального.
Профайлер качать не стал, написал такой код, заимствовав тип нагрузки из статьи.
Код: plaintext
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
27.
28.
29.
30.
31.
32.
33.
34.
35.
36.
37.
38.
39.
40.
41.
42.
43.
44.
45.
46.
47.
<?
set_time_limit( 60 );

$test = ""; // нагрузочный массив
$a_size =  100000 ; // размер нагрузочного массива
$a_value = "!"; // значение в каждой ячейке массива
$iterations =  5 ; // кол-во итераций цикла (для увеличения выборки => точности)
$c_time =  0 ; // время, затраченное при использовании count() 
$s_time =  0 ; // время, затраченное при использовании size_of()                                                 

function gettime() // время с микросекундами
{ 
	list($msec, $sec) = split(" ", microtime()); 
	return ((float)$msec + (float)$sec); 
} 

for ($i= 0 ; $i<$a_size; $i++) // заполняем нагрузочный массив
	$test[] = $a_value;

for ($i= 0 ; $i<$iterations; $i++)
{
	$a_count[$i]["begin"] = gettime(); // заносим в массив время начала цикла
	$x= 0 ; 
	for ($it= 0 ; $it<count($test); $it++)  
		$x=sprintf("test%08i",$test[$it]);
	$a_count[$i]["end"] = gettime(); // заносим в массив время окончания цикла
}


for ($i= 0 ; $i<$iterations; $i++)
{
	$a_sizeof[$i]["begin"] = gettime();
	$x= 0 ; 
	for ($it= 0 ; $it<sizeof($test); $it++) 
		$x=sprintf("test%08i",$test[$it]);
	$a_sizeof[$i]["end"] = gettime();
}

for ($i= 0 ; $i<$iterations; $i++)
{                                                         
	$c_time += ($a_count[$i]["end"] - $a_count[$i]["begin"]);
	$s_time += $a_sizeof[$i]["end"] - $a_sizeof[$i]["begin"];
}
$c_time = $c_time / $iterations; // усредненные значения по итерациям
$s_time = $s_time / $iterations;

echo "count = ".($c_time)."\nsizeof = ".($s_time);
?>
Запускал для чистоты эксперимента из командной строки.
Результаты после нескольких запусков примерно такие:
Код: plaintext
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
count =  0 . 48946084976196 
sizeof =  0 . 48834891319275 

count =  0 . 48651175498962 
sizeof =  0 . 48780460357666 

count =  0 . 49119200706482 
sizeof =  0 . 49274916648865 

count =  0 . 49285798072815 
sizeof =  0 . 49556179046631 
В среднем получается что разброс не более 3-4мс (менее 1%) в ту и другую сторону.
Имхо мануал был прав (WinXP, PHP4.3.9).
...
Рейтинг: 0 / 0
14 сообщений из 14, страница 1 из 1
Форумы / PHP, Perl, Python [игнор отключен] [закрыт для гостей] / Функция
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]