SQL是Structured Query Language(结构化查询语言)的缩写。SQL是专为数据库而建立的操作命令集,是一种功能齐全的数据库语言。在使用它时,只需要发出“做什么”的命令,“怎么做”是不用使用者考虑的。SQL功能强大、简单易学、使用方便,已经成为了数据库操作的基础,并且现在几乎所有的数据库均支持SQL。
前 言
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 数据库]
一、字符型:
① 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更精确
【创建表】:
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 关键词:学习基础mysql语法