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 ...
随机推荐
- oracle添加字段,备注
1.添加字段: alter table 表名 add (字段 字段类型) [ default '输入默认值'] [null/not null] ; 2.添加备注: comment on ...
- xtrabackup全库还原+binlog日志还原
1.场景 mysql数据库误删某个库.误删表或者误删除数据 如下模拟图:备份策略定为每天凌晨进行全库备份,在B时间点进行了误操作以后,有两种恢复场景,一种是恢复到B时间点误操作前,一种是恢复到C时间点 ...
- openvpn-服务端配置文件
;local a.b.c.d port 1194 ;proto tcp proto udp ;dev tap dev tun ;dev-node MyTap ca /etc/openvpn/keys/ ...
- jenkins借助winscp传本地文件到远程服务器上
有这样的场景,我们的ftp上都是些重要的资料,所以大家基本只有可看的权限,只有部分管理人员有可读可写的权限,但是jenkins上基本使用的都是ftp的路径,这个时候就存在一些问题,某些开发需要将自己构 ...
- jenkins配置详解之——执行者数量
jenkins上的执行者数量的设置并不是随意设置的,位置如下: 他是跟cpu核数密切相关的,原则上是不能超过cpu的核数的, 如何查看cpu的核数呢,命令如下: # 查看物理CPU个数cat /pro ...
- ICSharpCode.TextEditor使用及扩展
SharpDevelop (#develop)有很多“副产品”,其中最出名的应算SharpZipLib (#ziplib),纯C#的ZIP类库,而在SharpDevelop (#develop)中,“ ...
- CentOS6.5 安装Kafka集群
1.安装zookeeper 参考文档:http://www.cnblogs.com/hunttown/p/5452138.html 2.下载:https://www.apache.org/dyn/cl ...
- css--clearfix浮动
解读浮动闭合最佳方案:clearfix: http://www.daqianduan.com/3606.html clearfix清除浮动进化史:http://www.admin10000.com/d ...
- ODBC的JAR包和PLSQL
eclipse编辑器,写java 下载ODBC的JAR包 配置一下用户名和密码 java连接上数据库后 不是直接操作数据库 在代码里面有SQL语句 代码执行的时候遇到这些语句就可以操作数据库 平时操 ...
- centos7及服务器端安装python2.7.13, setuptools, pip
1. 安装python2.7.13 因为涉及到安装到服务器,所以可能不能直接在usr/bin及usr/local/bin下安装,所以本文详解安装在自定义目录下. 下载安装包: $ wget https ...