mysql之4;
1表之间的关系:
2select查询语句:
1表之间的关系
(1)多对一:(一个表里的多条记录对应另一个表里的一个记录)
建立多对一的关系需要注意
1 先建立被关联的表,被关联的字段必须保证是唯一的
2 再创建关联的表,关联的字段,一定要保证是可以重复的
ps:关联的字段一定是来自于被关联的表对应字段的值
代码:
create table dep(#部门表
id int primary key auto_increment, #被关联的字段必须保证是唯一的#id字段是主键并且是自增的
name varchar(20),#
comment varchar(50)
);
create table emp(#员工表
id int primary key auto_increment,
name varchar(20),
dep_id int, #关联的字段,一定要保证是可以重复的
constraint fk_depid_id foreign key(dep_id) references dep(id)#定义外键
on update cascade#这个是表示这两个是跟随被关联的表一起更改或者删除的
on delete cascade
);
(2)一对一
create table user(#建立user表
uid int primary key auto_increment,#主键且自增
name varchar(15)#用户的名字
);
insert into user(name) values#插入数据
('frank1'),
('frank2'),
('frank3'),
create table admin(#建立admin表
id int primary key auto_increment,#主键且自增
user_id int unique,#确保是独一无二的
password varchar(20),#密码的多少
foreign key(user_id) references user(uid)#关联到user的uid确保foreign 是独一无二的
on update cascade#后面这个可以确保关联的表可以跟着被关联的一起改动或者删除
on delete cascade
);
insert into admin(user_id,password) values
(1,'frank3714'),
(2,'alfrank371asdf4')
(3)多对多关系
多对多代码:
create table author (#创建作者信息
id int primary key auto_increment,
name char (10));
create table books (#创建书籍信息
id int primary key auto_increment,
name char (10));
create table books_authors(#建立一个关系表
id int primary key auto_increment ,#主键且自增
book_id int not null,#不为空
author_id int not null ,#不为空
unique(book_id,author_id),#联合唯一
foreign key (book_id) references books(id)#设置外键
on delete cascade#这两个是说明关联表是跟随被关联表一起变动
on update cascade ,
foreign key (author_id ) references author(id)#设置外键
on delete cascade
on update cascade );
2select查询语句:
mysql:增、删、改、查; 查是我们用到数据库最多的就是查询数据
我们以前学过基本的查询语句:select * from t1;
我们来看下一个where语句和(and,between and ,not ,or ,in、is 、like等)
select * from t1 where id=5;
select name,age where salary>1000 and salary <2000;可以写成select name,age where salary between 1000 and 2000;
select name,age where salary not between 1000and 2000;
select name,salary from employee where salary = 10000 or salary = 20000 or salary = 30000;
select name,salary from employee where salary in (10000,20000,30000);
select salary from employee where name like '%ank%'; #like 是模糊匹配 %可以代表任意字符(可以代表多个)
select salary from employee where name like 'frank_'; #like 是模糊匹配 _可以代表任意一个字符
select * from employee where dep_comment is Null;#is Null 判断是否为空;有值用=
select * from employee where dep_comment = Null;#这个是错误的
select * from employee where dep_comment is not Null;
group by 是分组(以什么为分组)
select depart_id,count(id) from employee group by depart_id;
mysql之4;的更多相关文章
- Hadoop 中利用 mapreduce 读写 mysql 数据
Hadoop 中利用 mapreduce 读写 mysql 数据 有时候我们在项目中会遇到输入结果集很大,但是输出结果很小,比如一些 pv.uv 数据,然后为了实时查询的需求,或者一些 OLAP ...
- mysql每秒最多能插入多少条数据 ? 死磕性能压测
前段时间搞优化,最后瓶颈发现都在数据库单点上. 问DBA,给我的写入答案是在1W(机械硬盘)左右. 联想起前几天infoQ上一篇文章说他们最好的硬件写入速度在2W后也无法提高(SSD硬盘) 但这东西感 ...
- LINUX篇,设置MYSQL远程访问实用版
每次设置root和远程访问都容易出现问题, 总结了个通用方法, 关键在于实用 step1: # mysql -u root mysql mysql> Grant all privileges o ...
- nodejs进阶(6)—连接MySQL数据库
1. 建库连库 连接MySQL数据库需要安装支持 npm install mysql 我们需要提前安装按mysql sever端 建一个数据库mydb1 mysql> CREATE DATABA ...
- MySQL高级知识- MySQL的架构介绍
[TOC] 1.MySQL 简介 概述 MySQL是一个关系型数据库管理系统,由瑞典MySQL AB公司开发,目前属于Oracle公司. MySQL是一种关联数据库管理系统,将数据保存在不同的表中,而 ...
- 闰秒导致MySQL服务器的CPU sys过高
今天,有个哥们碰到一个问题,他有一个从库,只要是启动MySQL,CPU使用率就非常高,其中sys占比也比较高,具体可见下图. 注意:他的生产环境是物理机,单个CPU,4个Core. 于是,他抓取了CP ...
- 我的MYSQL学习心得(一) 简单语法
我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(四) 数据类型 我的MYSQL学习心得(五) 运 ...
- Entity Framework Core 实现MySQL 的TimeStamp/RowVersion 并发控制
将通用的序列号生成器库 从SQL Server迁移到Mysql 遇到的一个问题,就是TimeStamp/RowVersion并发控制类型在非Microsoft SQL Server数据库中的实现.SQ ...
- Docker笔记一:基于Docker容器构建并运行 nginx + php + mysql ( mariadb ) 服务环境
首先为什么要自己编写Dockerfile来构建 nginx.php.mariadb这三个镜像呢?一是希望更深入了解Dockerfile的使用,也就能初步了解docker镜像是如何被构建的:二是希望将来 ...
- 当忘记mysql数据库密码时如何进行修改
因为长时间没有使用数据库了,或者把密码改完之后就忘了数据库密码,不能正常进入数据库,也无法修改密码,有一个简单的常用修改密码方式: 1.首先找到和打开mysql.exe和mysqld.exe所在的文件 ...
随机推荐
- Hibernate学习(三)———— 一对多映射关系
序言 前面两节讲了hibernate的两个配置文件和hello world!.还有hibernate的一级缓存和三种状态,基本上hibernate就懂一点了,从这章起开始一个很重要的知识点,hiber ...
- MySQL 事务机制
事务处理是保证数据安全的重要机制,事务有四个重要属性 ,根据它们的英文名称可以记为ACID: 原子性(Atomic): 事务操作是不可分割的; 事务只存在已执行和未执行两种状态,不存在只执行了部分指令 ...
- c# UTF-16转UTF-8 互转
/// <summary> /// UTF-16转UTF-8 /// </summary> /// <param name="str">< ...
- iview 刷新滞后于html问题
一.问题描述 每次刷新页面,下面的内容就会一闪而过. 一闪而过后恢复正常: 二.解决 问题代码: @*<span>修改密码</span>*@ @*<span>{{m ...
- 【Java】包,jar包的扫描
包扫描在框架中应用很广泛,在spring中,通过给自己的类加注解的方式,利用spring的包扫描,完成依赖注入. package com.test.package_scanner.core; impo ...
- 【Java深入研究】2、JDK 1.8 LinkedList源码解析
LinkedList是一个实现了List接口和Deque接口的双端链表. 有关索引的操作可能从链表头开始遍历到链表尾部,也可能从尾部遍历到链表头部,这取决于看索引更靠近哪一端. LinkedList不 ...
- Git的概念及常用命令
一.概念 Git是一个分布式的版本控制工具,区别于集中式管理的SVN. 二.优势 每个开发者都拥有自己的本地版本库,可以在本地任意修改代码.创建分支,不会影响到其他开发者的使用: 所有版本信息均保存在 ...
- Nhibernate学习的第一天
书本:https://www.tutorialspoint.com/nhibernate/index.htm 第一天学习内容 概念 Nhibernate是一个ORM框架. ORM框架:将声明的类映射到 ...
- Python 简单分页思路
一: li = [] for i in range(1000): li.append(i) while True: p = input('input page: ') p = int(p) start ...
- Jquery插件开发之图片放大镜效果(仿淘宝)
原网转载地址:http://www.cnblogs.com/hnvvv/archive/2011/11/19/2255197.html 需求:公司某个网站,需要实现图片预览效果,并能像淘宝一样实现局部 ...