zoukankan      html  css  js  c++  java
  • mysql 表的操作

    mysql 表格式

    语法:
      create table 表名(

      字段名1 类型[(宽度) 约束条件],

      字段名2 类型[(宽度) 约束条件],

      字段名3 类型[(宽度) 约束条件]

      );

    注意:
      1. 在同一张表中,字段名是不能相同
      2. 宽度和约束条件可选
      3. 字段名和类型是必须的

    表的数据类型

    整数类型:TINYINT SMALLINT MEDIUMINT INT BIGINT

    为该类型指定宽度时,仅仅只是指定查询结果的显示宽度,与存储范围无关,存储范围如下其实我们完全没必要为整数类型指定显示宽度,使用默认的就可以了默认的显示宽度,都是在最大值的基础上加1

    浮点类型:FLOAT DOUBLE

    类型大小范围(有符号)范围(无符号)用途
    TINYINT 1 字节 (-128,127) (0,255) 小整数值
    SMALLINT 2 字节 (-32 768,32 767) (0,65 535) 大整数值
    MEDIUMINT 3 字节 (-8 388 608,8 388 607) (0,16 777 215) 大整数值
    INT或INTEGER 4 字节 (-2 147 483 648,2 147 483 647) (0,4 294 967 295) 大整数值
    BIGINT 8 字节 (-9 233 372 036 854 775 808,9 223 372 036 854 775 807) (0,18 446 744 073 709 551 615) 极大整数值
    FLOAT 4 字节 (-3.402 823 466 E+38,-1.175 494 351 E-38),0,(1.175 494 351 E-38,3.402 823 466 351 E+38) 0,(1.175 494 351 E-38,3.402 823 466 E+38) 单精度
    浮点数值
    DOUBLE 8 字节 (-1.797 693 134 862 315 7 E+308,-2.225 073 858 507 201 4 E-308),0,(2.225 073 858 507 201 4 E-308,1.797 693 134 862 315 7 E+308) 0,(2.225 073 858 507 201 4 E-308,1.797 693 134 862 315 7 E+308) 双精度
    浮点数值
    DECIMAL 对DECIMAL(M,D) ,如果M>D,为M+2否则为D+2 依赖于M和D的值 依赖于M和D的值 小数值

    日期类型

      表示时间值的日期和时间类型为DATETIME、DATE、TIMESTAMP、TIME和YEAR。

    类型大小
    (字节)
    范围格式用途
    DATE 3 1000-01-01/9999-12-31 YYYY-MM-DD 日期值
    TIME 3 '-838:59:59'/'838:59:59' HH:MM:SS 时间值或持续时间
    YEAR 1 1901/2155 YYYY 年份值
    DATETIME 8 1000-01-01 00:00:00/9999-12-31 23:59:59 YYYY-MM-DD HH:MM:SS 混合日期和时间值
    TIMESTAMP 4

    1970-01-01 00:00:00/2038

    结束时间是第 2147483647 秒,北京时间 2038-1-19 11:14:07,格林尼治时间 2038年1月19日 凌晨 03:14:07

    YYYYMMDD HHMMSS 混合日期和时间值,时间戳

    字符串类型

      指CHAR、VARCHAR

      注意:char和varchar括号内的参数指的都是字符的长度

    char类型:定长,简单粗暴,浪费空间,存取速度快

    字符长度范围:0-255(一个中文是一个字符,是utf8编码的3个字节)

    存储:

    存储char类型的值时,会往右填充空格来满足长度

    例如:指定长度为10,存>10个字符则报错,存<10个字符则用空格填充直到凑够10个字符存储

    检索:

    在检索或者说查询时,查出的结果会自动删除尾部的空格,除非我们打开pad_char_to_full_length SQL模式

    varchar类型:变长,精准,节省空间,存取速度慢

    字符长度范围:0-65535(如果大于21845会提示用其他类型 。mysql行最大限制为65535字节,字符编码为utf-8

    存储:
    varchar类型存储数据的真实内容,不会用空格填充,如果'ab ',尾部的空格也会被存起来

    强调:varchar类型会在真实数据前加1-2Bytes的前缀,该前缀用来表示真实数据的bytes字节数(1-2Bytes最大表示65535个数字,正好符合mysql对

    row的最大字节限制,即已经足够使用)

    如果真实的数据<255bytes则需要1Bytes的前缀(1Bytes=8bit 2**8最大表示的数字为255)

    如果真实的数据>255bytes则需要2Bytes的前缀(2Bytes=16bit 2**16最大表示的数字为65535)

    检索:

    尾部有空格会保存下来,在检索或者说查询时,也会正常显示包含空格在内的内容

    枚举类型与集合类型

    字段的值只能在给定范围中选择,如单选框,多选框

    enum 单选 只能在给定的范围内选一个值,如性别 sex 男male/女female

    set 多选 在给定的范围内可以选择一个或一个以上的值(爱好1,爱好2,爱好3...)

     完整性约束

    not null - 不可空  defalut 默认值为

    unqiue  唯一性 

    联合唯一:create table service(id int primary key auto_increment,name varchar(20),host varchar(15) not null,port int not null,unique(host,port));

     

    primary key:单单从约束角度去看,primary key就等同于not null unique
    强调(******)
      1、一张表中必须有,并且只能有一个主键
      2、一张表中都应该有一个id字段,而且应该把id字段做成主键

    联合主键  create table t19(ip char(15),port int,primary key(ip,port));
     

     

  • 相关阅读:
    Netflix Ribbon(负载均衡)介绍
    Annotation 注解
    框架设计的灵魂-反射
    idea maven java.lang.outofmemoryerror gc overhead limit exceeded
    洛谷P4427 [BJOI2018]求和
    洛谷P1196 [NOI2002]银河英雄传说
    CF191C Fools and Roads
    洛谷P2296 寻找道路
    洛谷P3389 【模板】高斯消元法
    洛谷P1351 联合权值
  • 原文地址:https://www.cnblogs.com/tianyu529/p/9008288.html
Copyright © 2011-2022 走看看