doutizhou5312 2017-06-07 12:35
浏览 334
已采纳

MySQL如何在虚拟字段定义中实现条件

I'm using the PHP function below to calculate checksums for strings in PHP. The xor is required to produce the same value on 32 and 64 bit php platforms.

I would like to create a virtual field in MySQL select queries that will have the same value. SELECT ABS(CRC32(ui_data)) As checksum FROM user_data works but I don't know how to implement the if part in a SELECT statement to make it fully compatible to the PHP function.

10X

function checksum ($orig_id) {
    $crc= abs (crc32($orig_id));
    if( $crc & 0x80000000){
      $crc ^= 0xffffffff;
      $crc += 1;
     }
    return $crc;
}
  • 写回答

1条回答 默认 最新

  • duanke0178 2017-06-07 13:16
    关注
    SELECT IF(@crc & 0x80000000, @crc ^ 0xffffffff, @crc + 1)
    FROM (SELECT @crc := ABS(CRC32('your_value'))) v
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥30 基于信创PC发布的QT应用如何跨用户启动后输入中文
  • ¥20 非root手机,如何精准控制手机流量消耗的大小,如20M
  • ¥15 远程安装一下vasp
  • ¥15 自己做的代码上传图片时,报错
  • ¥15 Lingo线性规划模型怎么搭建
  • ¥15 关于#python#的问题,请各位专家解答!区间型正向化
  • ¥15 unity从3D升级到urp管线,打包ab包后,材质全部变紫色
  • ¥50 comsol温度场仿真无法模拟微米级激光光斑
  • ¥15 上传图片时提交的存储类型
  • ¥15 VB.NET如何绘制倾斜的椭圆