Issue Information
-
#008346
-
0 - None Assigned
-
Confirmed
Issue Confirmations
-
Yes (0)No (0)
0
Char server is not sending character data when some data is too big
Posted by AnyThing on 17 September 2014 - 12:26 PM
I enable very high level (up to 1000), and some of player mysql data in table 'char' on the 'base_exp' column has more than 4 billion values (let's say, 6966857840). The mysql field somehow support it since it's bigint(20), but char server will print below message:
[17/Sep 20:12:05][SQL]: DB error - data of field 'base_exp' was truncated.
[17/Sep 20:12:05][Debug]: column - 6
[17/Sep 20:12:05][Debug]: data - type=UNSIGNED MYSQL_TYPE_LONGLONG, length=4
[17/Sep 20:12:05][Debug]: buffer - type=UNSIGNED MYSQL_TYPE_LONG, length=4
And in client-side, this character AND ANY character after this character will not visible anymore in char select.
For example, in char select we have:
1. Name1
2. Name2
3. Name3
If Name2 base_exp value is more than 4 billion, only Name1 will be visible. Name2 and Name3 is not visible anymore.
[17/Sep 20:12:05][SQL]: DB error - data of field 'base_exp' was truncated.
[17/Sep 20:12:05][Debug]: column - 6
[17/Sep 20:12:05][Debug]: data - type=UNSIGNED MYSQL_TYPE_LONGLONG, length=4
[17/Sep 20:12:05][Debug]: buffer - type=UNSIGNED MYSQL_TYPE_LONG, length=4
And in client-side, this character AND ANY character after this character will not visible anymore in char select.
For example, in char select we have:
1. Name1
2. Name2
3. Name3
If Name2 base_exp value is more than 4 billion, only Name1 will be visible. Name2 and Name3 is not visible anymore.
what is your revision?
This look like more than 32 bit value, and server using internally 32 bit variables.
Max value for exp and many other fields is 4294967296.
Max value for exp and many other fields is 4294967296.
changed status to: Confirmed
I confirm the sql file differs from the expected size in the char server sql loaders, as well as from the data size it is stored into ingame (base_exp/job_exp are all unsigned int). I'm however inclined to say it's actually working as intended and the .sql file is the one thats wrong, I'll check in with other devs
AnnieRuru made a very good point, that the game client does not expect to receive a u/int64 and thus display area of experience data would be broken (packet fields are sized for u/int32), the question then becomes whether to fix the BIGINT field or not, as values >= uint32 are not supported by the game client for this kind of data.