Advertisement
Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- /*
- YourSQL Library by Gamer931215
- MYSQL Simplified in pawn
- V2.3 Release ©2011
- native yoursql_connect(host[],user[],table[],password[])
- native yoursql_insert(table[],type[],{Float,_}...)
- native yoursql_receive(strquery[])
- native yoursql_update(table[],updater[],identifier[])
- native yoursql_delete(table[],identifier[])
- native yoursql_countrows(strquery)
- native yoursql_escape_string(str[]);
- native yoursql_close();
- */
- #include <a_samp>
- #include <a_mysql>
- new connection = -1;
- #if defined FILTERSCRIPT
- public OnFilterScriptExit()
- {
- mysql_close(connection);
- return CallLocalFunction("yoursql_OnFilterScriptExit","");
- }
- #if defined _ALS_OnFilterScriptExit
- #undef OnFilterScriptExit
- #else
- #define _ALS_OnFilterScriptExit
- #endif
- #define OnFilterScriptExit yoursql_OnFilterScriptExit
- forward yoursql_OnFilterScriptExit();
- #else
- public OnGameModeExit()
- {
- mysql_close(connection);
- return CallLocalFunction("yoursql_OnGameModeExit","");
- }
- #if defined _ALS_OnGameModeExit
- #undef OnGameModeExit
- #else
- #define _ALS_OnGameModeExit
- #endif
- #define OnGameModeExit yoursql_OnGameModeExit
- forward yoursql_OnGameModeExit();
- #endif
- stock yoursql_connect(host[],user[],table[],password[])
- {
- printf("yoursql => Connecting to %s...",host);
- connection = mysql_connect(host,user,table,password);
- if(mysql_ping(connection) == 1)
- {
- printf("yoursql => Connection to %s succesfully established! (Connection ID %i).",host,connection);
- } else {
- printf("yoursql => Connection to %s failed!",host);
- }
- return 0;
- }
- stock yoursql_close()
- {
- mysql_close(connection);
- }
- stock yoursql_insert(table[],type[],{Float,_}:...)
- {
- new query[256],values[128];
- for(new i = 0;i<numargs();i++)
- {
- switch(type[i])
- {
- case 's':
- {
- new result[32];
- for(new a= 0;getarg(i +2,a) != 0;a++)
- {
- result[a] = getarg(i +2,a);
- }
- if(!strlen(values))
- {
- format(values,sizeof values,"'%s'",result);
- } else format(values,sizeof values,"%s, '%s'",values,result);
- }
- case 'i':
- {
- new result = getarg(i +2);
- if(!strlen(values))
- {
- format(values,sizeof values,"%i",result);
- } else format(values,sizeof values,"%s, %i",values,result);
- }
- case 'f':
- {
- new Float:result = Float:getarg(i +2);
- if(!strlen(values))
- {
- format(values,sizeof values,"%f",result);
- } else format(values,sizeof values,"%s, %f",values,result);
- }
- }
- }
- format(query,sizeof query,"INSERT INTO %s (%s) VALUES (%s)",table,GetStructure(table),values);
- return mysql_query(query,-1,-1,connection);
- }
- stock yoursql_update(table[],updater[],identifier[])
- {
- new query[256];format(query,sizeof query,"UPDATE %s SET %s WHERE %s",table,updater,identifier);
- return mysql_query(query,-1,-1,connection);
- }
- stock yoursql_delete(table[],identifier[])
- {
- new query[128];format(query,sizeof query,"DELETE FROM %s WHERE %s",table,identifier);
- return mysql_query(query,-1,-1,connection);
- }
- stock yoursql_receive(table[],identifier[])
- {
- new query[128];format(query,sizeof query,"SELECT * FROM %s WHERE %s",table,identifier);
- if(mysql_query(query,-1,-1,connection) == 0) return query;
- mysql_store_result(connection);
- if(mysql_fetch_row_format(query,"|",connection))
- {
- mysql_free_result(connection);
- return query;
- }
- return query;
- }
- stock yoursql_escape_string(str[])
- {
- new string[256];
- mysql_real_escape_string(str,string);
- return string;
- }
- stock yoursql_query(query[])
- {
- return mysql_query(query,-1,-1,connection);
- }
- stock yoursql_countrows(strquery[])
- {
- new query[96];format(query,sizeof query,"%s",strquery);
- mysql_query(query,-1,-1,connection);
- mysql_store_result(connection);
- new result = mysql_num_rows(connection);
- mysql_free_result(connection);
- return result;
- }
- stock GetStructure(table[])
- {
- new query[96];format(query,sizeof query,"SHOW FIELDS FROM %s",table);
- if(!mysql_query(query,-1,-1,connection))
- {
- printf("yoursql => ERROR! Could not execute query: %s",query);
- }
- mysql_store_result(connection);
- new temp[32],result[96];
- while(mysql_retrieve_row(connection))
- {
- mysql_fetch_field_row(temp,"Field");
- if(!strlen(result))
- {
- format(result,sizeof result,"`%s`",temp);
- } else {
- format(result,sizeof result,"%s,`%s`",result,temp);
- }
- }
- mysql_free_result(connection);
- return result;
- }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement