您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

学习基础mysql语法

2024/3/12 14:05:17发布23次查看
前  言
 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语法的详细内容。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product