[英]mysql_query doesn't work and gives error
while($x < 10)
{
$str = "( NULL, '{$players[$x]}', '1' , 0 + {$sonucs[$x]},oynananoyun - win,'{$rols[$x]}','{$teams[$x]}','{$playerkills[$x]}','{$playerdeaths[$x]}','{$playerassists[$x]}','{$creeps[$x]}','{$dmgs[$x]}','{$dpms[$x]}','{$wards[$x]}','{$playergolds[$x]}','{$gpms[$x]}', '{$goldpercantages[$x]}', 0 + {$fbs[$x]},'{$dmgpercantages[$x]}', '{$wardscleared[$x]}', '{$wpm[$x]}', '{$wcpm[$x]}','{$wardpercents[$x]}', '{$wardsclearedpercents[$x]}', '{$cspms[$x]}')";
$yaya = "kill = kill + {$playerkills[$x]}, death = death + {$playerdeaths[$x]},assist = assist + {$playerassists[$x]},cs = cs + {$creeps[$x]}, cspm = cspm + {$cspms[$x]}, takim = {$teams[$x]}, dmg = dmg + {$dmgs[$x]}, dpm = dpm + {$dpms[$x]},wardplaced = wardplaced + {$wards[$x]}, oynananoyun = oynananoyun + 1, win = win + {$sonucs[$x]}, rol = {$rols[$x]}, gold = gold + {$playergolds[$x]}, goldshare = goldshare + {$goldpercantages[$x]}, gpm = gpm + {$gpms[$x]}, fb = fb + {$fbs[$x]}, dmgshare = dmgshare + {$dmgpercantages[$x]}, wardcleared = wardcleared + {$wardscleared[$x]}, wardplacedpm = wardplacedpm + {$wpm[$x]}, wardclearedpm = wardclearedpm + {$wcpm[$x]}, wardplacedshare = wardplacedshare + {$wardpercents[$x]}, wardclearedshare = wardclearedshare + {$wardsclearedpercents[$x]}";
mysql_query ("INSERT INTO playerstats18 (`id`,`player`,`oynananoyun`,`win`,`lose`,`rol`,`takim`,`kill`,`death`,`assist`,`cs`,`dmg`,`dpm`,`wardplaced`,`gold`,`goldshare`,`gpm`,`fb`,`dmgshare`,`wardcleared`,`wardplacedpm`,`wardclearedpm`,`wardplacedshare`,`wardclearedshare`,`cspm`) VALUES $str ON DUPLICATE KEY UPDATE $yaya");
$x++;
}
mysql_query was working but then i added more values at $yaya and its not working now. mysql_query在工作,但是后来我在$ yaya中添加了更多值,并且现在不工作。 Im not missing any commas, I checked it. 我没有错过任何逗号,我检查了一下。 Its not updating or inserting. 它没有更新或插入。
" You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'kill = kill + 0, death = death + 1,assist = assist + 14,cs = cs + 28, cspm = csp' at line 1 " “您的SQL语法有错误;请查看与您的MySQL服务器版本相对应的手册,以正确使用语法'kill = kill + 0,death = death + 1,assist = Assist + 14,cs = cs + 28,cspm =第1行的csp'”
'kill = kill + 0, death = death + 1,assist = assist + 14,cs = cs + 28, cspm = csp' at line 1 第1行的'kill = kill + 0,death = death + 1,assist =助攻+ 14,cs = cs + 28,cspm = csp'
What $yaya loooks like $ yaya看起来像什么
kill = kill + 0, death = death + 1,assist = assist + 14,
cs = cs + 28, cspm = cspm + 1, takim = DP,
dmg = dmg + 3.0, dpm = dpm + 110,wardplaced = wardplaced + 43,
oynananoyun = oynananoyun + 1, win = win + 1 , rol = Support,
gold = gold + 7.7b, goldshare = goldshare + 14.1,
gpm = gpm + 283, fb = fb + 0,
dmgshare = dmgshare + 6.4, wardcleared = wardcleared + 9,
wardplacedpm = wardplacedpm + 1.58,
wardclearedpm = wardclearedpm + 0.33,
wardplacedshare = wardplacedshare + 29.6,
wardclearedshare = wardclearedshare + 31
edit: i changed yaya string to 编辑:我将yaya字符串更改为
$yaya = "`kill` = `kill` + {$playerkills[$x]},
death = death + {$playerdeaths[$x]},
assist = assist + {$playerassists[$x]},
cs = cs + {$creeps[$x]},
cspm = cspm + {$cspms[$x]},
takim = '{$teams[$x]}',
dmg = dmg + {$dmgs[$x]},
dpm = dpm + {$dpms[$x]},
wardplaced = wardplaced + {$wards[$x]},
oynananoyun = oynananoyun + 1,
win = win + {$sonucs[$x]},
rol = '{$rols[$x]}',
gold = gold + '{$playergolds[$x]}',
goldshare = goldshare + {$goldpercantages[$x]},
gpm = gpm + {$gpms[$x]}, fb = fb + {$fbs[$x]},
dmgshare = dmgshare + {$dmgpercantages[$x]},
wardcleared = wardcleared + {$wardscleared[$x]},
wardplacedpm = wardplacedpm + {$wpm[$x]},
wardclearedpm = wardclearedpm + {$wcpm[$x]},
wardplacedshare = wardplacedshare + {$wardpercents[$x]},
wardclearedshare = wardclearedshare + {$wardsclearedpercents[$x]}";
I changed kill to kill
, {$playergolds[$x]} to '{$playergolds[$x]}' because it has "b" (6.6b forexample and quoted varchars (not sure if it was necessary). 我将kill改为kill
,将{$ playergolds [$ x]}更改为'{$ playergolds [$ x]}”,因为它具有“ b”(例如6.6b并引用了varchars(不确定是否有必要))。
Since rol
is a VARCHAR
, you need quotes around the value. 由于rol
是VARCHAR
,因此您需要在该值rol
加上引号。
rol = {$rols[$x]}
should be: 应该:
rol = '{$rols[$x]}'
You can see this in the value of $yaya
: 您可以在$yaya
的值中看到:
rol = Support
it should be 它应该是
rol = 'Support'
You wouldn't have problems like this if you used prepared queries with PDO or mysqli. 如果您将预查询与PDO或mysqli一起使用,则不会有这样的问题。
The other problem is that kill
is a reserved word. 另一个问题是, kill
是保留字。 To use it as a column name, you need to escape it with backticks: 要将其用作列名,您需要使用反引号对其进行转义:
`kill` = `kill` + {$playerkills[$x]}
Also, when using ON DUPLICATE KEY UPDATE
, you don't need to repeat all the values from the VALUES
list. 同样,当使用ON DUPLICATE KEY UPDATE
,您不需要重复VALUES
列表中的所有值。 You can write 你可以写
rol = VALUES(rol)
which means that the update should use the same value that would have been inserted if there wasn't a duplicate key. 这意味着更新应该使用与没有重复键时插入的值相同的值。 So you could write: 所以你可以这样写:
$yaya = "`kill` = `kill` + VALUES(`kill`), death = death + VALUES(death), assist = assist + VALUES(assist),
cs = cs + VALUES(cs), cspm = cspm + VALUES(cspm), takim = VALUES(takim), dmg = dmg + VALUES(dmg),
dpm = dpm + VALUES(dpm), wardplaced = wardplaced + VALUES(wardplaced),
oynananoyun = oynananoyun + 1, win = win + VALUES(win), rol = VALUES(rol),
gold = gold + VALUES(gold), goldshare = goldshare + VALUES(goldshare), gpm = gpm + VALUES(gpm),
fb = fb + VALUES(fb), dmgshare = dmgshare + VALUES(dmgshare), wardcleared = wardcleared + VALUES(wardcleard),
wardplacedpm = wardplacedpm + VALUES(wardplacedpm), wardclearedpm = wardclearedpm + VALUES(wardclearedpm),
wardplacedshare = wardplacedshare + VALUES(wardplacedshare), wardclearedshare = wardclearedshare + VALUES(wardclearedshare)";
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.