CREATE USER ‘用户名’@’主机名’CREATE USER ‘用户名’@’主机名’

 

 

  前  言

 mysql 

style=”font-size: 14px; font-family: ‘Microsoft YaHei’;”> mysql语法– style=”font-size: 14px; font-family: ‘Microsoft YaHei’;”>本篇学习还是通过应用Navicat
Premium(数据库管理工具 style=”font-size: 14px; font-family: ‘Microsoft YaHei’;”>),连接mysql数据.

style=”font-size: 14px; font-family: ‘Microsoft YaHei’;”>本篇学习重大出些许只有:

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

    
二、MYSQL中广大的数据类型

style=”font-size: 14px; font-family: ‘Microsoft YaHei’;”>   三、表-创建表、主键、外键

    
四、数据库设计之老三杀范式

style=”font-size: 14px; font-family: ‘Microsoft YaHei’;”>以下有所代码全部每当新建查询表里面用mysql语法编辑。

  前  言

 mysql 

style=”font-size: 14px; font-family: ‘Microsoft YaHei’;”> mysql语法– style=”font-size: 14px; font-family: ‘Microsoft YaHei’;”>本篇学习都是通过采取Navicat
Premium(数据库管理工具 style=”font-size: 14px; font-family: ‘Microsoft YaHei’;”>),连接mysql数据.

style=”font-size: 14px; font-family: ‘Microsoft YaHei’;”>本篇学习重大有零星单部分:

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

    
二、MYSQL中普遍的数据类型

style=”font-size: 14px; font-family: ‘Microsoft YaHei’;”>   三、表-创建表、主键、外键

    
四、数据库设计的老三颇范式

style=”font-size: 14px; font-family: ‘Microsoft YaHei’;”>以下有所代码全部以新建查询表里面用mysql语法编辑。

 

 

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

/* SQL 多行注释 */
— SQL 单行注释

/* 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

创建用户: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 数据库]

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

 

 

2  MYSQL中常见的数据类型
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(“男”,”女”):枚举类型,字段只能容纳枚举出底数额。

      ①
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;

二、整形:
    
    ① 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号中数字;

    ① FLOAT:  可以规范到稍微数点后7各中数字;
    ② DOUBLE:  可以确切到多少数点后15位至16位中数字;

季、日期时数额列
    
  
 注意:由于时日存储使用字符串或者时间穿存储,所以数据库被几乎不用日期类型。
    ① DATE:存储日期及时数额
    ② TIMESTAMP:比DATE更精确

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

 

 

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

   
 【创建表】:

   
 【创建表】:

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

  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
          ②
外键与参照列的数据类型必须一致。(数值型要求长度以及无符号都如出一辙,字符串要求种相同,长度可以不同。)
          ③
设置外键的字段必须要生目录。如果没有索引,设置外键时会自动生成一个索引。

      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]–
设置参照完整性
          

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

      3、外键约束之参考完整性操作?
        
 参照操作:当对参照表的参照字段展开删减或更新是,外键表中的外键如何回答。
          参照操作而选值:restrict
拒绝参照表删除或更新参照字段;(默认)
                                          NO ACTION 与
restrict一样,但这个令就于mysql生效;
                                          cascade
删除或更新参照表的参考字段经常,外键表的记录并删除或更新;(外键表和参考表同步)
                                          set null
删除或更新参照表的参阅字段时,外键表的外键设为null;
  
         

      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;
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  数据库的三大范式
4  数据库的三大范式

   
1、第一范式(1NF):数据表中的诸一样列(字段),必须是不可拆分的最好小单元。也便是承保每一样列的原子性。
        例如: userInfo:’山东省烟台市 13181621008′
                     userads:’山东省烟台市’ userTel:’13181621008′
    
2、第二范式(2NF):满足1NF后,要求:表中的拥有列,都须依让主键,而无可知来外一样排列与主键没有涉嫌。  
也就是说,一个表只描述一桩事情。

   
1、第一范式(1NF):数据表中的各一样列(字段),必须是不足拆分的极致小单元。也不怕是保每一样排的原子性。
        例如: userInfo:’山东省烟台市 13181621008′
                     userads:’山东省烟台市’ userTel:’13181621008′
    
2、第二范式(2NF):满足1NF后,要求:表中的享有列,都要依让主键,而非能够生外一样排列与主键没有涉嫌。  
也就是说,一个表只描述一项事情。

        例如:
订单表,只能描述订单相关的消息,所以有的字段都得同订单ID相关;
                    
产品说明,只能描述产品有关的音讯,所以有的字段都要跟产品ID相关;
        因此: 不能够当同样摆设表中同事出现订单信息以及制品信息。

        例如:
订单表,只能描述订单相关的音,所以具有的字段都必须和订单ID相关;
                    
产品表明,只能描述产品有关的音,所以具有的字段都不能不与产品ID相关;
        因此: 不可知在相同布置表中同事出现订单信息及制品信息。

3、第三范式(3NF):表中的各一样排都设与主键直接相关,而无是间接相关。(表中的各国一样排,只能凭借让主键)。
  
 例如:订单表明中,需要来客户有关信息,在分理处客户表之后。订单表明中,只需要发出一个用户ID即可。而不能够起其他的客户信息。因为,其他的用户信息是直关系于用户ID,而休是关乎于订单ID。

3、第三范式(3NF):表中的各一样排都使跟主键直接相关,而休是间接相关。(表中的每一样排,只能凭借让主键)。
  
 例如:订单表明中,需要有客户有关信息,在分理处客户表之后。订单表明中,只待出一个用户ID即可。而休能够产生其它的客户信息。因为,其他的用户信息是直关联于用户ID,而无是涉嫌于订单ID。

【第二范式与第三范式的本质区别】
介于没有分开出些许摆表,第二范式是说一样摆放表中寓了多种不同实体的性,那么得要分成多张表。
其三范式是要求,已经分开好了大半张表的化,那么,一摆设表中只能发出其他一样摆表中的ID(主键),而未可知发另外的别样信息(其他的另外音讯,一律用主键在其他一样申明查询)
         

【第二范式与第三范式的本质区别】
在没有分开出个别布置表,第二范式是说一样摆设表中带有了多种不同实体的性,那么得要分成多张表。
其三范式是要求,已经分好了大多张表的成为,那么,一摆放表中只能发出其他一样布置表中的ID(主键),而无可知闹另外的其余音讯(其他的别音讯,一律用主键在其余一样申明查询)
         

图片 1

图片 2

 

 

图片 3

图片 4

 

 

 图片 5

 图片 6

 

 

 

 

学学时光的记,可能会见发生有荒谬的地方,欢迎各位的批评指点。

读时光的记,可能会见生一些误的地方,欢迎各位的批评指点。

反躬自省,复盘,每天取一点———————期待再次好之大团结

自省,复盘,每天取一点———————期待再次好的和睦