繁体   English   中英

将二进制字符串插入MYSQL varchar列

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM