• mysql(2)


    mysql的引擎:

      InnoDB:特点是行锁设计、支持外键,并支持类似 Oracle 的非锁定读,即默认读取操作不会产生锁。在mysql5.5.8以上默认储存引擎

      myisam:不支持事务、表锁设计、支持全文索引,主要面向一些 OLAP 数 据库应用,在 MySQL 5.5.8 版本之前是默认的存储引擎(除 Windows   版本外)。

      memory:内存中的引擎,

      blackhole:黑洞引擎

      指定表类的引擎:create table user(id int)engine=innodb;

      

    #.frm是存储数据表的框架结构
    
    # .ibd是mysql数据文件 
    
    #.MYD是MyISAM表的数据文件的扩展名
    
    #.MYI是MyISAM表的索引的扩展名
    
    #发现后两种存储引擎只有表结构,无数据
    
    #memory,在重启mysql或者重启机器后,表内数据清空
    #blackhole,往表内插入任何数据,都相当于丢入黑洞,表内永远不存记录
    

    复制mysql的表:create table user select * from db2.a1;必须指定详细的目录

    整型:tinyinit int bigint 作用:存储年龄 ,等级 id 各种号码    [unsigned] [zerofill]加这两个 前者为符号的有无,默认为无 后者为可见的位数,

    tinyint:小整数

      有符号:-128 到 127

      没有符号:0到225

    int:保存一定数据范围内的数值,后边括号里的值是查看的位数

       有符号:
                        -2147483648 ~ 2147483647
                无符号:
                        0 ~ 4294967295

    bigint:大数据的

      有符号:
                        -9223372036854775808 ~ 9223372036854775807
                无符号:
                        0  ~  18446744073709551615

    浮点型:

      float double                            定点数类型: DEC等同于DECIMAL

       作用:存储薪资、身高、体重、体质参数等

    FLOAT[(M,D)] [UNSIGNED] [ZEROFILL]
    #参数解释:单精度浮点数(非准确小数值),M是全长,D是小数点后个数。M最大值为255,D最大值为30

    #有符号:
               -3.402823466E+38 to -1.175494351E-38,
               1.175494351E-38 to 3.402823466E+38

    #无符号:
               1.175494351E-38 to 3.402823466E+38
    #精确度:
               **** 随着小数的增多,精度变得不准确 ****


    -------------------------DOUBLE-----------------------
    DOUBLE[(M,D)] [UNSIGNED] [ZEROFILL]

    #参数解释: 双精度浮点数(非准确小数值),M是全长,D是小数点后个数。M最大值为255,D最大值为30

    #有符号:
               -1.7976931348623157E+308 to -2.2250738585072014E-308
               2.2250738585072014E-308 to 1.7976931348623157E+308

    #无符号:
               2.2250738585072014E-308 to 1.7976931348623157E+308

    #精确度:
               ****随着小数的增多,精度比float要高,但也会变得不准确 ****

    ======================================
    --------------------DECIMAL------------------------
    decimal[(m[,d])] [unsigned] [zerofill]

    #参数解释:准确的小数值,M是整数部分总个数(负号不算),D是小数点后个数。 M最大值为65,D最大值为30。


    #精确度:
               **** 随着小数的增多,精度始终准确 ****
               对于精确数值计算时需要用此类型
               decaimal能够存储精确值的原因在于其内部按照字符串存储。

     时间:

    year data time datatime

    现在的时间now()函数

    了解 timestamp

    在写的时候注意是字符串:(1,'alex',"1995","1995-11-11","11:11:11","2017-11-11 11:11:11"),

    字符类型:

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

      字符长度范围:0-255(一个中文是一个字符,是utf8编码的3个字节)
        存储:
            存储char类型的值时,会往右填充空格来满足长度
            例如:指定长度为10,存>10个字符则报错,存<10个字符则用空格填充直到凑够10个字符存储
     varchar:变长,精准,节省空间,存取速度慢;空格算字符

      符长度范围:0-65535(如果大于21845会提示用其他类型 。mysql行最大限制为65535字节,字符编码为utf-8:https://dev.mysql.com/doc/refman/5.7/en/column-count-limit.html)
        存储:
            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)

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

    函数:length()查看字节数 char_length()查看字符数

    常用操作:select x,char_length(x),y,char_length(y) from t1; 字符和字节长度

         mysql> SET sql_mode = 'PAD_CHAR_TO_FULL_LENGTH';现原形

        select @@sql_mode;  查看当前的模式

    太长不够的话使用text6万多字

            longtext

    枚举和集合

      单选 enum

      多选 set

      mysql> create table t4(
        ->  id int,
        -> name varchar(50),
        ->  sex enum('male','female'),
        ->  fav set('play','read'));

    完整约束性:
      not null 不是空 default 默认值是自己定义

      unique单列不能重复

      联合唯一 两者都不一样
       
        create table dep2(
           id int unique,
           name char(6) unique
        
        );
        
        
        create table dep2(
           id int,
           name char(6),
           unique(id),
           unique(name)
        
        );
        
        
        组合唯一 其中有一个一样
        create table dep3(
           id int,
           name char(6),
           unique(id,name)
        
        );

      primary key: 单行做做主列  多列做主键(复合主键)  

            等价于 not null unique 每个表必须有一张主键

      auto_increment 自增

           #全局设置步长 都有效。
              set global auto_increment_increment=5;

          # 设置起始偏移量
              set global  auto_increment_offset=3;

      

      delete from t1; #如果有自增id,新增的数据,仍然是以删除前的最后一样作为起始。

      truncate table t1;数据量大,删除速度比上一条快,且直接从零开始。

    primary key(主键);

      单列主键

        create table t3(
         id int primary key,
         name char(6) not null
        
        );

      多列主键:

        create table t4(
         id int ,
         name char(6),
         primary key(id),
         primary key(name)
        );

      #复合主键
        
        create table t5(
         id int,
         name char(6),
         primary key(id,name)
        
        );

      foreign key(外键)

      1,先创建被关联表(主表);共性的先创建

      create table dep(
        id int primary key auto_increment,
        name varchar(10) not null,
        descripe varchar(40) not null
       );

      2,再创建 关联表(从表);注意最后的,号.

      create table emp(
        id int primary key auto_increment,
        name varchar(10) not null,
        age int not null,
        dep_id int,
        test_id int,
        constraint fk_dep foreign key(dep_id) references dep(id)
        on delete cascade
        on update cascade,
        constraint fk_dep foreign key(test_id) references test(id)
        on delete cascade
        on update cascade,
        
       );

      

      

  • 相关阅读:
    osg模型部分节点旋转
    IFC数据模型构件控制
    自定义基于IFC数据的施工进度数据结构
    QDateTime QString
    Qt获取屏幕分辨率
    Qt自定义类重写 copy
    removeEntry
    initGanttView
    IfcAxis2Placement3D IFC构件的位置和方向
    致我最爱的你
  • 原文地址:https://www.cnblogs.com/lnrick/p/9556273.html
Copyright © 2020-2023  润新知