>  기사  >  데이터 베이스  >  mysql 데이터 유형 예제 분석

mysql 데이터 유형 예제 분석

PHPz
PHPz앞으로
2023-06-01 23:38:021031검색

정수형

숫자 데이터 유형은 주로 숫자를 저장하는 데 사용됩니다. mysql은 다양한 숫자 데이터 유형을 제공합니다. 데이터 유형에 따라 저장할 수 있는 값 범위가 더 커집니다. 필요한 저장 공간도 더 커질 것입니다. mysql提供了多种数值数据类型,不同的数据类型提供不同的取值范围,可以存储的值范围越大,其所需要的存储空间也会越大。

mysql主要提供的整数类型有TINYINTSMALLINTMEDIUMINTINTBIGINT。整数类型的属性字段可以添加AUTO_INCREMENT自增约束条件。

看下下面两个表;

  • 表一:mysql中的整数型数据类型

  • 表二、mysql不同整数类型的取值范围

举个例子:

year int(4);

该声明指明,在year字段中的数据一般只显示4位数字的宽度;

注意点:显示宽度和数据类型取值范围是无关的。显示宽度只是指明mysql最大可能显示的数字个数,数值的位数小于指定的宽度时会由空格填充;如果插入了大于显示宽度的值,只要该值不超过该类型整数的取值范围,数值依然可以插入,而且能够显示出来。

例如:向year字段插入一个数值12345,当使用select查询该列值的时候,mysql显示的将是完整的带有5位数字的12345,而不是4位数字的值。

其他整数型数据类型也可以在定义表结构时指定所需要的显示宽度,如果不指定,则系统为每一种类型指定默认的宽度。

不同的整数类型有不同的取值范围,并且需要不同的存储空间,因此应该根据实际需要选择最合适的类型,这样有利于提高查询的效率和节省存储空间。在现实生活中,需要使用带小数部分的数字,而整数类型不包含小数部分。下面我们就来介绍下小数类型。

注意点:显示宽度只用于显示,并不能限制取值范围和占用空间。

浮点数类型和定点数类型

mysql中使用浮点数和定点数来表示小数。

浮点数类型有两种:

  • 单精度浮点类型(FLOAT)

  • 双精度浮点类型(DOUBLE)

定点数类型只有一种:

  • DECIMAL

浮点数类型和定点数类型都可以用(M,N)来表示。其中呢,我们用M称为精度,表示总共的位数N称为标度,表示小数的位数

DECIMAL类型不同于FLOATDOUBLEDECIMAL实际是以串存放的,可能的最大取值范围和DOUBLRE一样,但是其有效的取值范围由MD的值来决定。怎么说呢?

如果改变M而固定D,则其取值范围将随着M的变大而变大。

那么在mysql中,浮点数类型和定点数类型的取值范围有多大呢?

几乎正常业务情况下是不可能用完的,因为他们的取值范围如下:

FLOAT类型的取值范围:

  • 有符号的取值范围:-3.402823466E+38 ~-1.175494351E-38

  • 无符号的取值范围:0和1.175494351E-38 ~3.402823466E+38

DOUBLE类型的取值范围:

  • 有符号的取值范围:-1.7976931348623157E+308 ~-2.2250738585072014E-308

  • 无符号的取值范围:0和2.2250738585072014E-308~ 1.7976931348623157E+308

注意点:无论是定点数还是浮点数类型,如果用户指定的精度超出精度范围,则会四舍五入。

可能有点绕,举个栗子吧:

创建一个数据表为yunweijia_1,字段类型如下;

mysql> create table yunweijia_1 (x float(5,1), y double(5,1), z decimal(5,1));
Query OK, 0 rows affected, 2 warnings (0.04 sec)
mysql>

然后我们在这个表中插入一条数据,sql语句如下:

mysql> insert into yunweijia_1 values (6.66, 7.77, 8.888);
Query OK, 1 row affected, 1 warning (0.01 sec)
mysql>

看上面的提示信息,是不是在我们执行插入语句的时候,给了一个警告信息,然后我们来看下这个警告信息是什么吧;

mysql> show warnings;
+-------+------+----------------------------------------+
| Level | Code | Message |
+-------+------+----------------------------------------+
| Note | 1265 | Data truncated for column 'z' at row 1 |
+-------+------+----------------------------------------+
1 row in set (0.00 sec)
mysql>

可以看到他提示说,z字段在插入的时候被截断了,但是xy

mysql에서 제공하는 주요 정수 유형은 TINYINT, SMALLINT, MEDIUMINT, INT 코드 >, <code>BIGINT. 정수 유형 속성 필드는 AUTO_INCREMENT 자동 증가 제약 조건을 추가할 수 있습니다.

다음 두 테이블을 살펴보세요.

🎜
  • 🎜표 1: mysql🎜
  • 의 정수 데이터 유형 >🎜표 2, 다양한 정수 유형의 mysql 값 범위🎜
🎜🎜예: 🎜🎜
🎜year int(4);🎜
🎜이 문은 연도 필드의 데이터가 일반적으로 4자리 너비만 표시함을 나타냅니다. 🎜🎜🎜참고: 🎜표시 너비 및 데이터 유형 값 범위는 관련이 없습니다. . 표시 너비는 mysql이 표시할 수 있는 최대 숫자 수만 지정합니다. 자릿수가 지정된 너비보다 작을 때, 표시 너비보다 큰 값이 있으면 공백으로 채워집니다. 삽입된 값은 유형을 초과하지 않는 한 정수 값 범위 내에서도 값을 삽입하고 표시할 수 있습니다. 🎜🎜🎜예🎜: 연도 필드에 12345 값을 삽입합니다. select를 사용하여 열 값을 쿼리하는 경우 mysql 4자리 값 대신 전체 5자리 12345가 표시됩니다. 🎜🎜다른 정수 데이터 유형도 테이블 구조를 정의할 때 필요한 표시 너비를 지정할 수 있습니다. 지정하지 않으면 시스템에서 각 유형에 대한 기본 너비를 지정합니다. 🎜🎜다양한 정수 유형은 서로 다른 값 범위를 가지며 서로 다른 저장 공간을 필요로 하므로 실제 요구 사항에 따라 가장 적합한 유형을 선택해야 합니다. 이렇게 하면 쿼리 효율성이 향상되고 저장 공간이 절약됩니다. 실제 생활에서는 소수 부분이 있는 숫자를 사용해야 하며, 정수형에는 소수 부분이 포함되어 있지 않습니다. 다음으로 십진수 유형을 소개하겠습니다. 🎜
🎜🎜참고: 🎜표시 너비는 표시에만 사용되며 값 범위와 점유 공간을 제한할 수 없습니다. 🎜
🎜부동소수점수형과 고정소수점수형🎜🎜부동소수점수와 고정소수점수는 mysql에서 소수를 표현하는데 사용됩니다. 🎜🎜🎜부동 소수점 숫자에는 두 가지 유형이 있습니다. 🎜🎜
  • 🎜단정밀도 부동 소수점 유형(FLOAT) 🎜
  • 🎜이중 정밀도 부동 포인트 유형(DOUBLE) 🎜
🎜🎜고정 소수점 유형은 하나만 있습니다: 🎜🎜
  • 🎜DECIMAL🎜
  • 🎜 부동 소수점 유형과 고정 소수점 유형 모두 (M, N)으로 표현할 수 있습니다. 그중 M을 🎜precision🎜으로 사용하는데, 이는 🎜의 전체 자릿수를 나타내며, N은 소수 자릿수를 나타내는 🎜scale🎜이라고 합니다. . 🎜🎜DECIMAL 유형은 FLOATDOUBLE과 다릅니다. DECIMAL은 실제로 최대값으로 저장됩니다. 가능 값 범위는 DOUBLRE와 동일하지만 유효한 값 범위는 MD 값에 따라 결정됩니다. 어떻게 말할까? 🎜🎜M을 변경하고 D를 고정한 경우 M이 커질수록 값 범위도 커집니다. 🎜

    그럼 MySQL에서는 부동소수점형과 고정소수점형의 값 범위는 어떻게 되나요?

    🎜🎜값 범위는 🎜🎜🎜FLOAT 유형 🎜값 범위: 🎜🎜
    • 🎜🎜부호 있는 값 범위: 🎜-3.402823466E+38 ~-1.175494351E-38🎜
    • 🎜🎜부호 없는 값 범위: 🎜 0 및 1.175494351E-38 ~ 3.402823466E+38🎜
    🎜DOUBLE 유형 🎜값 범위: 🎜🎜
    • 🎜🎜서명된 값 범위: 🎜-1.7976931348623157E+308 ~-2.2250738585072014E-308🎜
    • 🎜🎜부호 없는 값 범위: 🎜0 및 2.2250738585072014E-3 08~ 1.797693134 8623157 E+308🎜
    🎜🎜참고: 🎜고정 소수점 숫자이든 부동 소수점 숫자 유형이든 사용자가 지정한 정밀도가 정밀도 범위를 초과하면 반올림됩니다. 🎜🎜🎜은 다소 복잡할 수 있습니다. 예를 들어보겠습니다. 🎜🎜🎜 yunweijia_1로 데이터 테이블을 생성하고 필드 유형 🎜은 다음과 같습니다. 🎜🎜
    mysql> create table yunweijia_2 (y year);
    Query OK, 0 rows affected (0.04 sec)
    mysql>
    🎜그런 다음 삽입합니다. 이 테이블의 행 데이터, sql 문 🎜은 다음과 같습니다. 🎜🎜
    mysql> insert into yunweijia_2 values(2022), (&#39;2022&#39;);
    Query OK, 2 rows affected (0.01 sec)
    Records: 2 Duplicates: 0 Warnings: 0
    mysql>
    🎜위 프롬프트 메시지를 보면 insert 문을 실행할 때 경고 메시지가 나오는지 살펴보겠습니다. 이 경고 메시지는 맞습니다. 🎜
    mysql> insert into yunweijia_2 values (&#39;2166&#39;);
    ERROR 1264 (22003): Out of range value for column &#39;y&#39; at row 1
    mysql>
    🎜 z 필드는 삽입 시 잘렸지만 xy 필드가 잘리지 않았습니다. 🎜🎜🎜그런 다음 결과를 확인하세요.🎜🎜<blockquote><p>mysql> select * from yunweijia_1;<br>+------+------+------+<br>| x | y | z |<br>+------+------+------+<br>| 6.7 | 7.8 | 8.9 |<br>+------+------+------+<br>1 row in set (0.00 sec)<br>mysql></p></blockquote> <p>可以看到分别都进行了<strong>四舍五入</strong>,这点需要注意。</p> <p><code>FLOATDOUBLE在不指定精度操作时,默认会按照实际的精度(由计算机硬件和操作系统决定),DECIMAL若不指定精度则默认为(10,0);

    浮点数相对于定点数的优点是在长度一定的情况下,浮点数能够表示更大的数据范围;他的缺点是会引起精度问题;

    注意点:在mysql中,定点数以字符串形式存储,在对精度要求比较高的时候,使用DECIMAL的类型比较好,另外,两个浮点数进行减法和比较运算时,容易出现问题,所以在使用浮点数时需要注意,并尽量避免做浮点数比较。

    日期与时间类型

    mysql中有多种表示日期的数据类型,主要有:

    • DATETIME

    • DATE

    • TIMESTAMP

    • TIME

    • YEAR

    比如说,当只记录年信息的时候,可以只使用YEAR类型,而没有必要使用DATE

    每一个类型都有合法的取值范围,当指定确实不合法的值时系统将“零”值插入到数据库中。

    YEAR

    year类型是一个单字节类型,用于表示年,在存储时只需要1字节。可以使用各种格式指定year值,如下:

    • 1、以4位字符串或者4位数字格式表示的year,范围为1901~2155。输入格式为yyyy或者'yyyy',例如:输入‘2022’或者2022,插入到数据库的值均为2022。

    • 2、以2位字符串格式表示的year,范围为“00”到“99”。“00”~“69”和“70”~“99”范围的值分别被转换为“2022”~“2069”和“1970”~“1999”范围的year值。“0”与“00”的作用相同。插入超过取值范围的值将被转换成2000

    • 3、以两位数字表示的YEAR,范围为1~99。1~69和70~99范围的值分别被转换为200·~2069和1970~1999范围的YEAR

    值。和字符相比较而言,这里的0值,将被转换成0000,而不是2000。

    注意点:

    两位整数范围与两位字符串范围稍有不同。例如,插入2000年,有人可能会使用数字格式的0表示year,实际上,插入数据库的值为0000,而不是所希望的2000。只有使用字符串格式的“0”或者“00”,才可以被正确的解释为2000,。非法YEAR值将被转换为0000。

    栗子:

    我们创建一个名为yunweijia_2的数据表,使用以下sql语句:

    mysql> create table yunweijia_2 (y year);
    Query OK, 0 rows affected (0.04 sec)
    mysql>

    然后我们往表中插入一条数据;

    mysql> insert into yunweijia_2 values(2022), (&#39;2022&#39;);
    Query OK, 2 rows affected (0.01 sec)
    Records: 2 Duplicates: 0 Warnings: 0
    mysql>

    再次尝试插入一条数据;

    mysql> insert into yunweijia_2 values (&#39;2166&#39;);
    ERROR 1264 (22003): Out of range value for column &#39;y&#39; at row 1
    mysql>

    我们发现‘2166’超出了YEAR类型的取值范围,所以不能插入数据,这个时候我们看下mysql数据库中的数据;

    mysql> select * from yunweijia_2;
    +------+
    | y |
    +------+
    | 2022 |
    | 2022 |
    +------+
    2 rows in set (0.00 sec)
    mysql>

    栗子:

    首先我们先删除yunweijia_2数据表中的数据;

    mysql> delete from yunweijia_2;
    Query OK, 2 rows affected (0.01 sec)
    mysql>

    可以看到提示删除了两条数据;

    然后我们再插入以下数据;

    mysql> insert into yunweijia_2 values (&#39;0&#39;), (&#39;00&#39;), (&#39;88&#39;), (&#39;22&#39;);
    Query OK, 4 rows affected (0.01 sec)
    Records: 4 Duplicates: 0 Warnings: 0
    mysql>

    然后看下结果是什么:

    mysql> select * from yunweijia_2;
    +------+
    | y |
    +------+
    | 2000 |
    | 2000 |
    | 1988 |
    | 2022 |
    +------+
    4 rows in set (0.00 sec)
    mysql>

    从上面i看到,字符串‘0’和‘00’的作用相同,分别都转换成了2000年;‘88’转换成了‘1988’;‘22’转换成了‘2022’。

    栗子:

    老规矩,先删除表中现有的数据;

    mysql> delete from yunweijia_2;
    Query OK, 4 rows affected (0.01 sec)
    mysql>

    然后再插入数据:

    mysql> insert into yunweijia_2 values (0), (99), (22);
    Query OK, 3 rows affected (0.01 sec)
    Records: 3 Duplicates: 0 Warnings: 0
    mysql>

    看下结果:

    mysql> select * from yunweijia_2;
    +------+
    | y |
    +------+
    | 0000 |
    | 1999 |
    | 2022 |
    +------+
    3 rows in set (0.00 sec)
    mysql>

    可以看到,0被转换成了0000,99被转换成了1999,22被转换成了2022。

    TIME

    time类型用在只需要时间信息的值,在存储时需要3字节,格式为HH:MM:SS

    其中,HH表示小时,MM表示分钟,SS表示秒。

    mysqltime类型的取值范围为-838:59:59~838:59:598,小时部分为什么会这么大呢,这是因为time类型不仅可以用来表示一天的时间,还可能是某个事件过去的时间或者两个事件之间的时间间隔。

    (1)‘D HH:MM:S’格式的字符串,可以使用下面任何一种“非严格”的语法:

    • ‘HH:MM:SS’

    • ‘HH:MM’

    • ‘D HH:MM’

    这里的D表示日,可以取0~34的值,在插入数据库时,D被转换成小时保存,格式为“D*24+HH”;

    (2)‘HH:MM:SS’格式的、没有间隔符的字符串或者HHMMSS格式的数值,假定是有意义的时间。例如:'223344'被理解成‘22:33:44’,但是‘223366’是不合法的(他有一个没有意义的秒部分),存储时将变成00:00:00。

    注意点:

    time列分配简写时应该注意,如果没有冒号,mysql解释值时,假定最右边的两位表示秒。如果time值中使用了冒号,则肯定被单做是当天的时间。

    例如:

    11:22 会被mysql解释成 00:11:22

    '11:22'会被mysql解释成11:22:00

    栗子

    创建一个名为yunweijia_3的数据表;

    mysql> create table yunweijia_3(t time);
    Query OK, 0 rows affected (0.03 sec)
    mysql>

    往这个表中插入数据:

    mysql> insert into yunweijia_3 values (&#39;10:06:06&#39;), (&#39;22:22&#39;), (&#39;2 10:10&#39;), (&#39;3 00&#39;), (&#39;20&#39;);
    Query OK, 5 rows affected (0.01 sec)
    Records: 5 Duplicates: 0 Warnings: 0
    mysql>

    看下表中的数据:

    mysql> select * from yunweijia_3;
    +----------+
    | t |
    +----------+
    | 10:06:06 |
    | 22:22:00 |
    | 58:10:00 |
    | 72:00:00 |
    | 00:00:20 |
    +----------+
    5 rows in set (0.00 sec)
    mysql>

    小提示:在使用‘D HH’格式时,小时一定要使用双位数值,如果是小于10的小时数,应在前面加0以用来补全双位数值。

    举个栗子 :

    首先我们删除数据表yunweijia_3里面的数据;

    mysql> delete from yunweijia_3;
    Query OK, 5 rows affected (0.01 sec)
    mysql>

    然后再表中插入数据:

    mysql> insert into yunweijia_3 values (&#39;101112&#39;), (111213), (&#39;0&#39;);
    Query OK, 3 rows affected (0.01 sec)
    Records: 3 Duplicates: 0 Warnings: 0
    mysql>

    再次向表中插入一条数据;

    mysql> insert into yunweijia_3 values (107010);
    ERROR 1292 (22007): Incorrect time value: &#39;107010&#39; for column &#39;t&#39; at row 1
    mysql>

    可以看到这条数据没有插入成功,我看看下提示信息;

    mysql> show warnings;
    +-------+------+--------------------------------------------------------+
    | Level | Code | Message |
    +-------+------+--------------------------------------------------------+
    | Error | 1292 | Incorrect time value: &#39;107010&#39; for column &#39;t&#39; at row 1 |
    +-------+------+--------------------------------------------------------+
    1 row in set (0.00 sec)
    mysql>

    为什么这次会插入失败呢,是不是因为我们的分钟应该是小于60的啊,但是这里是70,所以报错了。

    我们查看下这个数据库中的数据现在的展示吧:

    mysql> select * from yunweijia_3;
    +----------+
    | t |
    +----------+
    | 10:11:12 |
    | 11:12:13 |
    | 00:00:00 |
    +----------+
    3 rows in set (0.00 sec)
    mysql>

    又举个栗子:

    我们还可以使用系统函数向time字段列插入值;

    删除数据表yunweijia_3里面的数据;

    mysql> delete from yunweijia_3;
    Query OK, 3 rows affected (0.01 sec)
    mysql>

    然后在表中插入数据;

    mysql> insert into yunweijia_3 values (CURRENT_TIME), (NOW());
    Query OK, 2 rows affected (0.01 sec)
    Records: 2 Duplicates: 0 Warnings: 0
    mysql>

    查看下数据库中的结果;

    mysql> select * from yunweijia_3;
    +----------+
    | t |
    +----------+
    | 23:03:41 |
    | 23:03:41 |
    +----------+
    2 rows in set (0.00 sec)

    mysql>

    从结果中可以看到,获取系统当前的日志插入到time类型的列中。

위 내용은 mysql 데이터 유형 예제 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 yisu.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제