CREATE TABLE `student`(
`studentNo` INT (4) NOT NULL PRIMARY KEY COMMENT '学号',
`loginPwd` VARCHAR(20) NOT NULL COMMENT '密码',
`studentName` VARCHAR (50) NOT NULL COMMENT '姓名',
`sex` CHAR(2) NOT NULL DEFAULT '男' COMMENT '性别',
`gradeId` INT (4) UNSIGNED COMMENT'年级编号',
`phone` VARCHAR(50)COMMENT'电话',
`address` VARCHAR(255)COMMENT'地址',
`bornDate` DATETIME COMMENT'出生日期',
`email` VARCHAR(50) COMMENT '邮件帐号',
`identityCard` VARCHAR (18) UNIQUE KEY COMMENT'身份证号'
);
DROP TABLE `student`
CREATE TABLE `subject`(
`subjectNo` INT (4) PRIMARY KEY AUTO_INCREMENT COMMENT'课程编号',
`subjectName` VARCHAR(50) COMMENT'课程名称',
`classHour` INT (4)COMMENT'学时',
`gradeId`INT (4) COMMENT'年级编号'
)
CREATE TABLE `result`(
`studentNo` INT (4) NOT NULL COMMENT'学号',
`subjectNo` INT(4) NOT NULL COMMENT'课程编号',
`examDate` DATETIME NOT NULL COMMENT'考试日期',
`studentResult` INT(4) NOT NULL COMMENT'考试成绩'
)
CREATE TABLE `grade`(
`gradeId` INT(4) NOT NULL COMMENT'年级编号',
`gradeName` VARCHAR(50) NOT NULL COMMENT'年级名称'

)COMMENT='年级表';
#创建主键
ALTER TABLE `grade`ADD CONSTRAINT pk_grade PRIMARY KEY `grade`(gradeId);
ALTER TABLE `grade`MODIFY `gradeId` INT(4) NOT NULL COMMENT'年级编号';
#创建外键
ALTER TABLE `student` ADD CONSTRAINT
fk_student_grade FOREIGN KEY (`gradeId`)
REFERENCES `grade` (`gradeId`);
ALTER TABLE result ADD PRIMARY KEY pk_result(`studentNo`,`subjectNo`,`examDate`);

#test数据库创建person表

CREATE DATABASE `text`;
CREATE TABLE `person`(
`number` INT(4) AUTO_INCREMENT PRIMARY KEY COMMENT'序号',
`name` VARCHAR(50)NOT NULL COMMENT'姓名',
`sex` CHAR(2)COMMENT'性别',
`bornDate` DATETIME COMMENT'出生日期'
)COMMENT='person表';
ALTER TABLE `person` RENAME`tb_person`;
ALTER TABLE `tb_person`DROP `bornDate`;
ALTER TABLE `tb_person`ADD `bornDate` DATE;
ALTER TABLE `tb_person`CHANGE `number` `id`BIGINT;

mysql:
dbs 数据库
dbms 数据库管理系统
dba 数据库管理员
db 数据库
dba 通过dbms来操作db
关系型数据库和非关系型数据库
登录MySQL
mysql -h主机地址 -u 用户名 -p密码
查询所有的数据库
show databases;
创建数据库
create database [if not exists] 数据库名称;
删除数据库
drop database[if exists]数据库名称;

结构语言分类
DDL(数据定义语言) create drop alter 创建删除以及修改数据库,表,存储过程,触发器,索引。。。

DML(数据操作语言) insert delete update 用来操作数据库中的数据

DQL(数据查询语言)select 用来查询数据库中的数据

DCL(数据控制语言)grant(授权)revoke(撤销)

TCL(事物控制语言)begin savepoint(设置回滚点)rollback commit
grant 查询 to 用户名
revoke 查询from用户名
crud (增删改查)

创建用户
create user 用户名@‘地址’
identified by '密码';

给用户授权
01 grant all on *.* to 用户名;
02 grant all on *.* to 用户名@‘地址’;
刷新系统权限
flush privileges;
删除用户
所有的用户都存储在mysql数据库中的user表中
01 delete from mysql.user where user='14';
02 delete from mysql.user where user='14'and host='localhost';

逻辑运算符
and && 与
or || 或
not ! 非

user切换到指定的数据库
如果没有切换到指定的数据库,需要在表前面加上数据库的名称
use mysql;
select `host`,`user`from `user`;

数据类型
int double
在mysql数据库中都使用的是decimal(a,b)
a 指定小数点左边右边可以存储的十进制数字的最大的个数,最大精度38.
b 指定小数点右边可以存储的十进制数字的最大个数。小数位数必须是从0到a之间的值。默认小数位数必须是从0到a之间的值。默认小数位数是0

在oracle中经常使用 *****number*****

char 固定长度 例如、;性别是char类型 长度是10 但是我们的实际输入长度是2 ;那么存储的时候也是10 个空间造成资源浪费

varchar 可变长度 例子:性别是char 类型长度是10
但他的实际长度是2
那么存储的时候是2个空间

日期格式
date yyyy-MM-dd
datetime yy-MM-dd hh:mm:ss
time hh:MM:ss
timestamp 1970到现在 y yyyMMddhhmmss
year yyyy 1901

约束类型

主键约束 primary key (pk)
用于设置表的主键,用来确保该行的唯一性
外键 foreign key (fk)
用于建立表与表之间的关系
非空约束 not null
字段不为空
默认约束 default 字段的默认值
唯一约束 unique key(uk)
字段的值是唯一的可以是null,但只能有一个
自动增长 auto_increment 设置列的自动增长(标识列),通常用于设置主键

创建表
如果是关键字 那么使用反引号``

create table [if not exists] 表名(
字段1 数据类型 [约束,索引,注释],
字段2 数据类型 [约束,索引,注释],
字段3 数据类型 [约束,索引,注释]
)[表类型][表字符集][注释]

有符号类型和无符号类型

有符号类型?:可以取负值
无符号类型:默认是0! 0---类型的长度

zerofill属性:如果位数不够,前面用0补齐

若某位值字段指定了zrofill属性,将自动添加unsigned属性!

创建学生表

create table if not exists student(
studentNo int(4)
not null primary key comment '密码',
studentName varchar(20) not null comment'学生姓名',
sex char (2)not null default'男'comment'性别',
gradeId int(4)unsigned comment'年级编号',
phone varchar(50)comment'电话'
address VARCHAR(255) DEFAULT'地址不详' COMMENT '地址',
bornDate DATETIME COMMENT '出生日期',
email VARCHAR(50) COMMENT '邮箱账号',
identityCard VARCHAR(18) UNIQUE KEY COMMENT '身份证号'

)comment='学生表';

-- 修改表中 微信 字段的长度为50
ALTER TABLE student MODIFY wechat VARCHAR(50);

-- 删除表中 微信 字段
ALTER TABLE student DROP wechat;

-- 修改studentName字段的名称为 stuName
ALTER TABLE student CHANGE `name` stuName VARCHAR(20);

创建subject科目表
create table if not exists `subject`(
subjectNo INT(4) AUTO_INCREMENT PRIMARY KEY COMMENT '课程编号',
subjectName VARCHAR(50) COMMENT '课程名称',
classHour INT(4) COMMENT '学时',
gradeID INT(4) COMMENT '年级编号'
)comment='科目表'charset='utf8';
在使用AUTO_INCREMENT是 必须和PRIMARY KEY 联合使用!

创建年级表

CREATE TABLE IF NOT EXISTS grade(
gradeID INT(4) COMMENT '年级编号',
gradeName VARCHAR(10) COMMENT '年级名称'
)COMMENT='年级表';

添加主键的语法
alter table grade add constraint pk_grade_gradeId primary key(
gradeId);

创建成绩表

CREATE TABLE IF NOT EXISTS result(
studentNo INT(4) NOT NULL PRIMARY KEY COMMENT '学号',
subjectNo INT(4) NOT NULL COMMENT '课程编号',
examDate DATETIME NOT NULL COMMENT '考试日期 ',
studentResult INT(4) NOT NULL COMMENT '考试成绩'
)COMMENT='成绩表' charset='utf8' engine=InnoDB;

外键的语法:
ALTER TABLE 表名 ADD CONSTRAINT 外键名
FOREIGN KEY(外键字段)
REFERENCES 关联表名(关联字段);

创建student表和grade表的关系

学生应该属于某个年级

外键必须建立在 从表上!
alter table student add constraint
fk_studnet_grade
foreign key(gradeId)
references grade (gradeId);

问题: 前提已经建立了 主外键关系

如果说有三个年级,编号分别是 1 2 3
那么也有三个学生 对应的关系是
第1个学生 1年级
第2个学生 2年级
第3个学生 2年级

01.有没有这种情况 有个学生的年级编号是4 ??
主表中没有数据! 从表无法创建!

02.可不可以删除年级表2年级或者1年级???
不能删除!因为从表中还有关联数据!

03.如果我们非得删除年级 怎么办??
先把从表中的关联数据删除 ,之后再删除主表中的数据!

-- 给成绩表设置联合主键
alter table result add primary key pk_result(studentno,subjectno,examdate);

mysql数据库中常用的两种 存储 引擎

MyISAM InnoDB
使用的场景:

MyISAM:不能使用事务,空间小,适合查询!
InnoDB:多适用于增删改,安全性高!事务的并发处理!

查询当前默认的存储引擎
show variables like 'strage_engine';
--修改存储引擎
--找到安装路径下的my.ini文件
--加入
defaulet-storage-engine=innoDB

数据库表的存储位置
InnnoDB类型的表文件
*.frm : 表结构定义文件
*.ibd : 数据文件

MyISAM类型的表文件
*.frm : 表结构定义文件
*.MYD : 数据文件
*.MYI :索引文件

DML和DQL 增删改查

seclect * from grade
新增 insert
--向年级表中新增3条数据
insert into grade(gradeId,gradeName)values(4,'4年级');
INSERT INTO grade(gradeID,gradeName) VALUES(5,'5年级');
INSERT INTO grade(gradeID,gradeName) VALUES(6,'6年级');

--删除456
delete from grade where gradeID>3;
delete from grade where
gradeId=4 or gradeId=5 or gradeId=6;
delete from grade where gradeID in(4,5,6);

-- 同时插入多条数据 oracle数据库不支持
insert into grade (gradeId,gradeName)values(4,'4年级') ,
(5,'5年级'),(6,'6年级');

--修改gradeId=1的年级名称为 one
update grade set gradeName='one'
where gradeId=1

-----delete 删除表中所有的数据
delete from grade;

mysql01的更多相关文章

  1. 从零开始——MySql01

    注:如有侵权,请速联系,会速度删除!(都是同学分享的内容) 安装详解: 链接:http://pan.baidu.com/s/1skMQVgx 密码:z0xh Navicat安装包: 链接:http:/ ...

  2. MySQL-01 MySQL数据库安装指南

    学习要点 MySQL数据库的安装和设置 下载mysql mysql官网:https://www.mysql.com/downloads/ 主要版本: Oracle MySQL Cloud Servic ...

  3. 数据库-mysql01 简单介绍以及安装部署

    本次mysql数据库安装采用二进制安装(免安装即绿色版),数据库版本是mysql5.7.26 首先下载mysql安装包,然后上传服务器里,最后解压. 卸载centos7自带的数据库软件包: [root ...

  4. 极客mysql01

    1.MySQL的框架有几个组件, 各是什么作用?连接器:负责跟客户端建立连接.获取权限.维持和管理连接.查询缓存:查询请求先访问缓存(key 是查询的语句,value 是查询的结果).命中直接返回.不 ...

  5. 用脚本如何实现将Linux下的txt文件批量转化为Windows下的txt文件?

    众所周知,Windows和Linux的文件换行回车格式不同,Windows下换行格式是\r\n(回车+换行),Linux下换行格式为\n(只是换行),因此,其中一个操作系统的文本文件若需要在另外一个中 ...

  6. pt-table-checksum使用实践

    在工作中接触最多的就是mysql replication,由于现在公司也还在使用mysql 5.1.x版本,在复制方面还是比较多的问题,比如主库宕机或者从库宕机都会导致复制中断,通常我们需要进行人为修 ...

  7. python-基础案例

    范例一: 练习:元素分类 有如下值集合 [11,22,33,44,55,66,77,88,99,90...],将所有大于 66 的值保存至字典的第一个key中,将小于 66 的值保存至第二个key的值 ...

  8. MySQL性能优化笔记整理

    一.测试篇 1.测试目的,就是量化找出短板(基础参数配置) 2.测试三大指标 IOPS:每秒处理的IO请求数,即IO响应速度(注意和IO吞吐量的区别) QPS:每秒请求(查询)次数 TPS:每秒事务数 ...

  9. Galera 10.0.20 on CentOS 6.6

    Galera 10.0.20 on CentOS 6.6 0.使用场景 数据库软件:mariadb-galera-10.0.20-linux-x86_64.tar.gz 集群管理:galera-3-2 ...

随机推荐

  1. 敏捷开发— —Scrum 学习笔记

    敏捷开发模式是一种从1990年代开始逐渐引起广泛关注的一些新型软件开发方法,是一种应对快速变化的需求的一种软件开发能力.它们的具体名称.理念.过程.术语都不尽相同,相对于"非敏捷" ...

  2. Learn golang: Top 30 Go Tutorials for Programmers Of All Levels

    https://stackify.com/learn-go-tutorials/ What is Go Programming Language? Go, developed by Google in ...

  3. 算法笔记-PHP实现队列的操作

    [队列]先进者先出,这就是典型的“队列”.         最基本的两个操作:入队enqueue(),放一个数据到队列尾部:出队dequeue(),从队列头部取一个元素.队列可以用数组或者链表实现,用 ...

  4. [js]js的表单验证

    http://uule.iteye.com/blog/2183622 表单验证类 <form class="form" method="post" id= ...

  5. 教你写Makefile(很全,含有工作经验的)

    Makefile 值得一提的是,在Makefile中的命令,必须要以[Tab]键开始. 什么是makefile?或许很多Winodws的程序员都不知道这个东西,因为那些Windows的IDE都为你做了 ...

  6. 解决Linux 下 root用户删除文件提示:Operation not permitted

    问题描述 用最高权限rm文件,居然报错Operation not permitted.查看权限也没有问题.可想而知有可能文件被保护了.用命令lsattr检查一下就知道. [root@linux roo ...

  7. js计算最大公约数和最小公倍数

    一.计算最大公约数 1.小学时候一般采用质因数分解法,一般使用短除得到结果,下面用一种最初级的方法求最大公约数 function gcd2(a,b){ var result = 1; for(var ...

  8. cocos2d JS 使用代码判断对象类型

    changeAtlasScoreString : function (score,tfScore) { if(tfScore.getDescription() == "LabelAtlas& ...

  9. BCB6.0 清除TPanel面板上的所有控件

    方法一: panel->ComponentCount属性获得panel所拥有的控件个数 panel->Components[i]属性获得某一个控件 delete panel->Com ...

  10. java生成随机六位数的验证码&随机生成十位数ValidCode码,用于邮件的验证&检查是不是符合为合法的中国的手机号码

    package com.demo.test1; import java.security.NoSuchAlgorithmException; import java.security.SecureRa ...