0

0

学习基础mysql语法

巴扎黑

巴扎黑

发布时间:2017-06-23 11:10:40

|

1811人浏览过

|

来源于php中文网

原创

 

J.LB.PurchaseStore
J.LB.PurchaseStore

基于jsp+javabean+mysql三层结构的动态购物网站。网站用户接口(即界面)由jsp完成,数据和逻辑处理由beans完成,数据储存由mysql完成。因为beans独立负责处理整个网站的绝大部分数据,所以整个网站的负载量和速度都将大大提高。而且jsp的特性是一次运行,永远储留内存(包括bean在内),所以基于这种语言和结构开发的购物系统的优势是其它语言没法比尔的。更重要的是,jsp+bea

下载

  前  言

 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'];
     
查询本机中所有的数据库: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(主键),而不能有其他的任何信息(其他的任何信息,一律用主键在另一表查询)
         

 

 

 

 

 

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

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

 

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
go语言 注释编码
go语言 注释编码

本专题整合了go语言注释、注释规范等等内容,阅读专题下面的文章了解更多详细内容。

2

2026.01.31

go语言 math包
go语言 math包

本专题整合了go语言math包相关内容,阅读专题下面的文章了解更多详细内容。

1

2026.01.31

go语言输入函数
go语言输入函数

本专题整合了go语言输入相关教程内容,阅读专题下面的文章了解更多详细内容。

1

2026.01.31

golang 循环遍历
golang 循环遍历

本专题整合了golang循环遍历相关教程,阅读专题下面的文章了解更多详细内容。

0

2026.01.31

Golang人工智能合集
Golang人工智能合集

本专题整合了Golang人工智能相关内容,阅读专题下面的文章了解更多详细内容。

1

2026.01.31

2026赚钱平台入口大全
2026赚钱平台入口大全

2026年最新赚钱平台入口汇总,涵盖任务众包、内容创作、电商运营、技能变现等多类正规渠道,助你轻松开启副业增收之路。阅读专题下面的文章了解更多详细内容。

76

2026.01.31

高干文在线阅读网站大全
高干文在线阅读网站大全

汇集热门1v1高干文免费阅读资源,涵盖都市言情、京味大院、军旅高干等经典题材,情节紧凑、人物鲜明。阅读专题下面的文章了解更多详细内容。

73

2026.01.31

无需付费的漫画app大全
无需付费的漫画app大全

想找真正免费又无套路的漫画App?本合集精选多款永久免费、资源丰富、无广告干扰的优质漫画应用,涵盖国漫、日漫、韩漫及经典老番,满足各类阅读需求。阅读专题下面的文章了解更多详细内容。

67

2026.01.31

漫画免费在线观看地址大全
漫画免费在线观看地址大全

想找免费又资源丰富的漫画网站?本合集精选2025-2026年热门平台,涵盖国漫、日漫、韩漫等多类型作品,支持高清流畅阅读与离线缓存。阅读专题下面的文章了解更多详细内容。

19

2026.01.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 2万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 817人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号