首页数据库数据库number?关于mysql数据库里面数据类型number的问题

数据库number?关于mysql数据库里面数据类型number的问题

编程之家2023-10-1798次浏览

大家好,今天小编来为大家解答数据库number这个问题,关于mysql数据库里面数据类型number的问题很多人还不知道,现在让我们一起来看看吧!

数据库number?关于mysql数据库里面数据类型number的问题

Oracle中的number(10,0)是什么意思

意思是:Number(p)是声明一个整数,最多有10位有效数字,1位小数。

number(4,3)是表示这个数一共有4位是有效位,后面的3表示有3个是小数也就是这个数只能是1.234,这样格式的最大只能是9.999。

number(3,4)表示这个数有效位数是3位但是有四位小数也就是只能是这个格式0.0123最大只能是0.0999。

扩展资料

Number类型的用法

p(precision)为精度,精度最大值为38;

数据库number?关于mysql数据库里面数据类型number的问题

s(scale)表示小数点右边的数字个数,scale的取值范围为-84到127;

因此,Number(p)即是声明一个整数,相当于Number(p,0),即等同于int型;

例子:

Number(8,1)存储小数位为1位,总长度为8的浮点数,如果小数位数不足,则用0补全;

Number(8)存储总长度为8的整数。

oracle数据库中Number是什么类型

number类型就是包括了所有的数字类型。可以是integer也可以是numeric

数据库number?关于mysql数据库里面数据类型number的问题

Oracle数据类型之number

oracle的number类型是oracle的内置类型之一,是oracle的最基础数值数据类型。在9iR2及其以前的版本中只支持一种适合存储数值数据的固有数据类型,在10g以后,才出现了两种新的数值类型,即推出本地浮点数据类型(Native Floating-Point Data Types): BINARY_FLOAT(单精度32位)和BINARY_DOUBLE(双精度64位).这些新数据类型都是基于IEEE二进制浮点运算标准,ANSI/IEEE Std 754-1985 [IEEE 754],使用这些类型时要加上文字f(BINARY_FLOAT)或者d(BINARY_DOUBLE),比如2.07f、3.000094d。

number数据类型

number类型的语法很简单:number(p,s):

p:精度位,precision,是总有效数据位数,取值范围是38,默认是38,可以用字符*表示38。

s:小数位,scale,是小数点右边的位数,取值范围是-84~127,默认值取决于p,如果没有指定p,那么s是最大范围,如果指定了p,那么s=0。

p:is the precision,or the total number of digits. Oracle guarantees the portability of numbers with precision ranging from 1 to 38.

s:is the scale, or the number of digits to the right of the decimal point. The scale can range from-84 to 127.

number类型的p和s,与其底层存储完全没有关系,根本不会影响数据在磁盘上如何存储,它只会影响允许哪些值以及数值如何舍入,你可以认为其是对数据的“编辑”。简单的说,精度位p表示数值最多能有多少个有效数字,而小数位s表示最多能有多少位小数。换句话说,p表示一共有多少位有效数字(即小数点左边最多有p-s位有效数字),s表示小数点右边有s位有效数字。如number(5,2)类型的数据,就表示小数点左边最多有3位有效数字,右边最多有2位有效数字,加起来就是最多有5位有效数字,超过这个范围的数字就不能正确的存储下来,注意这里说的是不能正确存储,但并不是不能存储。

最高整数位数=p-s

s正数,小数点右边指定位置开始四舍五入

s负数,小数点左边指定位置开始四舍五入

s是0或者未指定,四舍五入到最近整数

当p小于s时候,表示数字是绝对值小于1的数字,且从小数点右边开始的前s-p位必须是0,保留s位小数。

p>0,对s分2种情况:

1. s>0

精确到小数点右边s位,并四舍五入。然后检验有效数位是否p,小数点右边至少有s-p个0填充。

2. s<0

精确到小数点左边s位,并四舍五入。然后检验有效数位是否<=p+|s|

关于mysql数据库里面数据类型number的问题

MySQL数据类型细分下来,大概有以下几类:

数值,典型代表为 tinyint,int,bigint

浮点/定点,典型代表为 float,double,decimal以及相关的同义词

字符串,典型代表为 char,varchar

时间日期,典型代表为 date,datetime,time,timestamp

二进制,典型代表为 binary,varbinary

位类型

枚举类型

集合类型

大对象,比如 text,blob

json文档类型

一、数值类型(不是数据类型,别看错了)如果用来存放整数,根据范围的不同,选择不同的类型。

以上是几个整数选型的例子。整数的应用范围最广泛,可以用来存储数字,也可以用来存储时间戳,还可以用来存储其他类型转换为数字后的编码,如 IPv4等。示例 1用 int32来存放 IPv4地址,比单纯用字符串节省空间。表 x1,字段 ipaddr,利用函数 inet_aton,检索的话用函数 inet_ntoa。

查看磁盘空间占用,t3占用最大,t1占用最小。所以说如果整数存储范围有固定上限,并且未来也没有必要扩容的话,建议选择最小的类型,当然了对其他类型也适用。root@ytt-pc:/var/lib/mysql/3305/ytt# ls-sihl总用量 3.0G3541825 861M-rw-r----- 1 mysql mysql 860M 12月 10 11:36 t1.ibd3541820 989M-rw-r----- 1 mysql mysql 988M 12月 10 11:38 t2.ibd3541823 1.2G-rw-r----- 1 mysql mysql 1.2G 12月 10 11:39 t3.ibd

二、浮点数/定点数先说浮点数,float和 double都代表浮点数,区别简单记就是 float默认占 4 Byte。float(p)中的 p代表整数位最小精度。如果 p> 24则直接转换为 double,占 8 Byte。p最大值为 53,但最大值存在计算不精确的问题。再说定点数,包括 decimal以及同义词 numeric,定点数的整数位和小数位分别存储,有效精度最大不能超过 65。所以区别于 float的在于精确存储,必须需要精确存储或者精确计算的最好定义为 decimal即可。示例 3创建一张表 y1,分别给字段 f1,f2,f3不同的类型。mysql-(ytt/3305)->create table y1(f1 float,f2 double,f3 decimal(10,2));Query OK, 0 rows affected(0.03 sec)

三、字符类型字符类型和整形一样,用途也很广。用来存储字符、字符串、MySQL所有未知的类型。可以简单说是万能类型!

char(10)代表最大支持 10个字符存储,varhar(10)虽然和 char(10)可存储的字符数一样多,不同的是 varchar类型存储的是实际大小,char存储的理论固定大小。具体的字节数和字符集相关。示例 4例如下面表 t4,两个字段 c1,c2,分别为 char和 varchar。mysql-(ytt/3305)->create table t4(c1 char(20),c2 varchar(20));Query OK, 0 rows affected(0.02 sec)

所以在 char和 varchar选型上,要注意看是否合适的取值范围。比如固定长度的值,肯定要选择 char;不确定的值,则选择 varchar。

四、日期类型日期类型包含了 date,time,datetime,timestamp,以及 year。year占 1 Byte,date占 3 Byte。

time,timestamp,datetime在不包含小数位时分别占用 3 Byte,4 Byte,8 Byte;小数位部分另外计算磁盘占用,见下面表格。

请点击输入图片描述

请点击输入图片描述

注意: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编写带来额外消耗。

4.如果有保存毫秒类似的需求,最好是用时间类型自己的特性,不要直接用字符类型来代替。MySQL内部的类型转换对资源额外的消耗也是需要考虑的。

示例 5

建立表 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和 varbinary对应了 char和 varchar的二进制存储,相关的特性都一样。不同的有以下几点:

binary(10)/varbinary(10)代表的不是字符个数,而是字节数。

行结束符不一样。char的行结束符是 \0,binary的行结束符是 0x00。

由于是二进制存储,所以字符编码以及排序规则这类就直接无效了。

示例 6

来看这个 binary存取的简单示例,还是之前的变量@a。

切记!这里要提前计算好@a占用的字节数,以防存储溢出。

六、位类型

bit为 MySQL里存储比特位的类型,最大支持 64比特位,直接以二进制方式存储,一般用来存储状态类的信息。比如,性别,真假等。具有以下特性:

1.对于 bit(8)如果单纯存放 1位,左边以 0填充 00000001。2.查询时可以直接十进制来过滤数据。3.如果此字段加上索引,MySQL不会自己做类型转换,只能用二进制来过滤。

示例 7

创建表 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)

其实这样的场景,也可以定义为 char(0),这也是类似于 bit非常优化的一种用法。

mysql-(ytt/3305)->create table c2(gender char(0));Query OK, 0 rows affected(0.03 sec)

那现在我给表 c1简单的造点测试数据。

mysql-(ytt/3305)->select count(*) from c1;+----------+| count(*)|+----------+| 33554432|+----------+1 row in set(1.37 sec)

把 c1的数据全部插入 c2。

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

检索方式稍微有些不同,不过效率也差不多。所以说,字符类型不愧为万能类型。

七、枚举类型

枚举类型,也即 enum。适合提前规划好了所有已经知道的值,且未来最好不要加新值的情形。枚举类型有以下特性:

1.最大占用 2 Byte。2.最大支持 65535个不同元素。3. MySQL后台存储以下标的方式,也就是 tinyint或者 smallint的方式,下标从 1开始。4.排序时按照下标排序,而不是按照里面元素的数据类型。所以这点要格外注意。

示例 8

创建表 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)

八、集合类型

集合类型 SET和枚举类似,也是得提前知道有多少个元素。SET有以下特点:

1.最大占用 8 Byte,int64。2.内部以二进制位的方式存储,对应的下标如果以十进制来看,就分别为 1,2,4,8,...,pow(2,63)。3.最大支持 64个不同的元素,重复元素的插入,取出来直接去重。4.元素之间可以组合插入,比如下标为 1和 2的可以一起插入,直接插入 3即可。

示例 9

定义表 c7字段 c1为 set类型,包含了 8个值,也就是下表最大为 pow(2,7)。

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)

插入 1到 128的所有组合。

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

九、数据类型在存储函数中的用法

函数里除了显式声明的变量外,默认 session变量的数据类型很弱,随着给定值的不同随意转换。

示例 10

定义一个函数,返回两个给定参数的乘积。定义里有两个变量,一个是 v_tmp显式定义为 int64,另外一个@vresult随着给定值的类型随意变换类型。

简单调用下。

mysql-(ytt/3305)->select ytt_sample_data_type(1111,222)'result';+--------------------------+| result|+--------------------------+| The result is:'246642'.|+--------------------------+1 row in set(0.00 sec)

本篇把 MySQL基本的数据类型做了简单的介绍,并且用了一些容易理解的示例来梳理这些类型。我们在实际场景中,建议选择适合最合适的类型,不建议所有数据类型简单的最大化原则。比如能用 varchar(100),不用 varchar(1000)。

数据库number和关于mysql数据库里面数据类型number的问题的问题分享结束啦,以上的文章解决了您的问题吗?欢迎您下次再来哦!

电脑主机配置清单表?自己组装电脑,配置清单域名 解析(域名解析是什么意思)