美文网首页
好心办坏事小心隐式类型转换

好心办坏事小心隐式类型转换

作者: 河东客 | 来源:发表于2018-01-05 12:42 被阅读0次

数据库为了保证SQL能够正常执行,总会提供一些友好性来满足那些看起来对的SQL正常执行,如隐式类型转换的使用,万字不如code,来看个具体的问题

创建表

create table  CONVERT_SHOW   
(  
  USER_ID              bigint(8),  
  NAME                 varchar(8),  
  OP_TIME              timestamp default CURRENT_TIMESTAMP
);  

插入模拟数据

insert into CONVERT_SHOW(user_id,name)values(0,'cast');  
insert into CONVERT_SHOW(user_id,name)values(1,'cast2');  
insert into CONVERT_SHOW(user_id,name)values(2,'cast3'); 

前台读取表中的数据一般使用的查询SQL

select USER_ID,NAME,OP_TIME from CONVERT_SHOW where USER_ID= ?;  

但会有省事的直接以'参数值' 来替换"?",替换后的SQL可能是这样的(参数有点夸张,但传递的查询值真可能什么都有)

select USER_ID,NAME,OP_TIME from CONVERT_SHOW where USER_ID= '查询参数';  

这时,隐藏的一个陷阱就可能出现:数据库为了SQL正常工作,会使用隐式类型转换使得参数变成bigint类型,如果传递的参数不是整数会出现什么样的情况?

select cast('查询参数' as UNSIGNED ) ;  

结果是:0

如果恰好表里存在一条user_id为0的数据(真遇到了,不然也不会有这篇文章),就会被返回,接着就是让人的各种着急,连在搜索引擎上使用什么样的关键字来描述问题都非常困难_

如果数据访问层能够做到对参数进行类型校验,肯定可以避免问题出现,但大多时候都是无心挖出来的坑,那真是满头的黑线啊!!!

相关文章

  • 好心办坏事小心隐式类型转换

    数据库为了保证SQL能够正常执行,总会提供一些友好性来满足那些看起来对的SQL正常执行,如隐式类型转换的使用,万字...

  • 数据类型转换

    写在前面 C/C++编程中常见数据类型转换,包括隐式类型转换和显式类型转换。 1. 隐式类型转换 隐式类型转换在以...

  • 04_什么是隐式转换?什么是显式转换?

    一、什么是隐式转换? 1.1、隐式转换 隐式类型转换,也称自动类型转换,是指不需要书写代码,由系统自动完成的类型转...

  • Java Script 类型转换以及运算

    (一)类型转换 1、隐式转换 num 被隐式转换为true 2、显式转换 其他数据类型转(布尔类型)1、数字:0和...

  • JavaScript 常见面试题分析(四)

    01 强制类型转换和隐式类型转换 强制:parseInt、parseFloat、toString隐式:if、逻辑运...

  • C++类型转换

    C++的类型转换分为隐式转换和显式转换 隐式转换举例: int i=4; double d=i;//隐式转换 显式...

  • Java 学习笔记_2

    1、隐式转换 和 强制类型转换 隐式转换: 又叫自动类型转换。由系统自动完成的类型转换. 从存储范围小的类型到存储...

  • JavaSE之隐式转换、强制转换

    课前小例 转换类型:隐式转换(自动类型转换)、强制类型转换 隐式转换:两种类型彼此兼容,范围小的类型转成范围大的类...

  • kotlin基础笔记之类型转换

    Kotlin没有隐式拓宽转换,如 Java 中 int 可以隐式转换为 long,必须要显式类型转换。 显式类型转...

  • 回顾Date.0402(类型转换、运算)

    类型转换 隐式转换 显式转换 转换为Boolean类型:Boolean(xxx) ; !!xxx 数字类型转换为布...

网友评论

      本文标题:好心办坏事小心隐式类型转换

      本文链接:https://www.haomeiwen.com/subject/mbnjnxtx.html