广告
返回顶部
首页 > 资讯 > 数据库 >SQL Server中怎么实现数据类型转换
  • 841
分享到

SQL Server中怎么实现数据类型转换

2024-04-02 19:04:59 841人浏览 泡泡鱼
摘要

这篇文章将为大家详细讲解有关SQL Server中怎么实现数据类型转换,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。1 显式转换显示转换是将某种数据类型的表

这篇文章将为大家详细讲解有关SQL Server中怎么实现数据类型转换,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

1 显式转换

显示转换是将某种数据类型的表达式显式转换为另一种数据类型。常用的是CAST 和 CONVERT 函数。

CAST: CAST ( expression AS data_type )CONVERT: CONVERT (data_type[(length)], expression [, style])

参数 expression 是任何有效的 Microsoft sql Server表达式。data_type 目标系统所提供的数据类型,不能使用用户定义的数据类型。

2 隐性转换

隐性转换对于用户是不可见的,由SQL Server 引擎自动处理。 隐性转换自动将数据从一种数据类型转换成另一种数据类型。例如,如果一个 smallint 变量和一个 int 变量相比较,这个 smallint 变量在比较前即被隐性转换成 int 变量。 当从一个 SQL Server 对象的数据类型向另一个转换时,一些隐性和显式数据类型转换是不支持的。例如,nchar 数值根本就不能被转换成 image 数值。nchar 只能显式地转换成 binary,隐性地转换到 binary 是不支持的。nchar 可以显式地或者隐性地转换成 nvarchar。

3 隐性转换的风险

隐性转换有的时候非常方便,可以简化SQL 脚本,但是这里面也孕育着潜在的风险,可能会出现在脚本一开始运行的时候都是正常的,但却某一个时间点之后,程序莫名出现错误。下面举一个现实项目中的例子来说明。在SQL Server 2008中有一个表,需要从两个不同的数据表中拉取数据,由于这两个数据表属于不同的系统,其主键类型是不同的,一个是int类型,一个是GUID,一开始想着这两个都可以转换成字符类型进行存储。所以就在表中建立一个nvarchar(50)的混合ID列作为主键。如下图所示:

一开始拉取的数据并未有GUID的值,都是INT类型转换过来的数据,所以SQL脚本运行的正常,但是突然某一次运行时,出现了“在将 nvarchar 值 '4C185367-F004-41FE-8A0A-DB4E819B1FF2' 转换成数据类型 int 时失败。”的错误。如下图所示:

定位到脚本,执行的SQL如下:

select * from dbo.Demo where 混合ID=305

其中主键中的数据有GUID转换的字符型,也有INT转换的字符串,示例数据如下:

但是如果执行下面的SQL,则都是正常执行:

select * from dbo.Demo where 混合ID=305 and 名称='INT'select * from dbo.Demo where 混合ID=305 and 序号='2'select * from dbo.Demo where 混合ID=305 and 序号=2select * from dbo.Demo where 混合ID='305' and 名称='INT'select * from dbo.Demo where 混合ID='305'

select * from dbo.Demo where 混合ID=305在执行时,SQL Server会将nvarchar类型的隐性转换成int类型,如果数据中没有GUID类型的字符,则转换正常,如果有,当进行GUID字符到INT的隐性转换时,则转换失败。

关于SQL Server中怎么实现数据类型转换就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

您可能感兴趣的文档:

--结束END--

本文标题: SQL Server中怎么实现数据类型转换

本文链接: https://www.lsjlt.com/news/58317.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • SQL Server中怎么实现数据类型转换
    这篇文章将为大家详细讲解有关SQL Server中怎么实现数据类型转换,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。1 显式转换显示转换是将某种数据类型的表...
    99+
    2022-10-18
  • sql server中怎么实现类型转换
    sql server中怎么实现类型转换,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。记录下 :DECLARE @i  INT;DEC...
    99+
    2022-10-18
  • SQL Server 中数据类型怎么实现隐式转换
    本篇文章为大家展示了SQL Server 中数据类型怎么实现隐式转换,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。如下所示: CREATE TA...
    99+
    2022-10-18
  • SQL Server中如何实现T-SQL数据类型转换
    这篇文章主要为大家展示了“SQL Server中如何实现T-SQL数据类型转换”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“SQL Server中如何实现T-S...
    99+
    2022-10-18
  • sql server中的数据类型转换cast与convert
    注意点: CAST()函数和CONVERT()函数都不能执行四舍五入或截断操作。如: SELECT CAST("12.5" AS decimal) 结果是一个整数值:12 如果通过CAST()函数将这个值转换为decimal类型,需...
    99+
    2014-07-20
    sql server中的数据类型转换cast与convert
  • SQL Server 中的数据类型隐式转换问题
    写这篇文章的时候,还真不知道如何取名,也不知道这个该如何将其归类。这个是同事遇到的一个案例,案例比较复杂,这里抽丝剥茧,仅仅构造一个简单的案例来展现一下这个问题。我们先构造测试数据,如下所示: CRE...
    99+
    2022-10-18
  • SqlServer中怎么实现数据类型转换
    SqlServer中怎么实现数据类型转换,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。SQL中的cast 和convert都是...
    99+
    2022-10-18
  • SQL中CAST()实例之转换数据类型
    目录1.CAST()的语法及用法(1)语法:CAST(Expression AS Data_type)(2)用法:2.CAST()的实例(1)将文本(字符串)时间转为日期格式,获取日期格式的字段(2)与其它语法进行结合使...
    99+
    2023-01-13
    sql cast() sql转换数据类型 sql转换数据类型语句
  • SQL的CAST()——转换数据类型
    目录 1.CAST()的语法及用法 (1)语法:CAST(Expression AS Data_type) 即CAST(表达式 AS 数据类型) (2)用法:将需要转换的表达式转为目标类型,可以是获取目标类型的字段,也可以与wher...
    99+
    2023-09-17
    其他 经验分享 sql mysql
  • SQL Server中怎么将二进制转换为字符类型
    这期内容当中小编将会给大家带来有关SQL Server中怎么将二进制转换为字符类型,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。问题描述:在SQL Server 数据库中...
    99+
    2022-10-18
  • java怎么实现数据类型的转换
    在Java中,可以使用类型转换操作符将一种数据类型转换成另一种数据类型。类型转换分为两种:隐式类型转换和显式类型转换。1. 隐式类型...
    99+
    2023-10-09
    java
  • Java中怎么实现基本数据类型转换
    这期内容当中小编将会给大家带来有关Java中怎么实现基本数据类型转换,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。自动类型转换自动类型转换是指:数字表示范围小的数据类型可以自动转换成范围大的数据类型。如:...
    99+
    2023-06-17
  • SQL Server中怎么将行数据转换为列数据
    今天就跟大家聊聊有关SQL Server中怎么将行数据转换为列数据,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。准备工作创建表use [t...
    99+
    2022-10-18
  • MySQL与oracle怎么实现数据类型转换
    这篇文章将为大家详细讲解有关MySQL与oracle怎么实现数据类型转换,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。 mysq...
    99+
    2022-10-18
  • php数据类型自动转换怎么实现
    这篇文章主要讲解了“php数据类型自动转换怎么实现”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“php数据类型自动转换怎么实现”吧!1.强类型和弱类型PHP变量有两种类型:强类型和弱类型。强...
    99+
    2023-07-05
  • SQL Server 2008处理隐式数据类型转换的示例分析
    小编给大家分享一下SQL Server 2008处理隐式数据类型转换的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧! ...
    99+
    2022-10-18
  • php8数据类型怎么转换
    php8数据类型的方法有字符串转换为整数、整数转换为字符串、字符串转换为浮点数、浮点数转换为字符串、数组转换为字符串、字符串转换为数组、布尔值转换为整数、整数转换为布尔值和变量类型判断和转换。详细介绍:1、字符串转换为整数包括intval(...
    99+
    2023-11-16
    PHP8 数据类型
  • C++中怎么实现类型转换
    本篇文章给大家分享的是有关C++中怎么实现类型转换,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。0. 类型转换的原理在进行下面的学习前,我觉得有比较知道不同类型是怎么进行转换的...
    99+
    2023-06-20
  • mysql 数据类型转换的实现
    一、问题 有一张如下图所示的表,需要我们查出 result 值大于 reference_high值的数据 然后我们写了下面的SQL查询语句 SELECT i.result,i.reference_hig...
    99+
    2022-05-25
    mysql 数据类型转换 mysql 转换数据类型
  • numpy数据类型dtype转换实现
    这篇文章我们玩玩numpy的数值数据类型转换 导入numpy >>> import numpy as np 一、随便玩玩 生成一个浮点数组 >...
    99+
    2022-11-12
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作