26.02.2014, 00:19
Use Auto-increment for the ID column and set ID as primary key as well.
Also set the default value to 0 for all columns that should have 0 when registering (or -1, like you have on 2 values).
You can setup such tables easily and you won't need such long register queries.
Then you only need to insert hIme,PlayerInfo[playerid][Lozinka],PlayerInfo[playerid][IP],PlayerInfo[playerid][Novac].
That's only 4 values. MySQL does the rest. It will automatically store a default value (which you set in the table-design) when inserting a new line without specifying any value for that column.
You see in this example (it's code from my script to auto-create tables if they don't exist) that:
- ID is AUTO_INCREMENT and PRIMARY KEY
- all values from "AdminLevel" until "JailTime" have a default value of 0.
The only thing I need to register a new account is the player's name and password.
The ID is automatically set by MySQL to a unique value each time a player registers an account.
Name and password need to be inserted (as they cannot be NULL, by the "NOT NULL" declaration).
All the rest doesn't need to be specified because of the default values.
If they're not given, MySQL will copy the default value and set that value in the newly created account, for each column that has a default value specified.
My register query:
Much shorter, just because of all the default values.
Also set the default value to 0 for all columns that should have 0 when registering (or -1, like you have on 2 values).
You can setup such tables easily and you won't need such long register queries.
Then you only need to insert hIme,PlayerInfo[playerid][Lozinka],PlayerInfo[playerid][IP],PlayerInfo[playerid][Novac].
That's only 4 values. MySQL does the rest. It will automatically store a default value (which you set in the table-design) when inserting a new line without specifying any value for that column.
pawn Код:
format(Query, sizeof(Query), "CREATE TABLE `playerdata` (");
format(Query, sizeof(Query), "%s`ID` int(11) NOT NULL AUTO_INCREMENT, ", Query);
format(Query, sizeof(Query), "%s`PlayerName` varchar(25) NOT NULL, ", Query);
format(Query, sizeof(Query), "%s`Password` varchar(130) NOT NULL, ", Query);
format(Query, sizeof(Query), "%s`AdminLevel` int(11) NOT NULL DEFAULT '0', ", Query);
format(Query, sizeof(Query), "%s`Money` int(11) NOT NULL DEFAULT '0', ", Query);
format(Query, sizeof(Query), "%s`Score` int(11) NOT NULL DEFAULT '0', ", Query);
format(Query, sizeof(Query), "%s`Fines` int(11) NOT NULL DEFAULT '0', ", Query);
format(Query, sizeof(Query), "%s`Tickets` int(11) NOT NULL DEFAULT '0', ", Query);
format(Query, sizeof(Query), "%s`TicketCost` int(11) NOT NULL DEFAULT '0', ", Query);
format(Query, sizeof(Query), "%s`SpeedInMph` int(11) NOT NULL DEFAULT '0', ", Query);
format(Query, sizeof(Query), "%s`JailTime` int(11) NOT NULL DEFAULT '0', ", Query);
format(Query, sizeof(Query), "%sPRIMARY KEY (`ID`)) ", Query);
format(Query, sizeof(Query), "%sENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8", Query);
mysql_query(SQL_db, Query, false);
- ID is AUTO_INCREMENT and PRIMARY KEY
- all values from "AdminLevel" until "JailTime" have a default value of 0.
The only thing I need to register a new account is the player's name and password.
The ID is automatically set by MySQL to a unique value each time a player registers an account.
Name and password need to be inserted (as they cannot be NULL, by the "NOT NULL" declaration).
All the rest doesn't need to be specified because of the default values.
If they're not given, MySQL will copy the default value and set that value in the newly created account, for each column that has a default value specified.
My register query:
pawn Код:
// This function creates a new account for the given player
Player_AccountCreate(playerid)
{
// Setup local variables
new Query[256];
// Add the player's account to the MySQL database (escape the name only, as there is no need to escape a hashed password)
mysql_format(SQL_db, Query, sizeof(Query), "INSERT INTO playerdata (PlayerName, Password) VALUES ('%e', '%s')", APlayerData[playerid][PlayerName], APlayerData[playerid][PlayerPassword]);
mysql_tquery(SQL_db, Query, "Player_OnAccountCreate", "i", playerid);
}
// This custom callback is used after creating a new account (playername and password are inserted, but the ID must be loaded now to reference the player later on using this ID)
forward Player_OnAccountCreate(playerid);
public Player_OnAccountCreate(playerid)
{
// Get the ID from the auto-incremented table ("ID") and store it
APlayerData[playerid][SQLID] = cache_insert_id();
return 1;
}