Zaloguj się by uzyskać pełen dostęp. Nie masz jeszcze konta? Założ je już teraz w kilka sekund.

Wysłany: 2014-05-31, 21:20


Drak







Wiek: 34
Na forum: 4903 dni
Posty: 71
Nick w MP: Drak

Piwa: 3

Respekt: 50

Witam! Mam ma?y problem z pewn? funkcj?.

Dana funkcja:


function givePlayerCash(nameamount)
    local ac getAccount(name) or getPlayerAccount(name)
    if name then
        name getAccountName(ac)
        local plr getPlayersAccounts(ac)
        if plr then
            local ac getElementData(plr"cash")
            if ac then
                setElementData(plr"cash"ac+amount)
            end
            executeSQLQuery("UPDATE PRS_Accounts SET cash='cash+"..amount.."' WHERE acc=?"name)
        else
            executeSQLQuery("UPDATE PRS_Accounts SET cash='cash+"..amount.."' WHERE acc=?"name)
        end
    end
end


Funkcja ta ma ustawia? kase gracza. Dok?adniej ma zwi?ksza? jej warto?? w bazie o 'amount', lecz zamiast ustawia? liczb ustawia np 'cash+5'. Przez to nie dzia?a poprawnie inny skrypt itd. Co mam ?le w tej funkcji? Co mam zmieni? aby otrzymywa? same liczby?

Postaw piwo autorowi tego posta
 

 
Wysłany: 2014-05-31, 21:22


MeeShuffle

Programista/Grafik






Wiek: 32
Na forum: 4394 dni
Posty: 2758
Nick w MP: Shuffle

Piwa: 8575

Respekt: 535,3
Respekt: 535,3

Poczekaj, dobrze zrozumia?em ? Kod czyta ci dan? warto?? jako znak/cyfre ?

Podpis

https://shufflecode.pl
Static Codes and Graphics - Join our discord!
Postaw piwo autorowi tego posta
 

 
Wysłany: 2014-05-31, 21:25


Drak







Wiek: 34
Na forum: 4903 dni
Posty: 71
Nick w MP: Drak

Piwa: 3

Respekt: 50

Linijka:
 executeSQLQuery("UPDATE PRS_Accounts SET cash='cash+"..amount.."' WHERE acc=?"name)

ustawia w bazie np 'cash+6' zamiast samego '6'.

Postaw piwo autorowi tego posta
 

 
Wysłany: 2014-05-31, 21:27


MeeShuffle

Programista/Grafik






Wiek: 32
Na forum: 4394 dni
Posty: 2758
Nick w MP: Shuffle

Piwa: 8575

Respekt: 535,3
Respekt: 535,3

Zr?b to na zmiennej :)



kasa cash+tonumber(ammount)
 executeSQLQuery("UPDATE PRS_Accounts SET cash=kasa WHERE acc=?"name)


Nie wiem czy dobrze sformu?owa?em linijk? execute, nie jestem dobry w mysql :)

[ Dodano: 2014-05-31, 21:30 ]
Pami?taj, ?e najpierw musisz pobra? t? tabelk?.

Podpis

https://shufflecode.pl
Static Codes and Graphics - Join our discord!
Postaw piwo autorowi tego posta
 

 
Wysłany: 2014-06-01, 09:33


Drak







Wiek: 34
Na forum: 4903 dni
Posty: 71
Nick w MP: Drak

Piwa: 3

Respekt: 50

PanMaszyna, czytaj?c twoje rady przypomnia?em sobie jak zrobi?em kiedy? t? funkcj?. Wystarczy?o zmieni?:
cash='cash+"..amount.."'

na
cash='"..ac+amount.."'


Dzi?kuje za pomoc.

Postaw piwo autorowi tego posta
 

 
Tagi: executesqlquery :: update
Anonymous





Na forum: 245 dni
Posty: 1



Anonymous Koniecznie zajrzyj na:






Skocz do:  
Wyświetl posty z ostatnich:   
GTAONLINE.PL » JĘZYKI PROGRAMOWANIA » LUA Ten temat jest zablokowany bez możliwości zmiany postów lub pisania odpowiedzi

Nie możesz pisać nowych tematów
Nie możesz odpowiadać w tematach
Nie możesz zmieniać swoich postów
Nie możesz usuwać swoich postów
Nie możesz głosować w ankietach
Dodaj temat do Ulubionych
Wersja do druku