@ckruseの回答を拡張するには、 mysql_real_escape_string()
文字列が任意のソースからのものである場合。
int insert_data(MYSQL * mysql, char * str, int len)
{
if (len < 0) {
len = strlen(str);
}
char esc[2*len+1];
unsigned long esclen = mysql_real_escape_string(mysql, esc, str, len);
char statement[512];
snprintf(statement, sizeof statement, "INSERT INTO table VALUES ('%s')", esc);
return mysql_query(mysql, statement);
}
(別の方法として、 mysql_hex_string()
正しく処理された場合。)