当前位置:Gxlcms > 数据库问题 > MySQL学习(3)

MySQL学习(3)

时间:2021-07-01 10:21:17 帮助过:18人阅读

  •     创建数据库:create database ‘数据库名字’;
  •     使用数据库:use ‘数据库名字‘;
  •     删除数据库:drop database ‘s数据库名字‘;
  •   2.数据表级别(*)

    •     显示全部数据表:show tables;
    •     显示数据表列:desc ‘数据表名‘;
    •     创建表:create table ‘数据表名‘(nid 类型,name 类型);
    •     删除表:drop table ‘数据表名‘;
    •     清空表内容:elete from ‘数据表名‘;
    •     清空表内容:truncate table ‘数据表明‘; 速度快,自增回到原点

        create table ‘表名‘(‘Field名‘ ‘Field类型‘ ‘是否为空‘ 默认值,‘Field名‘ ‘Field类型‘ ‘是否为空‘ 默认值)engine=innodb charset=utf8;

        例:

          技术图片

        创建表tb2成功。

        create table ‘表名‘(‘Field名‘ ‘Field类型‘ ‘是否为空‘ 默认值 auto_increment primary key,‘Field名‘ ‘Field类型‘ ‘是否为空‘ 默认值)engine=innodb charset=utf8; auto_increment代表自增(只能数值类型,所引,主键,一张表只能由一个自增列),加它时后面一定要由primary key(一张表只能由一个主键,不能为NULL,一般情况下把自增列设为主键,可以两列一起作为主键,查找速度非常快

        例:

          技术图片

           技术图片

           可以看到,我只查了num的值,但是id的value是随着递增的。

        a. delete from ‘数据表‘与truncate table ‘数据表‘的区别

          (1) 用delete from tb2;清空数据表tb2后,然后重新插入两行数据,结果:

          技术图片

           可以看到id是在原来的基础上递增的。

          (2) truncate table tb2; 然后再重新插入数据,结果:

          技术图片 

           可以看到表中id列是从1开始递增了。

        b. 外键

          把两个表中的两列进行了关联,加了约束。

          (1) 创建friInfo的表:

          技术图片

            创建department的表:

          技术图片

          向department表中插入数据,显示:

          技术图片

           将friInfo表中的departmentId和department表中的id建立关联:

          技术图片

           fk_f_d是外键的名字;外键建立成功。

          我们看看能否在friInfo表中的departmentId中插入在department表id列中没有的数字,结果:

          技术图片

           提示我们不可以插入数据,那我们插入符合要求的,结果:

          技术图片

           可以看到插入成功。

          friInfo表中的departmentId列的数据只能从department中的id列选取。

          (2)可以在创建表的时候直接添加约束

          例: 

            create table department(
                id int not null auto_increment primary key,
                name varchar(20))engine=innodb default charset=utf8;
    
            create table friInfo(
                id int not null auto_increment primary key,
                name varchar(20),
                departmentId int,
                constraint fk_f_d foreign key(departmentId) referneces department(id))engine=innodb default charset=utf8;

     

      3.数据行级别(****)

    •     显示表中数据:select * from ‘数据表明‘;
    •     添加列:lter table ‘表名‘ add ‘列名’ 类型;
    •     删除列:alter table ‘表名‘ drop column ‘列名‘;
    •     修改列类型:alter table ‘表名‘ modify column ‘列名‘ 类型;
    •     修改列名和类型:alter table ‘表名‘ change ‘原列名‘ ‘新列名‘ 类型;
    •     添加主键:alter table ‘表名‘ add primary key;
    •     删除主键:alter table ‘表名‘ drop primary key;
    •     添加外键:alter table ‘主表名‘ add constraint ‘外键名‘ foreign key ‘从表名‘(‘外键字段‘) references ‘主表‘(字段‘);
    •     删除外键:alter table ‘表名‘ drop foreign key ‘外键名‘;

    二 SQL基本数据类型

      1. 数字

       (1) bit(m) 二进制位,m表示二进制位的长度,范围1~64,默认m=1

       (2) tinyint 相当于c++中的int8类型,默认是有符号的,创建无符号:tinyint unsigned;注意:布尔类型用 tinyint(1)表示

       (3) smallint 相当于c++中的int16类型;

       (4) int 相当于c++中的int32类型;

       (5) bigint 相当于c++中的int64类型;

       (6) decimal(m[,d]) 精确的小数,m是数字总个数(负号不算),最大值65,d是小数点后个数,最大值30;

       (7) float(m,d) 单浮点数,m是数字总个数,d是小数点后数字个数;数值越大越不准确;

       (8) double(m,d) 双浮点数,m是数字总个数,d是小数点后数字个数;数值越大越不准确;

      2.字符串

       (1) char(m) 固定长度的字符串,最大长度255字符,m代表字符串长度,即使数据小于m,也会占用m个字符;

       (2) varchar(m) 可变长度的字符串,最大长度255字符,m代表字符串长度,只要小于m长度的字符串都可以保存在数据类型中;相比于char类型效率较低;

       (3) text 保存变长的大字符串,最大长度65535个字符;

       (4) mediumtext 保存变长的大字符串,最大长度16777215个字符;

       (5) longtext 保存变长的大字符串,最大长度4294967295个字符;

       (6) TinyBlog、Blog、MediumBlog、LongBlog 二进制数据;

      3.时间

       (1) date: YYYY-MM-DD;

       (2) time: HH:MM:SS;

       (3) datetime:  YYYY-MM-DD HH:MM:SS;

       (4) year: YYYY;

       (5) timestamp: YYYYMMDD HHMMSS;

      4.枚举

       相当于c++中的枚举。

       用法:

          create table studentInfo(
              name varchar(20),
              age int,
              class ENUM(‘class1‘, ‘class2‘, ‘class3‘)
          )engine=innodb default charset=utf8;
          
          insert into studentInfo(name,age,class) values(‘a‘,19,‘class1‘),(
    ‘b‘,20,‘class2‘),(‘c‘,21,‘class3‘);

      5.集合

       可以设置多个值。

       用法:

          create table teacher(
              name varchar(20),
              course SET(‘math‘, ‘sports‘, ‘english‘)
          )engine=innodb default charset=utf8;
    
          insert into teacher(name,course) values(‘a‘, (‘math‘, ‘sports‘)), (‘b‘, (‘english‘, ‘sports‘)), (‘c‘, (‘math‘, ‘english‘));

     

    MySQL学习(3)

    标签:多个   添加   math   truncate   建立   数据表   inf   的区别   show   

    人气教程排行