前  言

 mysql 

 mysql语法--本篇学习都是通过使用Navicat Premium(数据库管理工具),连接mysql数据.

本篇学习主要有两个部分:

     一、创建用户,创建数据库,给用户分配权限,删除用户权限。

     二、MYSQL中常见的数据类型

   三、表-创建表、主键、外键

     四、数据库设计的三大范式

以下所有代码全部在新建查询表里面使用mysql语法编辑。

1、创建用户,创建数据库,给用户分配权限,删除用户权限。
/* SQL 多行注释 */
-- SQL 单行注释

创建用户:CREATE USER '用户名'@'主机名' IDENTIFIED BY '密码';
      主机名可以为空,为空默认为%权限,表示所有主机可连接。
给用户分配权限: GRANT 权限名 ON 数据库名.表明 TO 用户名@主机名         
删除用户权限:    REVOKE 权限名 ON 数据库名.表明 FROM 用户名@主机名;
创建数据库: CREATE DATABASE [IF NOT EXISTS] 数据库名[CHARACTER SET[=] 'UTF8'];
     <<<如果省略 [IF NOT EXISTS] 在重复创建数据库时,会报错!
查询本机中所有的数据库:SHOW DATABASES

↓使用mydb这个数据库↓,表示下面的查询都将默认针对mydb数据库
USE mydb;
查询数据库中所有数据表: SHOW TABLES [FROM 数据库]

2  MYSQL中常见的数据类型
   
一、字符型:

   ① CHAR(N):固定N个字符长度的字符串,如果长度不够会自动空格补齐;
      ② VARCHAR(N):存储可边长度的字符节。常用的 0~255;
      ③ TEXT:存储可变长度的字符串。(常用语发布文章等大段内容)0~((2^16-1)*10^2);
      ④ TINYTEXT:0~((2^8-1)*10);
      ⑤ MEDIUMTEXT:0~((2^24-1)*10^3);
      ⑥ LINGTEXT:0~((2^32-1)*10^4);
      ⑦ enum("男","女"):枚举类型,字段只能容纳枚举出的数据。

二、整形:
    
    ① TINYINT:         无符号0~2^8-1  有符号 -2^7~2^7-1;
    ② SMALLINT:    无符号0~2^16-1 有符号 -2^15~2^15-1;
    ③ MEDIUMINT:   无符号0~2^24-1 有符号 -2^23~2^23-1;
    ④ INT:             无符号0~2^32-1 有符号 -2^31~2^31-1 最常用!
    ⑤ BIGINT:      无符号0~2^64-1 有符号 -2^63~2^63-1;

三、浮点型:

① FLOAT:  可以精确到小数点后7位有效数字;
    ② DOUBLE:  可以精确到小数点后15位到16位有效数字;

四、日期时间数据类型
    
    注意:由于时间存储使用字符串或者时间戳存储,所以数据库中几乎不用日期类型。
    ① DATE:存储日期和时间数据
    ② TIMESTAMP:比DATE更精确

3、表-创建表、主键、外键
   
 【创建表】:

  CREATE TABLE [IF NOT EXISTS] 表单名(
  IF NOT EXISTS 可以省略,省略后重复创建报错.如果不省略,则创建时会检测表是否已存在,如果表存在则不再执行创建语句
  定义列:列名 数据类型 列表关键字
  )
  常用的列定义关键字:
          ① UNSIGNED: 设置列表为无符号列。只能设置类型为数字类型的列
          ② AUTO_INCREMENT PRIMARY KEY 设置列为自动增长列。自动增长列必须是主键。
          ③ NOT null:设置列为非空约束
          ④ UNIQUE:设置唯一性约束。该字段不能出现重复值。
          ⑤ DEFAULT: 设置默认值约束。

【主键】:

    1、主键的注意事项?  主键默认为空!主键默认唯一性约束!
                                             只有主键才能设置自动增长(主键不一定自动增长,自动增长必须是主键)
                                            
      2、设置主键的方式?  
              ① 在列定义是设置: age SMALLINT(3) PRIMARY KEY,
              ② 在列定义完成后设置:  PRIMARY KEY(age),
    
 【外键】    
      1、设置外键有哪些注意事项
          ① 只有innodb的数据库引擎支持外键,修改mysql.ini文件:default-storage-engine=INNODB
          ② 外键与参照列的数据类型必须相同。(数值型要求长度和无符号都相同,字符串要求类型相同,长度可以不同。)
          ③ 设置外键的字段必须要有索引。如果没有索引,设置外键时会自动生成一个索引。

   2、设置外键的语法?
          [CONSTRAINT 外键名] FOREIGN KEY (外键字段) REFERENCES 参照表(参照字段) [ON DELETE SET NULL on update CASCADE]-- 设置参照完整性
     

   3、外键约束的参照完整性操作?
          参照操作:当对参照表的参照字段进行删除或者更新是,外键表中的外键如何应对。
          参照操作可选值:restrict 拒绝参照表删除或更新参照字段;(默认)
                                          NO ACTION 与 restrict一样,但这个指令只在mysql生效;
                                          cascade 删除或更新参照表的参照字段时,外键表的记录同步删除或更新;(外键表和参照表同步)
                                          set null 删除或更新参照表的参照字段时,外键表的外键设为null;
  
         

CREATE TABLE IF NOT EXISTS tb1(
-- IF NOT EXISTS 可以省略,省略后重复创建报错.如果不省略,则创建时会检测表是否已存在,如果表存在则不再执行创建语句
id INT(3),
`name` VARCHAR(255) NOT null, -- name是系统关键字,所以使用反引号``包裹
age SMALLINT(3) AUTO_INCREMENT PRIMARY KEY,
lalala INT UNIQUE,
height DOUBLE(3,2) DEFAULT 1.2 -- 设置默认值约束:默认值为1.2
-- PRIMARY KEY(age)
); create table if not exists classes(
id INT UNSIGNED AUTO_INCREMENT PRIMARY KEY,
classname VARCHAR(255) NOT NULL ); CREATE table if not EXISTS `user`(
id INT UNSIGNED AUTO_INCREMENT PRIMARY KEY,
clsId INT UNSIGNED,
`name` VARCHAR(255) NOT NULL,
CONSTRAINT user_fk_classes FOREIGN KEY (clsid) REFERENCES classes(id) ON DELETE SET NULL on update CASCADE
)
-- auto_increment -- 显示表结构
SHOW TABLES; -- 显示表内容结构
SHOW COLUMNS FROM TB1; -- 现实表的建表语句
show create TABLE tb1; -- 删除表
DROP TABLE IF EXISTS TB1;
DROP TABLE IF EXISTS classes;
DROP TABLE IF EXISTS `user`; -- 修改表名
ALTER table tb1 rename tb2; -- 修改字段 列
-- alter table 表名 change 旧列名 新列名 列定义 [first|after某一列]
-- first 将这个字段调整为表格第一列; after某一列: 将这个字段放到某一列后面
alter table tb1 change height width VARCHAR(200) not NULL FIRST; -- 删除表中某一列
alter table tb1 drop name; -- 新增一列:必选部分:alter table tb1 add haha DOUBLE(8,2)
alter table tb1 add haha DOUBLE(8,2) DEFAULT 1.2 after age; -- 新增多列:不能调整列的位置,只能插在最后。
alter table tb1 add (
ha1 DOUBLE(3,2) UNSIGNED,
ha2 VARCHAR(255)
); -- 同时修改多表明 rename table tb3 to tb1[,`USER`to user1];
rename table tb2 to tb1,`USER`to user1; -- 增加主键约束
alter table tb1 add PRIMARY KEY(id); -- 删除主键约束
alter table tb1 drop PRIMARY KEY; -- 新增唯一性约束
ALTER table tb1 add unique key(ha1); -- 删除唯一性约束:由于创建唯一性约束会默认创建索引,所以删除时,需删除索引
ALTER table tb1 drop index ha1; -- 设置默认值约束:前提必须设置default 属性
ALTER table tb1 alter ha1 set default 20; -- 删除默认值约束
ALTER table tb1 alter haha drop default; -- 设置外键约束 必选部分 alter table tb1 add foreign key (clsid)REFERENCES classes(id)
alter table tb1 add constraint waijianming foreign key (clsid)REFERENCES classes(id) ON DELETE SET NULL on update CASCADE; -- 删除外键约束,由于常见外键时会生成索引,所以删除外键后,需要删索引。
alter table tb1 drop foreign key waijianming; alter table tb1 drop INDEX waijianming; SHOW COLUMNS FROM TB1;
4  数据库的三大范式
   
1、第一范式(1NF):数据表中的每一列(字段),必须是不可拆分的最小单元。也就是确保每一列的原子性。
        例如: userInfo:'山东省烟台市 13181621008'
                     userads:'山东省烟台市' userTel:'13181621008'
    
2、第二范式(2NF):满足1NF后,要求:表中的所有列,都必须依赖于主键,而不能有任何一列与主键没有关系。   也就是说,一个表只描述一件事情。

例如: 订单表,只能描述订单相关的信息,所以所有的字段都必须与订单ID相关;
                     产品表,只能描述产品相关的信息,所以所有的字段都必须与产品ID相关;
        因此: 不能在同一张表中同事出现订单信息与产品信息。

3、第三范式(3NF):表中的每一列都要与主键直接相关,而不是间接相关。(表中的每一列,只能依赖于主键)。
    例如:订单表中,需要有客户相关信息,在分理处客户表之后。订单表中,只需要有一个用户ID即可。而不能有其他的客户信息。因为,其他的用户信息是直接关联于用户ID,而不是关联于订单ID。

【第二范式与第三范式的本质区别】
在于没有分出两张表,第二范式是说一张表中包含了多种不同实体的属性,那么必须要分成多张表。
第三范式是要求,已经分好了多张表的化,那么,一张表中只能有另一张表中的ID(主键),而不能有其他的任何信息(其他的任何信息,一律用主键在另一表查询)
         

学习时候的笔记,可能会有一些错误的地方,欢迎各位的批评指点。

反思,复盘,每天收获一点---------------------期待更好的自己

学习mysql语法--基础篇(一)的更多相关文章

  1. 学习mysql语法--基础篇(二)

      前  言  mysql  mysql语法--本篇学习都是通过使用Navicat Premium(数据库管理工具),连接mysql数据. 本篇学习主要有两个部分: [SQL语句的组成]   DML ...

  2. 2019-10-10:渗透测试,基础学习,mysql语法基础,笔记

    mysql常用命令mysql -u用户名 -p,登录方式也称为,二进制方式exit 退出mysql 查看mysql版本select version(); 查看mysql所有数据库show dateba ...

  3. Django学习笔记(基础篇)

    Django学习笔记(基础篇):http://www.cnblogs.com/wupeiqi/articles/5237704.html

  4. Spark学习体系整理(基础篇、中级篇、高级篇所涉及内容)

    新手刚开始学习比较迷茫,参考下面,然后找相关资料学习 1 Spark基础篇      1.1 Spark生态和安装部署          在安装过程中,理解其基本操作步骤.          安装部署 ...

  5. Python学习笔记之基础篇(-)python介绍与安装

    Python学习笔记之基础篇(-)初识python Python的理念:崇尚优美.清晰.简单,是一个优秀并广泛使用的语言. python的历史: 1989年,为了打发圣诞节假期,作者Guido开始写P ...

  6. mysql学习笔记之基础篇

    数据库学习之基础篇 ① 开放数据库互连(Open Database Connectivity,ODBC ② 结构化查询语言(Structured Query Language) ③ 进入mysql:M ...

  7. Python学习总结之一 -- 基础篇

    Python学习第一篇 一:写在前面 啊,最近我的新博客一直都没有更新学习内容了,只是最近一直都在忙着寻找实习机会(或许这只是一个借口,真实原因是我太懒惰了,改改改!).终于今天又投递了几个新的实习职 ...

  8. 与你一起学习MS Project——基础篇:Project基础应用

    为了更清晰容易地熟悉掌握Project的基础应用,我们在基础篇中一起来学习掌握在Project中如何做进度计划.资源计划.成本计划以及跟踪项目的执行情况并生成所需的项目报表. 一.进度计划 这里,首先 ...

  9. java开发中的重中之重-------mysql(基础篇)

    介绍: mysql是目前世界上最流行的关系型数据库,在国内大的互联网公司都在使用mysql数据库,mysql经常被我们这样概述,“mysql是轻量级关系型数据库”,其实轻量级并不是说mysql是中小型 ...

随机推荐

  1. PAT1029.Median (25)

    (一)题目 题目链接:https://www.patest.cn/contests/pat-a-practise/1029 1029. Median (25) Given an increasing ...

  2. 北京赛车PK10 幸运飞艇 重庆时时彩 PC蛋蛋 快乐8 福彩3D 十分彩

    QQ:1395239152 2017-3.14最新修复完整运营版时时彩源码PC+手机版本功能齐全 重庆时时彩是一种经中国国家财政部批准,重庆市福利彩票发行中心承销的福彩快开彩票,2元1注,分为&quo ...

  3. docker安装hadoop集群

    docker安装hadoop集群?图啥呢?不图啥,就是图好玩.本篇博客主要是来教大家如何搭建一个docker的hadoop集群.不要问 为什么我要做这么无聊的事情,答案你也许知道,因为没有女票.... ...

  4. JAVA中事物以及连接池

    一.事物 什么是事物? 事务,一般是指要做的或所做的事情.在计算机术语中是指访问并可能更新数据库中各种数据项的一个程序执行单元.这些单元要么全都成功,要么全都不成功. 做一件事情,这个一件事情中有多个 ...

  5. python 之变量

    什么是变量? 变量就是存储一个不固定的值,可以随时更改其值. 1.变量不仅可以是数字,还可以是任意数据类型 2.变量名必须是大小写英文.数字和_的组合,且不能用数字开头 python变量如何存储 首先 ...

  6. 读Zepto源码之集合操作

    接下来几个篇章,都会解读 zepto 中的跟 dom 相关的方法,也即源码 $.fn 对象中的方法. 读Zepto源码系列文章已经放到了github上,欢迎star: reading-zepto 源码 ...

  7. 使用Html5下WebSocket搭建简易聊天室

    一.Html5WebSocket介绍 WebSocket protocol 是HTML5一种新的协议(protocol).它是实现了浏览器与服务器全双工通信(full-duplex). 现在,很多网站 ...

  8. 【干货】Markdown编辑博文,公式图片轻松搞定

    # Markdown 使用操作手册 作者:白宁超 Blog:伏草唯存 Markdown 是一种轻量级的「标记语言」,它的优点很多,目前也被越来越多的写作爱好者,撰稿者广泛使用.看到这里请不要被「标记」 ...

  9. [原创]CentOS实现智能DNS

    一.       环境: Centos-6.6-x64位操作系统,IP地址:210.38.248.7 二.       安装和配置bind服务: 1.      命令:yum install bind ...

  10. zabbix agent安装详解

    安装 Installing repository configuration package Zabbix 2.2 for RHEL5, Oracle Linux 5, CentOS 5: rpm - ...