如何利用MySQL查询varbinary中存储的数据

 更新时间:2023年07月12日 10:41:30   作者:nomandia  
varbinary 类型和char与varchar类型是相似的,他们是包含字节流而不是字符流,他们有二进制字符的集合和顺序,他们的对比,排序是基于字节的数值进行的,本文给大家介绍如何利用MySQL查询varbinary中存储的数据,感兴趣的朋友一起看看吧

MySQL查询varbinary的数值

如何利用MySQL查询varbinary中存储的数据?这里记录下例子

SELECT ORD(SUBSTRING(`binary_column`, 1, 1)) AS converted_value FROM `TableName`;

上述语句中,SUBSTRING(binary_column, 1, 1) 会提取字段中的第一个字节。然后,ORD() 函数会将该字节转换为对应的 ASCII 值,因为 unpack() 函数返回的是一个字节流。

这样,你将得到一个名为 converted_value 的列,其中存储了通过 MySQL 查询得到的值为 1 的整数。

请注意,这种方法假设字段中的值是按照字节顺序存储的。如果存储方式不同,可能需要相应地调整提取和转换的逻辑。

用 php的 unpack 函数解析的形式,比如上面的例子,要解出一个整型(int32)可以这样表示,unpack('Iintval', $bindata)

mysql中varbinary什么意思_sql中varbinary 是什么数据类型

varbinary 类型和char与varchar类型是相似的,只是他们存储的是32313133353236313431303231363533e59b9ee7ad9431333431363564二进制数据,也就是说他们是包含字节流而不是字符流,他们有二进制字符的集合和顺序,他们的对比,排序是基于字节的数值进行的

binary与varbinary的最大长度和char与varchar是一样的,只不过他们是定义字节长度,而char和varchar对应的是字符长度。Varbinary是一个可以改变长度的二进制数据。

Varbinary[(n)] 是 n 位变长度的二进制数据。其中,n 的取值范围是从 1 到 8000。其存储窨的大小是 n + 4个字节,不是n 个字节。

varbinary在插入不会去填补0x00字节,查询的时候也不会丢弃任何字节,在比较的时候,所有的字节都是有效的,并且0x00

de266b0c1f75da4b4eca8f6104028a90.png

扩展资料:

varbinary( n | max):可变长度,n 的取值范围为 1 至 8,000,max 是指最大存储空间是 2^31-1 个字节,即最大4GB;

在将数据转换为二进制数据时,SQL Server会对生成的二进制数据进行填充或截断,详细的规则是:

1、填充(或扩展)的二进制数据是16进制的0x00的整数倍,这就是说,填充的字节中每一个bit都是0;

2、将字符类型转换成二进制数据时,在数据的右侧填充或截断数据,填充数值是0x00;

3、将其他类型数据转换成二进制数据时,在数据的左侧填充或截断数据,填充数值是0x00;在截断数据时,保留低位的数据,将高位数值截断。

到此这篇关于MySQL查询varbinary的数值的文章就介绍到这了,更多相关mysql查询varbinary内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 详解MySQL开启远程连接权限

    详解MySQL开启远程连接权限

    这篇文章主要介绍了MySQL开启远程连接权限,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-04-04
  • MySQL数据库开启、关闭、查看函数功能的方法

    MySQL数据库开启、关闭、查看函数功能的方法

    这篇文章主要介绍了MySQL数据库开启、关闭、查看函数功能的方法,本文为解决一个错误总结而来,错误信息本文一同给出,需要的朋友可以参考下
    2014-10-10
  • MySQL亿级数据平滑迁移双写方案实战

    MySQL亿级数据平滑迁移双写方案实战

    预约业务与其他业务数据表存储在同一个数据库,当其他业务出现慢SQL等异常时,会影响到预约业务,为了提高系统稳定性和数据隔离性,需要将预约数据表从原来的数据库中迁移出来,单独建立数据库,涉及到的读写场景多,改造成本大,采用 Mybatis插件实现迁移所需的双写等功能
    2024-08-08
  • 解决ERROR 2003 (HY000): Can‘t connect to MySQL server on ‘localhost‘ (111)的问题

    解决ERROR 2003 (HY000): Can‘t connect to MySQL server 

    在Windows系统上使用Django连接Ubuntu虚拟机中的MySQL数据库时,遇到无法连接的问题,排查后发现是由于MySQL绑定的IP地址改变导致的,下面就来介绍一下问题解决,感兴趣的可以了解一下
    2024-09-09
  • 三种常用的MySQL 数据类型

    三种常用的MySQL 数据类型

    这篇文章主要介绍了MySQL 的数据类型的的相关资料,文中讲解非常细致,帮助大家更好的理解和学习MySQL,感兴趣的朋友可以了解下
    2020-06-06
  • mysql 事务处理及表锁定深入简析

    mysql 事务处理及表锁定深入简析

    本文将详细介绍mysql 事务处理及表锁定,需要了解更多的朋友可以参考下
    2012-11-11
  • MYSQL中解析json格式数据方法示例

    MYSQL中解析json格式数据方法示例

    这篇文章主要给大家介绍了关于MYSQL中解析json格式数据的相关资料,JSON是一种轻量级的数据交换格式,采用了独立于语言的文本格式,类似XML,但是比XML简单,易读并且易编写,需要的朋友可以参考下
    2023-08-08
  • mysql 计算函数详情

    mysql 计算函数详情

    这篇文章主要介绍了mysql 计算函数,函数没有SQL的可移植性强 能运行在多个系统上的代码称为可移植的(portable)。相对来说,多数SQL语句是可移植的,在SQL实现之间有差异时,这些差异通常不那么难处理,下面来看看文章的具体内容吧
    2021-10-10
  • MySql事务原理介绍及特性

    MySql事务原理介绍及特性

    事务就是一组DML语句组成,这些语句在逻辑上存在相关性,这一组DML语句要么全部成功,要么全部失败,是一个整体。MySQL提供一种机制,保证我们达到这样的效果。事务还规定不同的客户端看到的数据是不相同的
    2022-09-09
  • 一文带你了解MySQL之事务隔离级别和MVCC

    一文带你了解MySQL之事务隔离级别和MVCC

    这篇文章主要带大家详细了解一下MySQL之事务隔离级别和MVCC,文中有详细的代码示例,具有一定的参考价值,感兴趣的同学可以借鉴月u的
    2023-06-06

最新评论