当前位置: 首页 > 编程日记 > 正文

mysql字符串外键约束_MySQL中的约束函数主外键

/*select语句有6大子句:

(1)from子句

(2)where子句

(3)group by子句

(4)having子句

(5)order by子句

(6)limit子句

强调:每一个select的6大子句的顺序是(1)-(6)

(1)from子句,后面跟表,视图,多行多列的二维表的结构

from意思从哪里筛选数据

(2)where子句:后面跟条件

where意思取那几行,要哪些行

(3)group by:后面跟字段

group by意思是分组

select 结果字段列表

from 表名称

where 条件

group by 分组字段列表;

要求: 结果字段列表中不要出现和分组无关的字段

(4)having:后面跟条件

having:意味着在分组统计结果中再次对统计结果加条件,不是对原表中的记录加条件

having和where的区别:

①where后面不能跟分组函数,having后面可以

②where是用于在原表的记录中筛选,having可以是对原表的筛选,但是更多的是用于对统计结果再加条件

(5)order by:后面跟字段或表达式

order by:排序

升序:省略asc或加asc

降序:desc

(6)limit:取几条记录

limit m,n

m表示从第几天记录开始取,n表示最多取n条件

通常用于分页查询*/#查询每个部门的人数SELECT did,COUNT(*)FROMt_employeeGROUP BYdid/*以下代码,语法不报错,但是语义有问题

建议、要求:分组查询的结果的字段列表中不要出现和分组无关的字段*/

SELECT ename,did,COUNT(*)FROMt_employeeGROUP BYdid

#查询每个部门的平均薪资SELECT did,AVG(salary)FROMt_employeeGROUP BYdid;

#查询每个部门的最高薪资SELECT did,MAX(salary)FROMt_employeeGROUP BYdid;

#查询每一个部门的男、女的最高薪资SELECT did,gender,MAX(salary)FROMt_employeeGROUP BYdid,gender;

#查询每一个部门的男、女的人数SELECT did,gender,COUNT(salary)FROMt_employeeGROUP BYdid,gender;

#查询每一个部门的薪资高于15000的员工的人数SELECT did,COUNT(*)FROMt_employeeWHERE salary > 15000

GROUP BYdid;

#having#查询每个部门的人数,只显示部门人数超过10人的/*select did,count(*)

from t_employee

where COUNT(*) > 10

group by did;

错误代码: 1111

Invalid use of group function*/

SELECT did,COUNT(*)FROMt_employeeGROUP BYdidHAVING COUNT(*) > 10#查询每个部门的男员工的人数,只显示人数超过2人SELECT did,COUNT(*)FROMt_employeeWHERE gender = '男'

GROUP BYdidHAVING COUNT(*) > 2#查询员工姓名和薪资,按照薪资的降序排列SELECTename,salaryFROMt_employeeORDER BY salary DESC#查询每个部门的员工的人数,按照人数的升序排列SELECT did,COUNT(*)FROMt_employeeGROUP BYdidORDER BY COUNT(*) ASC#查询每个部门的员工的人数,按照人数的升序排列,如果人数相同,按照did降序排列SELECT did,COUNT(*)FROMt_employeeGROUP BYdidORDER BY COUNT(*) ASC, did DESC#查询每个部门的男员工的人数,按照部门编号降序排列SELECT did,COUNT(*)FROMt_employeeWHERE gender = '男'

GROUP BYdidORDER BY did DESC#查询每个部门的男员工的人数,按照部门编号降序排列,显示人数超过1人SELECT did,COUNT(*)FROMt_employeeWHERE gender = '男'

GROUP BYdidHAVING COUNT(*)>1

ORDER BY did DESC

/*limit m,n

m:从第几条开始,第一条,用0表示

n:最多取n条

假设page代表第几页,nums代表每页显示的数量

limit (page-1)*nums ,nums

每页显示10条,第1页 limit (1-1)*10,10 -> limit 0,10

每页显示10条,第2页 limit (2-1)*10,10 -> limit 10,10

每页显示10条,第3页 limit (3-1)*10,10 -> limit 20,10

问?每页显示25条,第5页

limit (5-1)*25, 25*/#查询员工表的员工信息,每页显示10条,第1页SELECT *

FROMt_employee

LIMIT0,10#查询员工表的员工信息,每页显示10条,第2页SELECT *

FROMt_employee

LIMIT10,10#查询员工表的员工信息,每页显示10条,第1页SELECT *

FROMt_employee

LIMIT20,10

相关文章:

POJ 3683 【2-sat+求一组可行解】.cpp

题意: 有一个牧师要给好几对新婚夫妇准备婚礼.. 已知每对新婚夫妇的有空的时间以及婚礼持续时间.. 问是否可以让每对新婚夫妇都得到该牧师的祝福~ 如果可以就输出YES以及可行解 不可以就输出NO 输入: 一个n 表示有n对新婚夫妇 接下来n行每行a b c 表示在…

Matlab并行编程方法1

相信很多朋友在利用matlab进行计算时,会遇到循环次数过大,或者是单次计算量过大的问题,比如需要计算的数值阵列数据量过大,利用传统的编程方式,跑一次程序几个小时,都要等的急死了是不是呢?如果…

使用postman修改SAP Marketing Cloud contact主数据

Marketing Cloud里的contact主数据,创建成功后也不是所有字段都能够被修改。在Personal data区域的字段是可以被修改的。 比如我在“客户属性”字段里维护了一些值: 然后点保存: 其中第二个batch操作是通过一个roundtrip读取contact模型下多个…

java判断一个对象是否为空_Java中判断对象是否为空的方法的详解

首先来看一下工具StringUtils的判断方法:一种是org.apache.commons.lang3包下的;另一种是org.springframework.util包下的。这两种StringUtils工具类判断对象是否为空是有差距的:StringUtils.isEmpty(CharSequence cs); //org.apache.commons…

解决cocos2dx 3.x 导入cocostudio的ui界面出现错位问题

笔者今天发现导入cocostudio的ui界面时,会有部分控件出现错位的现象,后来我看了一下源码,发现是部分控件是没有继承 Layout类,导致不能设置控件位置造成,原因可以看看cocos2dx 源码的CCSGUIReader.cpp文件的函数&#…

Media Queries

支持情况罗列成如下表: Media Queries 使用 说起CSS3的新特性,就不得不提到 Media Queries 。 本文比较详细,所以很多实际中用不到。所以如果只是想简单了解Media Queries,推荐参考 CSS3 Media Queries 。 CSS2.1定义了 Media 的部…

AndroidStudio脚本命令指定AAR生成目录与版本号

A build.gradle全局常量: //根路径def ROOT_PATH rootProject.rootDir.pathdef GROUP "com.genialsir.mobileads"def MOB_SDK_VERSION_NAME "1.1.2" 复制代码 B 在当前库项目的build.gradle文件中android{}中配置如下: //自定义a…

文本文件 java_简单的用java实现读/写文本文件的示例

简单的用java实现读/写文本文件的示例更新时间:2008年07月26日 13:09:26 作者:同时也展示了如果从输入流中读出来内容写入输出流中(仅限文本流)三个例子可以独立存在,所以根据需要只看其中一个就行了。/** 简单的读/写文本文件的示例* 这里…

7个华丽的基于Canvas的HTML5动画

说起HTML5,可能让你印象更深的是其基于Canvas的动画特效,虽然Canvas在HTML5中的应用并不全都是动画制作,但其动画效果确实让人震惊。本文收集了7个最让人难忘的HTML5 Canvas动画,包括画板、文字、图表等,希望你会喜欢。…

网络工程师课程---4、网络层(网关是什么)

网络工程师课程---4、网络层(网关是什么) 一、总结 一句话总结: 必在当前网段:你到达另外一个网段必过的一个端口,所以必在当前网段 1、icmp如何检测双向通路的连通性? ping 命令 2、计算机1-65535这些端口…

团队分数分配方法——BY 李栋

作为一个团队,自然是一体的,所以要摒弃个人开发的不良习惯,互帮互助,共同进步。以期望在项目过程中能够不使一个人掉队,不因一个人的工作而使全队进度拖延。所以在分工的基础上还是要互帮互助,团队整体的分…

autowired java_Java 基础之Autowired 是否是自动注入

Java 基础之Autowired 是否是自动注入相信很多人对Autowired 注解理解不深入,或者是认为此注解就是spring的自动注入。相信看完本篇文章,你会有更加不一样的理解。首先我们先看下什么是手动注入?在我们的spring应用程序中,定义多个…

Eclipse进行可视化的GUI开发3大GUI插件

Eclipse进行可视化的GUI开发3大GUI插件 转自http://www.cnblogs.com/NationWoo/archive/2011/05/31/2065176.htmlEclipse并不自带GUI的可视化开发工具,那么如果要在Eclipse进行可视化的GUI开发,就需要依靠第三方的插件。 1. Visual Editor Eclipse官方提…

【BZOJ 4016】[FJOI2014]最短路径树问题

! 卡时过了 为什么我的这么慢?姿势不对??? -->谢 ws_fqk 我的Do(num[i])应该用 DO(root) 找了半天的root居然没有用.... define的教训永远忘不了了!!! 优化…

mongodb索引--从55.7秒到毫秒级别

从头开始,验证mongodb的索引的好处。(window7环境下) 下载mongodb服务器,并解压到d盘,并使用以下命令启动 mongod --dbpath D:\mongodb\datamongo客户端Robo 3T 去官网下载,安装准备数据,条数为1亿public static void …

汉字转16进制java_java实现汉字转unicode与汉字转16进制实例

本文实例讲述了java实现汉字转unicode与汉字转16进制的实现方法。分享给大家供大家参考。具体实现方法如下&#xff1a;一、汉字转unicodepublic static String toUnicode(String s){String as[] new String[s.length()];String s1 "";for (int i 0; i < s.len…

使用pytest对django项目单元测试

2019独角兽企业重金招聘Python工程师标准>>> 背景 使用django开发了个人博客&#xff0c;欲单元测试&#xff0c;后遍寻网络&#xff0c;然相关资料甚少&#xff0c;遂成此文&#xff0c;望对汝有所助 环境 pytestpytest-djangopytest-covpytest-htmldjangomixer测试…

jquery通知插件toastr

使用方法3个简单步骤对于其他API调用,看到演示。<link href"toastr.css" rel"stylesheet"/> <script src"toastr.js"></script> //显示一个信息没有标题 toastr.info(Are you the 6 fingered man?)其他选项/显示一个警告,没有…

1282. Game Tree

http://acm.timus.ru/problem.aspx?space1&num1282 简单博弈 注意题意的理解 代码&#xff1a; #include<iostream> #include<cstdio> #include<cstring> #include<string> #include<vector> #include<queue> #include<map> #i…

java web dao_JavaWeb项目,DAO应该怎么写?

有一张字段足够多的表&#xff0c;要对它进行各种各样的查询&#xff1a;根据字段A根据字段B&#xff0c;或者根据字段A和B&#xff0c;或者再加上字段C&#xff0c;然后可能还要加上分页&#xff0c;排序等等的逻辑。现在的项目的DAO层为了满足上面这些需要出现了很多参数列表…

2016 - 1- 21 - RunLoop使用(2016-1-24修改一次)(2016 - 1 - 24 再次修改)

一&#xff1a;常驻线程 &#xff1a;当需要一个线程一直处理一些耗时操作时&#xff0c;可以让它拥有一个RunLoop。具体代码如下&#xff1a; 1.通过给RunloopMode里加源来保证RunLoop不直接退出。 这里有个很重要得知识点&#xff0c;runloop对象如果mode为空得话&#xff…

【BZOJ1016】【Luogu P4208】 [JSOI2008]最小生成树计数 最小生成树,矩阵树定理

蛮不错的一道题&#xff0c;遗憾就遗憾在数据范围会导致暴力轻松跑过。 最小生成树的两个性质&#xff1a; 不同的最小生成树&#xff0c;相同权值使用的边数一定相同。不同的最小生成树&#xff0c;将其都去掉同一个权值的所有边&#xff0c;其连通性一致。这样我们随便跑一个…

Asterisk安装

一、获取asterisk安装包wget http://downloads.asterisk.org/pub/telephony/asterisk/releases/asterisk-1.6.0.tar.gz后面的版本号可以改变&#xff0c;可以安装的版本可以参考http://downloads.asterisk.org/pub/telephony/asterisk/releases/二、解压安装1. [root~]# tar -z…

java编写一个通讯录_java写的通讯录(小玩意)

上次有发个超级菜鸟级别的连接access的小程序受兄弟委托&#xff0c;如今表妹期末了&#xff0c;要写个通讯录于是草草的给写了个&#xff0c;毕竟有一个学期了&#xff0c;所以这次的代码会比较合理些……使用说明:实现技术:java语言,界面采用java swing编程,数据库用access数…

20175203 2018-2019 实验五《网络编程与安全》

20175203 2018-2019 实验五《网络编程与安全》 知识重点&#xff08;摘自实验资料&#xff09; 栈 &#xff1a;(Stack)是一种只允许在表尾插入和删除的线性表&#xff0c;有先进后出&#xff08;FILO&#xff09;&#xff0c;后进先出(LIFO)的特点。允许插入和删除的一端称为栈…

统计文件种类数+获取子shell返回值的其它方法

前言 只是作为一个shell的小小练习和日常统计用&#xff0c;瞎折腾的过程中也是摸到了获取子shell返回值的几种方法&#xff1b; 肯定还有别的方法&#xff0c;跟进程间的通信相关&#xff0c;希望你能提出建议和补充&#xff0c;谢谢~ 完整程序&#xff1a; #! /bin/bash #检查…

java中next的用法_关于java iterator的next()方法的用法

UYOUnext()是java迭代器类(Iterator)的方法&#xff0c;获得当前游标指向的下一个元素&#xff0c;详细说明和应用如下&#xff1a;1、迭代器(Iterator)介绍  迭代器是一种设计模式&#xff0c;它是一个对象&#xff0c;它可以遍历并选择序列中的对象&#xff0c;而开发人员不…

Python如何进行cross validation training

以4-fold validation training为例 (1) 给定数据集data和标签集label 样本个数为 sampNum len(data)(2) 将给定的所有examples分为10组 每个fold个数为 foldNum sampNum/10 (3) 将给定的所有examples分为10组 参考scikit-learn的3.1节&#xff1a;Cross-validation 1 impor…

Python的while循环

2019独角兽企业重金招聘Python工程师标准>>> 1.while循环的格式 while 条件:条件满足时&#xff0c;做的事情1条件满足时&#xff0c;做的事情2条件满足时&#xff0c;做的事情3...(省略)...demo i 0while i < 5:print("当前是第%d次执行循环" % (i …

LeetCode Add Binary

Given two binary strings, return their sum (also a binary string). For example,a "11"b "1"Return "100". 这题用数组来做可能更简单&#xff0c;但考虑到可能面试的时候要求不能开额外的数组&#xff0c;就只能对string操作了。最主要的…