数据库binary
1. binary 数据类型
语法 BINARY [ ( max-length ) ]参数 max-length 值的最大长度,以字节为单位。该长度必须在 1 到 32767 范围内。如果未指定长度,则值为 1。注释 在比较过程中,将会精确地逐个字节地对 BINARY 值进行比较。与之不同的是,CHAR 数据类型的值是使用数据库的归类序列进行比较。如果某个二进制字符串是另一个二进制字符串的前缀,即认为较短的字符串小于较长的字符串。与 CHAR 值不同,BINARY 值在字符集转换期间不会进行转换。BINARY 在语义上等同于 VARBINARY。它是一种可变长度类型。在其它数据库管理系统中,BINARY 是一种固定长度类型。另请参见 VARBINARY 数据类型 LONG BINARY 数据类型 字符串函数
2. mysql数据类型中blob和binary的区别
MySQL 数据类型细分下来,大概有以下几类:
数值,典型代表为 tinyint,int,bigint
浮点/定点,典型代表为 float,double,decimal 以及相关的同义词
字符串,典型代表为 char,varchar
时间日期,典型代表为 date,datetime,time,timestamp
二进制,典型代表为 binary,varbinary
位类型
枚举类型
集合类型
大对象,比如 text,blob
json 文档类型
一、数值类型(不是数据类型,别看错了)如果用来存放整数,根据范围的不同,选择不同的类型。
注意:timestamp 代表的时间戳是一个 int32 存储的整数,取值范围为 '1970-01-01 00:00:01.000000' 到 '2038-01-19 03:14:07.999999';datetime 取值范围为 '1000-01-01 00:00:00.000000' 到 '9999-12-31 23:59:59.999999'。
1. 如果时间有可能超过时间戳范围,优先选择 datetime。2. 如果需要单独获取年份值,比如按照年来分区,按照年来检索等,最好在表中添加一个 year 类型来参与。3. 如果需要单独获取日期或者时间,最好是单独存放,而不是简单的用 datetime 或者 timestamp。后面检索时,再加函数过滤,以免后期增加 SQL 编写带来额外消耗。
建立表 t5,对这些可能需要的字段全部分离开,这样以后写 SQL 语句的时候就很容易了。
当然了,这种情形占用额外的磁盘空间。如果想在易用性与空间占用量大这两点来折中,可以用 MySQL 的虚拟列来实时计算。比如假设 c5 字段不存在,想要得到 c5 的结果。mysql-(ytt/3305)->alter table t5 drop c5, add c5 year generated always as (year(c1)) virtual;Query OK, 1 row affected (2.46 sec)Records: 1 Duplicates: 0 Warnings: 0
五、二进制类型
binary(10)/varbinary(10) 代表的不是字符个数,而是字节数。
行结束符不一样。char 的行结束符是 ,binary 的行结束符是 0x00。
由于是二进制存储,所以字符编码以及排序规则这类就直接无效了。
六、位类型
1. 对于 bit(8) 如果单纯存放 1 位,左边以 0 填充 00000001。2. 查询时可以直接十进制来过滤数据。3. 如果此字段加上索引,MySQL 不会自己做类型转换,只能用二进制来过滤。
创建表 c1, 字段性别定义一个比特位。mysql-(ytt/3305)->create table c1(gender bit(1));Query OK, 0 rows affected (0.02 sec)
mysql-(ytt/3305)->select cast(gender as unsigned) 'f1' from c1;+------+| f1 |+------+| 0 || 1 |+------+2 rows in set (0.00 sec)
过滤数据也一样,二进制或者直接十进制都行。mysql-(ytt/3305)->select conv(gender,16,10) as gender -> from c1 where gender = b'1';+--------+| gender |+--------+| 1|+--------+1 row in set (0.00 sec)mysql-(ytt/3305)->select conv(gender,16,10) as gender -> from c1 where gender = '1';+--------+| gender |+--------+| 1|+--------+1 row in set (0.00 sec)
mysql-(ytt/3305)->create table c2(gender char(0));Query OK, 0 rows affected (0.03 sec)
mysql-(ytt/3305)->select count(*) from c1;+----------+| count(*) |+----------+| 33554432 |+----------+1 row in set (1.37 sec)
mysql-(ytt/3305)->insert into c2 select if(gender = 0,'',null) from c1;Query OK, 33554432 rows affected (2 min 18.80 sec)Records: 33554432 Duplicates: 0 Warnings: 0
两张表的磁盘占用差不多。root@ytt-pc:/var/lib/mysql/3305/ytt# ls -sihl总用量 1.9G4085684 933M -rw-r----- 1 mysql mysql 932M 12月 11 10:16 c1.ibd4082686 917M -rw-r----- 1 mysql mysql 916M 12月 11 10:22 c2.ibd
检索方式稍微有些不同,不过效率也差不多。所以说,字符类型不愧为万能类型。
七、枚举类型
1. 最大占用 2 Byte。2. 最大支持 65535 个不同元素。3. MySQL 后台存储以下标的方式,也就是 tinyint 或者 smallint 的方式,下标从 1 开始。4. 排序时按照下标排序,而不是按照里面元素的数据类型。所以这点要格外注意。
创建表 t7。mysql-(ytt/3305)->create table t7(c1 enum('mysql','oracle','dble','postgresql','mongodb','redis','db2','sql server'));Query OK, 0 rows affected (0.03 sec)
1. 最大占用 8 Byte,int64。2. 内部以二进制位的方式存储,对应的下标如果以十进制来看,就分别为 1,2,4,8,...,pow(2,63)。3. 最大支持 64 个不同的元素,重复元素的插入,取出来直接去重。4. 元素之间可以组合插入,比如下标为 1 和 2 的可以一起插入,直接插入 3 即可。
mysql-(ytt/3305)->create table c7(c1 set('mysql','oracle','dble','postgresql','mongodb','redis','db2','sql server'));Query OK, 0 rows affected (0.02 sec)
mysql-(ytt/3305)->INSERT INTO c7WITH RECURSIVE ytt_number (cnt) AS ( SELECT 1 AS cnt UNION ALL SELECT cnt + 1 FROM ytt_number WHERE cnt < pow(2, 7) )SELECT *FROM ytt_number;Query OK, 128 rows affected (0.01 sec)Records: 128 Duplicates: 0 Warnings: 0
示例 10
mysql-(ytt/3305)->select ytt_sample_data_type(1111,222) 'result';+--------------------------+| result |+--------------------------+| The result is: '246642'. |+--------------------------+1 row in set (0.00 sec)

综上所述,日期这块类型的选择遵循以下原则:
4. 如果有保存毫秒类似的需求,最好是用时间类型自己的特性,不要直接用字符类型来代替。MySQL 内部的类型转换对资源额外的消耗也是需要考虑的。
示例 5
binary 和 varbinary 对应了 char 和 varchar 的二进制存储,相关的特性都一样。不同的有以下几点:
示例 6
来看这个 binary 存取的简单示例,还是之前的变量 @a。
切记!这里要提前计算好 @a 占用的字节数,以防存储溢出。
bit 为 MySQL 里存储比特位的类型,最大支持 64 比特位, 直接以二进制方式存储,一般用来存储状态类的信息。比如,性别,真假等。具有以下特性:
示例 7
其实这样的场景,也可以定义为 char(0),这也是类似于 bit 非常优化的一种用法。
那现在我给表 c1 简单的造点测试数据。
把 c1 的数据全部插入 c2。
枚举类型,也即 enum。适合提前规划好了所有已经知道的值,且未来最好不要加新值的情形。枚举类型有以下特性:
示例 8
八、集合类型
集合类型 SET 和枚举类似,也是得提前知道有多少个元素。SET 有以下特点:
示例 9
定义表 c7 字段 c1 为 set 类型,包含了 8 个值,也就是下表最大为 pow(2,7)。
插入 1 到 128 的所有组合。
九、数据类型在存储函数中的用法
函数里除了显式声明的变量外,默认 session 变量的数据类型很弱,随着给定值的不同随意转换。
定义一个函数,返回两个给定参数的乘积。定义里有两个变量,一个是 v_tmp 显式定义为 int64,另外一个 @vresult 随着给定值的类型随意变换类型。
简单调用下。
总结
本篇把 MySQL 基本的数据类型做了简单的介绍,并且用了一些容易理解的示例来梳理这些类型。我们在实际场景中,建议选择适合最合适的类型,不建议所有数据类型简单的最大化原则。比如能用 varchar(100),不用 varchar(1000)。
3. SQL-SQL中binary 和 varbinary的区别
binary 和 varbinary
固定长度 (binary) 的或可变长度 (varbinary) 的 binary 数据类型。
binary [ ( n ) ]
固定长度的 n 个字节二进制数据。N 必须从 1 到 8,000。存储空间大小为 n+4 字节。
varbinary [ ( n ) ]
n 个字节变长二进制数据。n 必须从 1 到 8,000。存储空间大小为实际输入数据长度 +4 个字节,而不是 n 个字节。输入的数据长度可能为 0 字节。在 SQL-92 中 varbinary 的同义词为 binary varying。
注释
如果在数据定义或变量声明语句中没有指定 n,默认长度为 1。如果没有用 CAST 函数指定 n,默认长度为 30。
当列数据项大小一致时应使用 binary。
当列数据项大小不一致时应使用 varbinary。
BLOB (binary large object),二进制大对象,是一个可以存储二进制文件的容器。
在计算机中,BLOB常常是数据库中用来存储二进制文件的字段类型。
BLOB是一个大文件,典型的BLOB是一张图片或一个声音文件,由于它们的尺寸,必须使用特殊的方式来处理(例如:上传、下载或者存放到一个数据库)。
大型对象
BLOB就是使用二进制保存数据。
如:保存位图。
CLOB使用CHAR来保存数据。
如:保存XML文档。
MySQL中,BLOB是个类型系列,包括:TinyBlob、Blob、MediumBlob、LongBlob,这几个类型之间的唯一区别是在存储文件的最大大小上不同。
MySQL的四种BLOB类型
类型 大小(单位:字节)
TinyBlob 最大 255
Blob 最大 65K
MediumBlob 中等16M
LongBlob 最大 4G
4. 为什么在数据库建表时图片字段不能编辑(显示binary)类型应该是image吗怎么才能把图片插入表中
不能编辑的意思是什么?修改里面的某些内容吗?binary属于二进制方式的存在,你直接将对象写到数据库中就可以了,至于使用image还是binary存储图片都是可以的,这个不影响。
5. 数据库中的binary类型有啥用,可以存放对象吗
表面上这个存的是0101这样的字节,其实经过编码解码什么都可以存了。
OO的对象,可以考虑先序列化为字串,再取字串的字节序列来存了。取用的时候再做相反操作了。
不过好像没有这种必要吧,OR之间转换是是逃不掉的,你这是在为难自己
6. 请教:vb access数据库中的binary类型可存放什么范围怎样
哈哈,难得啊,这种类型确实用的人不多啊,我当时也是被整得很惨,研究了好久才摸到点门道,这里跟你分享下吧。
binary是二进制类型,长度可以定义的,你定义了多少个字节就是就是多少字节;
可以用来放些不太规则的数据,比如5个字节、6个字节的,你找不到对应的数据类型,但是又不愿意用varchar来存放。实际上基本上binary的都可以改用varchar,除非数据库设计者非得坚持这样子,开发人员也没办法,对吧。
access里怎么创建和选长度我也不知道,直接打开就能看到个ole对象,连内容都看不到,真是晕啊,但是确确实实可以通过编程用create语句创建出来这种字段的。
而且有一点,一旦这个字段类型是binary的,那这个字段就不能作为主键了,access就是这样的,没处说理啊。如果业务要求这个字段又非得是主键,那就只好整个表都不建主键了,靠应用程序来保证不会出现主键冲突的情况吧。
写数据库的时候,用个数组就行,像这样
Dim
ckp(8)
As
Byte
ckp(0)
=1
ckp(1)
=&h10
ckp(2)
=0
ckp(3)
=0
......
With
rstTable
.AddNew
......
!mcheckpoint
=
ckp
......
.Update
End
With
读数据库的时候,定义个动态数组,取出来就是了
SQL="select
*
from
mytable"
Rs.Open
SQL,
cn,
adOpenKeyset,
adLockPessimistic
If
Rs.RecordCount
>
0
Then
'查到了
Dim
ckp()
As
Byte
If
IsNull(Rs!mcheckpoint)
Then
ckp
=
Rs!mcheckpoint
Else
ReDim
ckp(8)
End
If
.......
用where语句选择的时候可以用等于号,后面用二进制表示
select
*
from
mytable
where
mCheckPoint
=
0x000000000000000001
如果这样子不行的话,还可以尝试下用like
select
*
from
mytable
where
mCheckPoint
like
0x000000000000000001
祝你好运啦!
7. ADO方式下,怎么获取sql server数据库中Binary数据(初学者提问)
CString str1;//不要比如int型了,还是CString吧
str1=m_pRecordset->GetCollect("roles"); //字段roles的数据保存到str1
//中,不过是一条数据
如果数据多条,可以用m_pRecordset->MoveNext(),来逐条读取
8. 在MYSQL数据库中,BINARY(M)中的M指的是什么
在MySQL数据库中,
BINARY是二进制字符串,M表示字符串的个数
9. 数据库里的一个字段是以binary存储的,在后台调用查询方法时页面显示的是了u乱码,怎么解决啊
binary类型是二进制啊,你后台查询出结果后需要转换二进制才能显示出原来的字符。
10. 数据库里binary类型的数据应该如何写入和查看
//用下面的语句创建一个名为binary_test的表,其中包含了一个BINARY_FLOAT列和BINARY_DOUBLE列:
CREATETABLEbinary_test(
bin_floatBINARY_FLOAT,
bin_doubleBINARY_DOUBLE,
);
//注意:在SQL目录中会发现一个名为oracle_10g_example.sql的脚本,这个脚本在store模式中创建了binary_test表,该脚本还可以执行INSERT语句,如果可以访问一个Oracle10g的数据库,就可以运行这个脚本。下面的这些语句时像binary_test表中添加一行;
INISERTINTObinary_test(
bin_float,bin_double
)VALUES(39.5f,15.7d
);
f和d分别用于表明一个数字是BINARY_FLOAT类型或者BINARY_DOUBLE类型的。