怎样将bitmap添加到mysql数据库中

怎样将bitmap添加到mysql数据库中,第1张

MySQL 原生并不支持 bitmap 类型,所以就只能存字符串,然后就根据你的 bitmap 长度以及转换方式来选择是用什么类型来存储,处理的过程在代码层面完成。

我简单说下我们做同样的事情的做法,不一定是好方法,可以一起探讨。

首先,我们 *** 作数据库的语言是 PHP。使用的是 ASCII 表里的 0 ~ 127位的字符,所以每一个字符可以存 8bits,然后用一个 char(125) 来存 bitmap 的一个片段,每个片段可以存 1000bits。

通过 PHP 计算某一位在那一个片段的第几位,例如 2345,就在第三个片段的第345位(从1开始的话),然后通过 PHP 进行更新。当然,也可以直接用 SQL 更新,SQL 语句写起来比较麻烦,我写了半天才写出来:

unhex( conv( bin( conv( hex( STR1 ), 16, 10 ) | conv( hex( STR2 ), 16, 10 ) ), 2, 16 ) )

不过我们用 MySQL 存储也就是为了确保数据的安全性,大部分的查询 *** 作都在 redis 里面完成,redis 原生支持 bitmap 用起来又高效又方便。

System.IO.FileStream fs = new System.IO.FileStream("file path and name", IO.FileMode.Open, IO.FileAccess.Read)

byte[] imgData = new byte[fs.Length]

fs.Read(imgData, 0, fs.Length)

SqlConnection conn = new SqlConnection("...")

SqlDataAdapter da = new SqlDataAdapter("select ... ", conn)

DataSet ds = new DataSet()

da.Fill(ds)

SqlCommandBuilder cb = new SqlCommandBuilder(da)

ds.Tables[0].Rows[0]["img"] = imgData

da.Update(ds)

其中,img字段为Image类型


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/6664057.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-26
下一篇 2023-03-26

发表评论

登录后才能评论

评论列表(0条)

保存