Mövzu üzrə bənzər suallara da baxa bilərsiniz.

Mysql AUTO_INCREMENT

Salam php də qarşıma belə bir problem çıxıb

$sssoo = mysql_fetch_array(@mysql_query("select MAX(id) as num from MYSQL_NAME ORDER BY `id`  DESC LIMIT 1 "));
$new = $sssoo[0] + 1;

@mysql_query("INSERT INTO `MYSQL_NAME` SET `diger` = '".$new."',ve s.

Əvvəlcə onu deyim ki bu kod nəçə ildir ki işləyir.Yeni ki sciripte sehv yoxdur.
Göründüyü kimi insert yaranarkən `id` linasının üstüne +1 gelir və `digər` adlı linaya göndərilir. `id` linası hər dəfəsində AUTO_INCREMENT ile özü artır. Nəticədə `id` linası ile `digər` linası eyni dəyəre sahib olur. Son vaxtlar bu kod eyni anda 50-60 user üçün açılır problemde bunda olur . San ki melumatların oxunması gecikir eyni reqem ile 2 insert yaranan vaxtlar olur. eslinde her insert yaranarkən rəqəm +1 artmaalıdır. AUTO_INCREMENT ile yaranan `id` linasında rəqəm artır lakin `diger` adlı linada köhne rəqem qalir. Cox proses tələb eden sciriptdir .Server zeif deyil..
Php-de bələ bir kod varmı ki select emri olmadan AUTO_INCREMENT ile yaranan id-i diger bir linadada yaransin.


Kateqoriya: Sual . , , . Qısa keçid.

Verilmiş cavablar və yazılan şərhlər (2 cavab var)

(16:37, 23/11/2014 ) #49571

Bu problem retki hallarda olur.Gün ərzinde təxmini 500 -1000 insert yaranırsa bunun 2-3 denesi bele olur ve mecburen mysql-dan editleyib deyisirem .

Cavablamaq üçün sağ sütundan hesaba daxil olmaq lazımdır

(11:58, 24/11/2014 ) #49625

İki query bir birindən müstəqil ayrı query olduğundan paralel user çox olanda araya başqa query-lər girir zaman anlamında. Ona görə də belə problemlər yaranması təbiidir. Daha effektiv, bir sətirlik həll əminəm ki düşünmək olar, amma gəlin indi tez düşünməklə ağlıma gələn yolu deyim.
1. Bazadan heç bir id zad götürmədən birbaşa insert edirsiz. Bu zaman diger xanasına unikal bir qiymət mənimsədirsiz. Məsələn query-dən yuxarıda bir php dəyişəninə rand() funksiyası ilə filan unikal bir qiymət mənimsədirsiz, insert zamanı da məhz o qiyməti ötürürsüz diger xanasına. ( diger=’$unikal_qiymet’
2. İnsert-dən sonra update ilə məsələni qapayırsız. update table set diger=id where diger=’unikal_qiymet’;
Bu halda bütün userlərin mysql-ə datasının daxil olması prosesləri asinxronlaşır və konflikt aradan qalxır

Cavablamaq üçün sağ sütundan hesaba daxil olmaq lazımdır

Bu suala aid öz sualım var:
Sual verin
Bu suala cavab vermək istəyirəm:
Cavab verin

Cavab verin


Cavab yazmaq üçün lütfən sağ sütundan və ya buradan hesaba daxil olun.

Üzvlər üçün giriş

Qeydiyyat

Elan qutusu

Son cavablar və şərhlər

Mirsəid Mirzəzadə cavab verdi - Aliexpressdən Samsung S3 ucun batareya(akkumlyator) (12 saat əvvəl)

Rustem444 cavab verdi - Piyada Cərimələri (14 saat əvvəl)

selef cavab verdi - Piyada Cərimələri (19 saat əvvəl)

Rustem444 cavab verdi - Piyada Cərimələri (22 saat əvvəl)

E. Hacı cavab verdi - Piyada Cərimələri (1 gün əvvəl)

Orxan cavab verdi - Aliexpressdən 2 dən artıq Müxtəlif elektronika (1 gün əvvəl)

Orxan cavab verdi - Bakı baxa Tibb Kolleci neçe il oxunur (1 gün əvvəl)

Orxan cavab verdi - Youtubda (Geçersiz tıklama nedeniyle devre dışı bırakıldı) Bele yazılıb (1 gün əvvəl)

Emil- cavab verdi - AutoCad install etmək olmur (1 gün əvvəl)

E. Hacı cavab verdi - AutoCad install etmək olmur (2 gün əvvəl)

newprogrammer cavab verdi - Düzgün sıralanmama (2 gün əvvəl)

Maqa cavab verdi - Aliexpress'dən mal gətirəndə gömrükdə problem yaranırmı? (2 gün əvvəl)

E. Hacı cavab verdi - Opencart şablonunda ödəmə qəbul etmək (2 gün əvvəl)

E. Hacı cavab verdi - Düzgün sıralanmama (3 gün əvvəl)

E. Hacı cavab verdi - Aliexpressdən Samsung S3 ucun batareya(akkumlyator) (3 gün əvvəl)

E. Hacı - 579 xal

Software Developer - 578 xal

Onar Alili - 526 xal

Dilsuz - 448 xal

Cabbarov Sübhan - 414 xal

Ruslan Butdayev - 328 xal

Namiq Bəndəli - 297 xal

U.Tarlan - 244 xal

Meherremoff - 234 xal

Bextiyar Azeroglu - 218 xal

Sistemə daxil olmuş 19896 sualdan 94%-dən çoxu cavablandırılmışdır.

Proyekt haqqında

E-Haci.net istehsalı. © 2010-2018