MySQL学习(3)

Wesley13
• 阅读 571

一 SQL语句

  1. 数据库级别(*)

  • 显示全部数据库:show databases;
  • 创建数据库:create database '数据库名字’;
  • 使用数据库:use '数据库名字';
  • 删除数据库:drop database 's数据库名字‘;
  • 导出数据库:mysqldump -uroot -p 数据库名 > 导出文件名
  • 导入数据库:mysql -uroot -p 数据库名 < 文件路径.数据表

  2.数据表级别(*)

  •     显示全部数据表:show tables;
  •     显示数据表列:desc '数据表名';
  •     创建表:create table '数据表名'(nid 类型,name 类型);
  •     删除表:drop table '数据表名';
  •     清空表内容:elete from '数据表名';
  •     清空表内容:truncate table '数据表明'; 速度快,自增回到原点;
  •     添加列: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 '外键名';

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

    例:

      MySQL学习(3)

    创建表tb2成功。

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

    例:

      MySQL学习(3)

       MySQL学习(3)

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

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

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

      MySQL学习(3)

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

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

      MySQL学习(3)  

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

    b. 外键

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

      (1) 创建friInfo的表:

      MySQL学习(3)

        创建department的表:

      MySQL学习(3)

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

      MySQL学习(3)

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

      MySQL学习(3)

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

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

      MySQL学习(3)

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

      MySQL学习(3)

       可以看到插入成功。

      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.数据行级别(****)

    增:a. insert into '表名'('列名','列名') values('值','值'),('值','值'), ('值','值'); 一次插入多条数据;

      b. insert into '表名'('列名','列名') select '列名','列名' from '表名'; 把另一个表的两列中的数据插入到表的列中;

    删:delete from  '表名' where '列名'='值'; 将某一列中某一值的一行数据删掉; '列名'>'值',  '列名'<值',  '列名'!='值' 都可以;

    改:update '表名' set '列名1'='值1' where '列名2'='值2' and ...; 把'列名2'='值2的'列名1'的值改为'值1';

    查:select  '列名1', '列名2' from '数据表名' where '列名'='值'; 显示表中'列名'='值'的那行中 '列名1'和'列名2'数据;

    其他:条件,通配符,限制,排序,分组,连表,组合。参考https://www.cnblogs.com/wupeiqi/articles/5713315.html

二 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'));
点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
待兔 待兔
3个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Stella981 Stella981
3年前
Python3:sqlalchemy对mysql数据库操作,非sql语句
Python3:sqlalchemy对mysql数据库操作,非sql语句python3authorlizmdatetime2018020110:00:00coding:utf8'''
Stella981 Stella981
3年前
Django之Django模板
1、问:html页面从数据库中读出DateTimeField字段时,显示的时间格式和数据库中存放的格式不一致,比如数据库字段内容为2012082616:00:00,但是页面显示的却是Aug.26,2012,4p.m.答:为了页面和数据库中显示一致,需要在页面格式化时间,需要添加<td{{dayrecord.p\_time|date:
Stella981 Stella981
3年前
KVM调整cpu和内存
一.修改kvm虚拟机的配置1、virsheditcentos7找到“memory”和“vcpu”标签,将<namecentos7</name<uuid2220a6d1a36a4fbb8523e078b3dfe795</uuid
Easter79 Easter79
3年前
Twitter的分布式自增ID算法snowflake (Java版)
概述分布式系统中,有一些需要使用全局唯一ID的场景,这种时候为了防止ID冲突可以使用36位的UUID,但是UUID有一些缺点,首先他相对比较长,另外UUID一般是无序的。有些时候我们希望能使用一种简单一些的ID,并且希望ID能够按照时间有序生成。而twitter的snowflake解决了这种需求,最初Twitter把存储系统从MySQL迁移
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
9个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这