mysql01
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的更多相关文章
- 从零开始——MySql01
注:如有侵权,请速联系,会速度删除!(都是同学分享的内容) 安装详解: 链接:http://pan.baidu.com/s/1skMQVgx 密码:z0xh Navicat安装包: 链接:http:/ ...
- MySQL-01 MySQL数据库安装指南
学习要点 MySQL数据库的安装和设置 下载mysql mysql官网:https://www.mysql.com/downloads/ 主要版本: Oracle MySQL Cloud Servic ...
- 数据库-mysql01 简单介绍以及安装部署
本次mysql数据库安装采用二进制安装(免安装即绿色版),数据库版本是mysql5.7.26 首先下载mysql安装包,然后上传服务器里,最后解压. 卸载centos7自带的数据库软件包: [root ...
- 极客mysql01
1.MySQL的框架有几个组件, 各是什么作用?连接器:负责跟客户端建立连接.获取权限.维持和管理连接.查询缓存:查询请求先访问缓存(key 是查询的语句,value 是查询的结果).命中直接返回.不 ...
- 用脚本如何实现将Linux下的txt文件批量转化为Windows下的txt文件?
众所周知,Windows和Linux的文件换行回车格式不同,Windows下换行格式是\r\n(回车+换行),Linux下换行格式为\n(只是换行),因此,其中一个操作系统的文本文件若需要在另外一个中 ...
- pt-table-checksum使用实践
在工作中接触最多的就是mysql replication,由于现在公司也还在使用mysql 5.1.x版本,在复制方面还是比较多的问题,比如主库宕机或者从库宕机都会导致复制中断,通常我们需要进行人为修 ...
- python-基础案例
范例一: 练习:元素分类 有如下值集合 [11,22,33,44,55,66,77,88,99,90...],将所有大于 66 的值保存至字典的第一个key中,将小于 66 的值保存至第二个key的值 ...
- MySQL性能优化笔记整理
一.测试篇 1.测试目的,就是量化找出短板(基础参数配置) 2.测试三大指标 IOPS:每秒处理的IO请求数,即IO响应速度(注意和IO吞吐量的区别) QPS:每秒请求(查询)次数 TPS:每秒事务数 ...
- 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 ...
随机推荐
- java -jstack
一.介绍 jstack是java虚拟机自带的一种堆栈跟踪工具.jstack用于打印出给定的java进程ID或core file或远程调试服务的Java堆栈信息,如果是在64位机器上,需要指定选项&qu ...
- Nginx解析PHP的原理 | CGI、FastCGI及php-fpm的关系
Nginx解析PHP的原理,CGI/FastCGI以及PHP-Fpm的关系. 一.PHP+Nginx应运而生的场景.随着互联网的发展,用户对此接受面广,数据流的增大使得Web端的运行承载压力日益增大, ...
- 异常Exception分类
1:编译时被检测异常:只要有是Exception和其子类都是,除了特殊子类RuntimeException体系. 这种问题已但出现,希望在编译时进行检测,让这种问题有对应处理方式 ...
- selenium python3
安装pip3 install selenium 查看版本pip3 show selenium 安装后还是提示找不到相应的模块 Mac安装PyCharm后,将已有工程导入,之前使用Mac终端执行脚本时正 ...
- 《全栈性能Jmeter》-2性能测试初体验
- express-generator 自动生成服务器基本文件
(1) 安装 express-generator 构建工具 npm install -g express-generator 在命令行中用 npm 在全局安装 express-generator 脚手 ...
- Go linux 实践3
Go 的灵魂-goroutine(协程), channel(渠道) 看看吧,不多说了 ************************************************ package ...
- selenium处理弹出窗口
在selenium ui自动化测试过程中,经常会遇到,弹出新窗口,那么会对我们元素定位造成哪些影响呢? 1.元素id或xpath;name都没有问题,就是定位不到. 那如何解决呢?没错webdrive ...
- 图像控件 ImageControl
图像控件 书:164 <?xml version="1.0" encoding="utf-8"?> <s:Application xmlns: ...
- UVA 11178 Morley's Theorem(几何)
Morley's Theorem [题目链接]Morley's Theorem [题目类型]几何 &题解: 蓝书P259 简单的几何模拟,但要熟练的应用模板,还有注意模板的适用范围和传参不要传 ...