MySQL笔记 合并查询 外连接 约束

-- 合并查询 union all以及union
-- union all就是将两个查询结果合并,不会去重
select ename,sal,job from emp where sal>2500; -- 5条记录
select ename,sal,job from emp where job = 'MANAGER' -- 3条记录select ename,sal,job from emp where sal>2500 
union all
select ename,sal,job from emp where job = 'MANAGER' select ename,sal,job from emp where sal>2500 
union
select ename,sal,job from emp where job = 'MANAGER' -- 外连接 以往对多张表进行查询,对笛卡尔集用条件进行过滤,显示出所有匹配上的记录,匹配不上的则不进行显示,外连接则会会显示出所有的记录,不管有没有匹配上
-- 左外连接和右外连接
-- 左外连接,左边的表完全显示
-- 右外连接,右边的表完全显示
-- 列出部门名称和这些部门的员工信息(名字和工作),同时列出没有员工的部门
select dept.deptno,emp.ename,emp.job,emp.empno from emp right join dept on emp.deptno=dept.deptno-- 约束
-- 1、主键
-- 在一张表中最多只能有一个主键但可以是复合主键,主键不能重复也不能为null
-- 直接在字段名指定:字段名 primary key
-- 在表后面写primary(字段1,字段2,。。。。)
-- primary key = not null + uniquecreate table t1
(
id int primary key,
name varchar(10),
email varchar(25)
);
desc t1;
insert into t1(id,name,email) values(1,'tom','tom@163.com'),(2,'jack','jack@163.com')
select * from t1;
alter table t1 modify id varchar(10) not null default '';
-- 删除主键
alter table t1 drop primary key;
-- 添加主键
alter table t1 add primary key(name);-- 2、unique不允许这一列出现重复值,如果没有指定not null,则unique字段可以出现多个null,一张表也可以出现多个unique字段create table t2
(
id int unique,
name varchar(25),
email varchar(25)
);
alter table t2 add unique(name);
desc t2;
insert into t2 values(1,'tom','tom@163.com');
insert into t2 values(2,'tom','tom@163.com');-- 插入失败
select * from t2;
-- 3、外键
-- 用于定义主表从表的之间的关系,外键约束要定义在从表上,主表则必须具有主键约束或者unique约束,当定义外键约束后,要求外键列数据必须在主表的主键列存在或是为nullcreate table my_class
(
id int primary key,
name varchar(255) not null default ''
);
create table my_stu
(
id int primary key,
name varchar(255) not null default '',
class_id int,
foreign key(class_id) references my_class(id)
);
desc my_stu;
INSERT INTO my_class VALUES(100, 'java'), (200, 'web');
INSERT INTO my_class VALUES(300, 'php');
INSERT INTO my_stu VALUES(1, 'tom', 100);
INSERT INTO my_stu VALUES(2, 'jack', 200);
INSERT INTO my_stu VALUES(3, 'hsp', 300);
INSERT INTO my_stu VALUES(4, 'mary', 400); -- 这里会失败...因为400班级不存在
INSERT INTO my_stu VALUES(5, 'king', NULL);
delete from my_class where id=100; -- 删除失败
delete from my_stu where class_id=100;
delete from my_class where id=100; -- 删除成功-- 4、check MySQL8.0以前前不支持check,只做语法校验但不会生效,oracle、sql server支持,8.0以后添加了check约束
-- 非生成列和生成列允许被添加到表达式,但包含auto_increase的列不允许被加入
-- 字面量和确定性的内置函数以及操作符允许添加到表达式,确定性的含义是:同样的数据不同用户多次调用的结果是一样的
-- 存储函数和用户自定义函数不被允许
-- 可以通过触发器来实现check的功能
-- 查看客户端的版本
SHOW VARIABLES LIKE 'version';
create table t3
(
id int primary key,
name varchar(25),
sex varchar(6) check(sex in('man','woman')),
sal double check(sal>100 and sal<2000)
);
insert into t3 values(1,'tom','m',1100)  -- Check constraint 't3_chk_2' is violated.
select * from t3;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/92053.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

JUC——并发编程—第二部分

集合类不安全 list不安全 //报错 java.util.ConcurrentModificationException public class ListTest {public static void main(String[] args) {List<String> list new CopyOnWriteArrayList<>();//并发下Arrayist边读边写会不安全的/*** 解决方案&#xff1a…

iPhone苹果手机复制粘贴内容提示弹窗如何取消关闭提醒?

经常使用草柴APP查询淘宝、天猫、京东商品优惠券拿购物返利的iPhone苹果手机用户&#xff0c;复制商品链接后打开草柴APP粘贴商品链接查券时总是弹窗提示粘贴内容&#xff0c;为此很多苹果iPhone手机用户联系客服询问如何关闭iPhone苹果手机复制粘贴内容弹窗提醒功能的方法如下…

Java-API简析_java.util.Objects类(基于 Latest JDK)(浅析源码)

【版权声明】未经博主同意&#xff0c;谢绝转载&#xff01;&#xff08;请尊重原创&#xff0c;博主保留追究权&#xff09; https://blog.csdn.net/m0_69908381/article/details/133463511 出自【进步*于辰的博客】 因为我发现目前&#xff0c;我对Java-API的学习意识比较薄弱…

Linux Ubuntu配置Git的方法

本文介绍在Linux操作系统的Ubuntu版本中&#xff0c;配置分布式开源版本控制系统Git&#xff0c;随后基于Git克隆GitHub中项目的代码的详细方法。 在之前的文章分布式版本控制系统Git的下载、安装与使用其复制GitHub项目代码的方法&#xff08;https://blog.csdn.net/zhebushib…

【前段基础入门之】=>你不知道的 CSS 选择器的进阶使用!

导语&#xff1a; 在上一章节中&#xff0c;我们了解了 CSS 的一些基本语法概念&#xff0c;那么在这一章节中我们就带来 CSS 选择器知识的分享&#xff0c;选择器这一章的知识点有一点多&#xff0c;不过我们只要认真去理解&#xff0c;学习它也是没什么问题的&#xff0c;还有…

【模型压缩】Distiller学习-初认识

Distiller学习-初认识 简介 Intel AILab的神经网络压缩框架&#xff0c;建立在Pytorch基础上 安装 压缩方法 权重正则化方法权重剪枝方法训练后量化方法训练时量化方法条件计算低质分解方法知识蒸馏方法 总体目录 核心代码实现 所有案例的配置文件 举例 初始化网络评价网络…

SpringMVC处理请求流程

一、前言 SpringMVC是一个基于Java的轻量级Web框架&#xff0c;它使用Model-View-Controller&#xff08;MVC&#xff09;设计模式来处理Web请求。 二、请求实现 1、用户发送请求&#xff1a;用户通过浏览器或其他客户端工具向服务器发送一个HTTP请求&#xff0c;请求中包含…

hadoop.ipc:Client

org.apache.hadoop.ipc:Client []- Failed to connect towgqccbsun07/172.29.100.147:8032:server:retries get failed due to exceeded maximum allowed retries number:参考YARN 切换ResourceManager&#xff08;Failed to connect to server:8032 retries get failed due to…

基于Vue和Element UI实现前后端分离和交互

目录 前言 一、Element UI简介 1.Element UI是什么 2.Element UI的特点 二、项目搭建 1.创建一个SPA项目 2.安装 Element-UI 3.导入组件 4.创建登陆注册界面 登录组件---Login.vue 注册组件---Register.vue 定义组件与路由的对应关系 效果演示&#xff1a; 三、前…

1.4.C++项目:仿muduo库实现并发服务器之buffer模块的设计

项目完整版在&#xff1a; 一、buffer模块&#xff1a; 缓冲区模块 Buffer模块是一个缓冲区模块&#xff0c;用于实现通信中用户态的接收缓冲区和发送缓冲区功能。 二、提供的功能 存储数据&#xff0c;取出数据 三、实现思想 1.实现换出去得有一块内存空间&#xff0c;采…

Redis与分布式-集群搭建

接上文 Redis与分布式-哨兵模式 1. 集群搭建 搭建简单的redis集群&#xff0c;创建6个配置&#xff0c;开启集群模式&#xff0c;将之前配置过的redis删除&#xff0c;重新复制6份 针对主节点redis 1&#xff0c;redis 2&#xff0c;redis 3都是以上修改内容&#xff0c;只是…

string模拟实现

string模拟实现 整体代码 #pragma once #include<assert.h>namespace hqj {class string{public:friend ostream& operator<<(ostream& _cout, const hqj::string& s);friend istream& operator>>(istream& _cin, hqj::string& s)…

十、空闲任务及其钩子函数

1、空闲任务的介绍 (1)一个良好的程序&#xff0c;它的任务都是事件驱动的&#xff1a;平时大部分时间处于阻塞状态。 (2)有可能我们自己创建的所有任务都无法执行&#xff0c;但是调度器必须能找到一个可以运行的任务。所以&#xff0c;我们要提供空闲任务。 (3)在使用vTas…

格拉姆角场GAF将时序数据转换为图像并应用于凯斯西楚大学轴承故障诊断(Python代码,CNN模型)

1.运行效果&#xff1a; 格拉姆角场GAF将时序数据转换为图像并应用于故障诊断&#xff08;Python代码&#xff09;_哔哩哔哩_bilibili 环境库 只要tensorflow版本大于等于2.4.0即可运行 2.GAF的内容 GAF是一种用于时间序列数据可视化和特征提取的技术&#xff0c;通常用于…

计算机网络两位伟人

克劳德艾尔伍德香农 克劳德艾尔伍德香农&#xff08;Claude Elwood Shannon&#xff09;是一位美国数学家、电子工程师和计算机科学家&#xff0c;被誉为“信息论之父”。他于1916年生于密歇根州&#xff0c;于2001年去世。以下是一些关于他的详细介绍&#xff1a; 信息论的奠…

蓝桥等考Python组别八级007

第一部分:选择题 1、Python L8 (15分) 运行下面程序,输出的结果是( )。 i = 2 while i < 5: print(i, end = ) i += 1 2 3 4 5 61 2 3 4 52 3 43 4 5正确答案:C 2、Python L8 (

Linux——补充点(进程切换及页表映射)

目录 补充点1&#xff1a;进程地址空间堆区管理 补充点2&#xff1a;Linux内核进程上下文切换 补充点3&#xff1a;页表映射 补充点4&#xff1a;两级页表 补充点1&#xff1a;进程地址空间堆区管理 Linux内核通过一个被称为进程描述符的task_struct结构体来管理进程&#…

keil调试的时候没问题,下载时候没反应

今天遇到这样一个问题。我下载商家的代码例程后单片机没反应&#xff0c;进入调试的时候一切正常。很奇怪&#xff0c;在网上找了教程问题解决&#xff0c;总结一下。 原因在于程序下载进去后没有按下复位键&#xff0c;导致还是之前的程序。我之前设置的是下载后自动复位运行…

【STL】用一棵红黑树封装map和set

⭐博客主页&#xff1a;️CS semi主页 ⭐欢迎关注&#xff1a;点赞收藏留言 ⭐系列专栏&#xff1a;C进阶 ⭐代码仓库&#xff1a;C进阶 家人们更新不易&#xff0c;你们的点赞和关注对我而言十分重要&#xff0c;友友们麻烦多多点赞&#xff0b;关注&#xff0c;你们的支持是我…

玩转gpgpu-sim 04记—— __cudaRegisterBinary() of gpgpu-sim 到底做了什么

官方文档&#xff1a; GPGPU-Sim 3.x Manual __cudaRegisterBinary(void*) 被执行到的代码逻辑如下&#xff1a; void** CUDARTAPI __cudaRegisterFatBinary( void *fatCubin ) { #if (CUDART_VERSION < 2010)printf("GPGPU-Sim PTX: ERROR ** this version of GPGPU…