c#里,通过串口收到的数据会转换为16进制字符串,想将数据存入数据库,应该怎么写?

用的是05版本的,我觉得16进制需要转成10进制存入吧,程序应该怎么写求大神指导啊,数据库链接神马的都编好了。下面是我写的实验用的程序,转10进制就蒙圈了已经。
private void DataReceived(object sender, System.IO.Ports.SerialDataReceivedEventArgs e)//16进制接收模式
{
int n = serialPort.BytesToRead;//先记录下来,避免某种原因,人为的原因,操作几次之间时间长,缓存不一致
byte[] buf = new byte[n];//声明一个临时数组存储当前来的串口数据
serialPort.Read(buf, 0, n);//读取缓冲数据
//依次的拼接出16进制字符串
this.Invoke((EventHandler)(delegate
{
foreach (byte b in buf)
{
builder.Append(b.ToString("X2") + " ");
}
string hexstring = builder.ToString();
int i = Int32.Parse(hexstring, System.Globalization.NumberStyles.HexNumber);
//this.richTextBox1.AppendText(builder.ToString());
this.richTextBox1.AppendText(i);
}));
}
中间把16进制字符串转成int型字符了应该是,然后怎么能变成10进制?另外如何存入sql数据库呢?存入的应该是10进制还是16进制的啊?求指点。

数值是没有必要分几进制的,它在内存中就是二进制保存的。只是为了方便人们查看,可以转为n进制的格式显示在文本框中进行显示的。
所以
1 buf 就不要转为字符串了,直接以二进制格式存入数据库。下次也是以二进制的形式取出(就是byte[])

2 richTextBox1 要显示二进制也好,16进制也好 根据实际需要决定。象你上面的例子,builder 中的内容直接插入到richTextBox1中就好了。追问

直接存入数据库,数据库里显示的是什么数据啊?是二进制的?那怎么看呢?我还得做个显示收到的数据的部分。。。

追答

数据列就设置为二进制数组 ,比如 sql server 中的binary、varbinary或image。
数据库中的数据不一定非要能显示的。它只要管存数据就好了。怎么显示是界面上的事。

从数据库中读取出为二进制数组(byte[]),可以转为16进制的字符串显示,也可以转为二进制的字符串显示,或是界面上有一个选项按钮,由使用人员来选择什么格式显示。再比如这个二进制数组是一个图像文件,那么使用Image载入,然后显示在界面上。

温馨提示:答案为网友推荐,仅供参考
第1个回答  2014-04-02
read()函数读到的数据是二进制的。也就是说buf数组里面的数据就是二进制的。string str=Enconding.编码格式.GetString(buf)就可以把buf按相应编码格式转成可识别字符,也就是我们认识的字符。如果二进制数据代表的是10进制数字,那么str里就是对应的10进制数字。还有你这个串口读数据有点问题,会丢失数据。就是可能发生有的数据还没到缓存,你已经读了的情况。最简单方法是在 int n=serialPor.BytesToRead;前加一个Thread.Sleep(毫秒数)来给缓存一个接收数据的时间。多少毫秒你根据你给串口设置的波特率来设置。追问

可以理解为不用转成16进制显示,就用您的那个命令直接显示收到的数据就行么?那后边存入数据库就直接把str内数据存入么?数据库内是显示什么样的数据呢?

第2个回答  2014-04-02
把16进制字符串转10进制数字很简单
int i;
i=Convert.ToInt32("0a", 16);
i 就等于10
第3个回答  2014-04-02
//var 进制基数 = Convert.ToString(99, 16);
//Console.WriteLine(进制基数);
//Console.WriteLine(Convert.ToInt32(进制基数, 16));
//进制基数 = Convert.ToString(99, 8);
//Console.WriteLine(进制基数);
//Console.WriteLine(Convert.ToInt32(进制基数, 8));
//进制基数 = Convert.ToString(99, 2);
//Console.WriteLine(进制基数);
//Console.WriteLine(Convert.ToInt32(进制基数, 2));
http://social.msdn.microsoft.com/search/zh-cn?query=%E8%BF%9B%E5%88%B6
相似回答