[英]Insert a Binary string into MYSQL varchar column
众所周知,我们将使用mysql_query api将查询发送到服务器,并且查询将通过字符串作为参数传递。 而且我们将不得不在s_printf之类的C函数调用的mysql_query外部编写字符串。
sprintf(buffer, “insert into table(describe) values(‘%s’)”, strA);
mysql_query(..., buffer);
The ‘describe’ is a VARCHAR(150).
在某些特殊情况下,我们的函数之一会将几个C样式字符串转换为长字符串,并保留所有结尾的'\\ 0'以形成二进制文件,即以C形式将“ abc”和“ efg”转换为“ abc \\ 0efg \\” 0”,当然还有给呼叫者的长度(在这种情况下为8)。 但是,out二进制绝对不能在上面的sprintf中用作strA,因为C函数将通过满足第一个'\\ 0'来截断字符串。
我们有什么特别的事情可以满足我们的需求? 我们想将二进制文件插入定义为VARCHAR的列中。 我们试图将所有的'\\ 0'真正地更改为'\\ 0',这看起来不错,但是很费时间和代码。 有没有其他更简便的方法?
提前致谢。
您应该使用mysql_real_escape_string()来转义该字符串。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.