python查看关键字列表的命令是_Python 41 完整查询语句 和 一堆关键字

一:完整查询语句

1、拷贝表 ***

create table copy_table select *from customer ; 拷贝结构 与数据

create table copy_table select *from customer where 0 > 1; 仅拷贝结构

共同点: 索引 不能拷贝   描述不能拷贝(自增)

[ ] 表示可选的

{ }表示必选的

insert [into] 表名[字段名] value|values(字段值....);

into 可省略     [字段名] 可选         如果写了,你后面的值必须与写的字段匹配;不写,后面的值必须和表的结构完全匹配

value 插入一条记录

values 插入多条记录

update 表名 set 字段名 = 新的值[,字段n = 新值n]  [where 条件]    可以同时修改多个字段用逗号隔开,注意最后一个字段不能加逗号

where 可选         有就修改满足条件的记录,没有就全部修改

delete from 表名 [where 条件]

where 可选         有就删除满足条件的记录,没有就全部删除,如果你需要全部删除 请使用truncate table 表名,

delete 是逐行比对  删除 效率低

delete删除的行号会保留

查询:完整的查询语句

select  [distinct] {* | 字段名 | 聚合函数 | 表达式} from 表名

[where 条件

group by 字段名

having 条件

order by 字段名

limit 显示的条数]

注意: 关键字的顺序必须与上述语法一致

简单查询 ******

1.* 表示所有列 都显示

2.也可以手动指定要显示的列  可以是多个

3.distinct 用于去除重复的记录,只取出完全相同的记录,当然,也可以手动指定要显示的列 从而来去重

4.表达式  支持四则运算

执行顺序

def select()

from() 打开文件

where() 读取每一行并判断是否满足条件

group() 对数据进行分组

having() 再分组之后进行过滤

having不单独出现 仅用于分组之后进行过滤

distinct() 去重

order() 用于对筛选后的数据 进行排序

limit() 限制显示的条数

最后根据select后制定的字段来显示数据

准备数据:

create table stu(idint primary key auto_increment,name char(10),math float,english float); insert into stu values(null,"赵云",90,30); insert into stu values(null,"小乔",90,60); insert into stu values(null,"小乔",90,60); insert into stu values(null,"大乔",10,70); insert into stu values(null,"李清照",100,100); insert into stu values(null,"铁拐李",20,55); insert into stu values(null,"小李子",20,55);

查询所有人的总成绩select name,english+math 总分 fromstu;select name,english+10 英语 fromstu;

需要 在字段的数据前加上字段名:

name:赵云 english:90 math:30需要使用字符串拼接函数

concat(字符串)

案列:selectconcat("name:",name),

concat("english:",english),

concat("math:",math)from stu;

小练习

观光代码 **

select (case

when english + math < 150 then

concat(name," shit")

when english + math >= 150 then

concat(name," nice")

end) 评语 from stu;

二:一堆关键字

where 条件           ******

group by 字段名   ***

having 条件          ***

order by 字段名    *****

limit 显示的条数]   *******

where

从硬盘上读取数据时的一个过滤条件

where 的筛选过程     在没有索引的情况下,挨个比较效率低,所以我们应该给表添加索引

group by

作用 用于给数据分组

为什么要分组?  思考生活为什么要分组

1.在生活中是为了方便管理

2.在数据库中是为了 方便统计

按照部门给数据分组  select *from emp group by dept;

有两种情况

1.sql_mode中 没有设置 ONLY_FULL_GROUP_BY 显示每个组的第一条记录 没有意义 所以新版中 自带ONLY_FULL_GROUP_BY

2.sql_mode中有设置 ONLY_FULL_GROUP_BY  直接报错

原因是:  * 表示所有字段都要显示  但是 分组后 记录的细节被隐藏 只留下了

这意味着:只有出现在group by 后面的字段才能被显示

分组是为了统计分组数据  如何统计?

需要使用到聚合函数

聚合函数:

将一堆数据经过计算,得到一个数据

sum() 求和

avg() 求平均数

max()/min() 求最大值 / 最小值

count() 个数

准备数据

create table emp (idint,name char(10),sex char,dept char(10),job char(10),salary double);

insert into emp values (1,"刘备","男","市场","总监",5800),

(2,"张飞","男","市场","员工",3000),

(3,"关羽","男","市场","员工",4000),

(4,"孙权","男","行政","总监",6000),

(5,"周瑜","男","行政","员工",5000),

(6,"小乔","女","行政","员工",4000),

(7,"曹操","男","财务","总监",10000),

(8,"司马懿","男","财务","员工",6000);

练习一

查询每个部⻔门有⼏几个⼈人select dept,count(*) fromemp group by dept;

计算每个部⻔门的平均⼯工资select avg(salary) fromemp group by dept;5.查询平均⼯工资⼤大于5000的部⻔select avg(salary) from emp where avg(salary) > 5000group by dept;where语句后面 不能使用聚合函数select avg(salary) from emp;

练习二

练习一:

总结 :什么时候需要使用分组   只要你的需求中 带有 每个这样的字眼 就需要分组 每个岗位  每个部门  每个性别

练习二:

总结 :where 条件不能用于筛选分组后的数据

group_concat 用于分组后 将组中的某些字段拼接成字符串

select  dept,group_concat(name) from emp group by dept;

having

用于对分组后的数据进行过滤

having不会单独出现 都是和group by 一起出现

与where的区别

相同点: 都用于过滤数据

不同点:

1.where是最先执行   用于读取硬盘数据;having 要等到数据读取完之后 才能进过滤 比where晚执行

2.where中不能使用聚合函数;having中可以

需求:5.查询平均⼯工资⼤大于5000的部⻔select dept,avg(salary) from emp group by dept h0aving avg(salary) > 500;6.查询工资最高的人的姓名和他的工资

需要用到子查询

having小练习

order by [desc,asc]

用于对记录进行 排序

desc为降序     asc为升序

按照工资的从低到高顺序 显示所有的员工     select *from emp order by salary;     默认为升序

修改为降序     select *from emp order by salary desc;

按照每个部门的平均工资 降序排序     select dept,avg(salary) from emp group by dept order by avg(salary) desc;

limit  *******

用于限制显示的条数     limit [start,]count

看看表里前三条数据     select *from emp limit 3;

看看表里的3-5条     select * from emp limit 2,3;

看工资最高的那个人的信息     select *from emp order by salary desc limit 1;

limit 常用于 数据的分页展示  比如腾讯新闻 的上拉加载新的而一页

select *from emp limit 0,10; 第一页     页数 减1  乘以条数 得到起始位置

select *from emp limit 10,10; 第2页

select *from emp limit 20,10; 第3页

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

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

相关文章

程序员的技术人生

文章目录第一阶段&#xff0c;高级程序员第二阶段&#xff0c;技术经理第三阶段&#xff0c;技术总监第四阶段&#xff0c;架构师第五阶段&#xff0c;CTO人们常常把 CTO、架构师、技术经理的头衔&#xff0c;乱授予技术负责人。在国内这种现象尤其严重。比如&#xff0c;一个初…

python csv转为html,在Python中将CSV转换为HTML表格

首先安装熊猫&#xff1a;pip install pandas然后运行&#xff1a;import pandas as pdcolumns [age, week, opp, ACscr, OPPscr, location]df pd.read_csv(Crushers.csv, namescolumns)# This you can change it to whatever you want to getage_15 df[df[age] U15]# Othe…

python椭圆拟合_opencv python 轮廓特征/凸包/外接矩形/外接圆/拟合矩形/拟合直线/拟合圆...

Contour Features1 图像的矩cv2.moments()图像的矩可以帮助计算物体的某些特征&#xff0c;如对象的质心&#xff0c;对象的区域等.代码&#xff1a;import cv2import numpy as npimg cv2.imread(img7.png,0)ret,thresh cv2.threshold(img,127,255,0)im2,contours,hierarchy …

RPM 软件包命名规范

文章目录命名格式示例命名格式 name-version-release.os.arch.rpm&#xff0c;软件名称-版本号-发布次数.适合linux系统.硬件平台.rpm name&#xff1a;程序名称 version&#xff1a;程序版本号 release&#xff1a;用于标识 RPM 包本身的发行号&#xff0c;其实就是软件包…

junit5和junit4_JUnit 5符合AssertJ

junit5和junit4JUnit 5在断言库中带来了很多改进&#xff0c;这主要归功于Java 8和Lambda Expression的支持以及新断言&#xff08;如assertAll &#xff0c; assertTimeout或assertThrows 。 尽管我非常喜欢JUnit 5&#xff0c;但我相信AssertJ在生产级单元测试中仍然是必不可…

微信html人脸识别接口,微信人脸识别可视化的实现:

实现方式主要通过以下模块实现&#xff1a;DateFromWebChat (从网页版微信窗口下载好友头像)AI (识别模块&#xff0c;主要用于识别好友头像是否为人脸&#xff0c;并且计算人脸的数量与头像的总数且return)DateVisul (数据可视化模块&#xff0c;用与AI模块返回参数的可视化)u…

安卓手机端运行的adb工具_MQTT通信手机端接收生产车间设备运行信息3

应用场景&#xff1a;对车间重点设备的运行参数进行实时跟踪。比如烘干炉的烟囱温度、TNV的出口温度、喷漆室的温湿度、小时产量等等信息。以前这些信息的获取都需要在电脑端获取、相对比较繁琐。这里我们选择在手机端实现获取这些信息。尤其是对于作者这样的设备负责人而言&am…

Linux 命令之 tree -- 以树状图列出目录的内容/查看目录内容

文章目录一、命令介绍二、常用选项三、命令示例&#xff08;一&#xff09;按树形结构显示当前目录下的内容&#xff08;二&#xff09;按树状图显示当前目录下的所有目录名称而非文件&#xff08;三&#xff09;列出指定目录下的第一层级的文件和目录名称&#xff08;四&#…

jsf 项目_您将在下一个项目中使用JSF吗?

jsf 项目上周有一篇很棒的stackoverflow博客文章&#xff0c;主题是“ Javascript框架的残酷生命周期” 。 这篇文章是关于Javascript UI框架&#xff08;angularjs&#xff0c;angular&#xff0c;jquery和react&#xff09;的流行和流行的速度。 这篇文章的关键指标是每月关于…

html 定时刷新 数据,js中,设置定时器 每隔几秒刷新一次页面数据

页面加载进来&#xff0c;查询 然后设置定时器 每隔五秒刷新一次页面数据fnSearch();var interval3setInterval(function(){fnSearch();},5000);function fnSearch(){searchjson.search$(".iptsearch").val();$.ajax({url:/movecheck/getCheckInfo,data:searchjson,…

查询varchar实际大小_微服务和VUE(11): mybatis 动态查询

1. 新建class表和student表&#xff1a;CREATE TABLE class ( class_id varchar(20) NOT NULL, class_name varchar(50) DEFAULT NULL, headmaster_name varchar(20) DEFAULT NULL, headmaster_tel varchar(20) DEFAULT NULL, PRIMARY KEY (class_id)) ENGINEInnoDB …

Linux 中 ctime,mtime,atime 的区别

文章目录改变和修改的区别ctimemtimeatime查看文件时间关于 relatime改变和修改的区别 改变和修改之间的区别在于是改变文件的属性还是改变文件的内容。如果有人说 chmod a-w myfile&#xff08;删除所有用户对文件 myfile 的写权限&#xff09;&#xff0c;那么这叫改变&…

java迭代器删除两个_两个迭代器的故事

java迭代器删除两个当您查看最流行的Java面试问题时&#xff0c;您可能会遇到有关故障快速和故障安全迭代器的问题&#xff1a; 故障快速迭代器和故障安全迭代器之间有什么区别&#xff1f; 简化的答案是&#xff1a; 如果在迭代过程中修改了集合&#xff0c;则快速失败迭代器…

Linux 命令之 stat -- 显示文件的状态信息

文章目录一、命令介绍二、命令语法三、常用选项四、命令示例&#xff08;一&#xff09;显示文件的状态信息&#xff08;二&#xff09;以简洁方式输出文件的状态信息&#xff08;三&#xff09;显示文件所属的文件系统状态信息一、命令介绍 用于显示文件的状态信息。stat命令…

python tkinter滚动条不起作用_Tkinter滚动条不工作

我有一段运行在python3.4上的tkinter代码&#xff0c;它是一个放在画布上的带有垂直滚动条的大框架&#xff0c;但是滚动条是灰色的&#xff0c;似乎没有与框架的大小相关联。我使用的代码基本上是&#xff1a;class EntryWindow:def __init__(self, master):self.master mast…

大工17秋《计算机文化基础》在线测试1,大工17秋《组织行为学》在线测试1答案...

大工17秋《组织行为学》在线测试1一、单选题&#xff1a;1.根据气质的分类&#xff0c;较适合做推销工作的人员的气质类型是( )。 (满分:3)A.胆汁质B.多血质C.抑郁质D.黏液质正确答案:[hide]——B——[/hide]2.组织行为学在中观层面所要研究的主要内容是( )。 (满分:3)A.个体心…

java分页中显示更多_早期更多失败– Java 8

java分页中显示更多快速失败或早期失败是一种软件工程概念&#xff0c;旨在通过在不应该发生的事情发生时立即停止执行来防止复杂问题的发生。 在之前的博客文章和演示中&#xff0c;我将详细介绍这种方法的优点&#xff0c;在此博客文章中&#xff0c;我将详细介绍Java 8中该思…

计算机组装与维修单招,单招职二 计算机组装与维修试卷.doc

单招职二 计算机组装与维修试卷高二 计算机组装与维修试卷一、填空题(每空1分&#xff0c;共计30分)1.一个完整的计算机系统是由______________和______________两部分组成的。2.为了更好的为CPU散热&#xff0c;在安装风扇前&#xff0c;先在CPU芯片的顶部均匀地涂抹上一层___…

普通人学python好吗_有人问,普通人学python真的有意义吗?看看大家都是怎么说的吧...

普通人学python有意义吗&#xff1f;现在随着python越来越火&#xff0c;尤其是它成为了人工智能的第一编程语言&#xff0c;还被纳入了中小学的教育中。并且python的应用范围很广泛&#xff0c;可以解决很多专业或非专业的问题。但python真的适合普通人学习吗&#xff1f;我个…

Linux 如何安装程序的源代码软件包/源码程序包/源码包?

文章目录一、安装源码包的三个步骤&#xff08;一&#xff09;执行命令 configure&#xff0c;进行配置/检测&#xff08;二&#xff09;执行命令 make&#xff0c;编译源码&#xff08;三&#xff09;执行命令 make install&#xff0c;安装软件二、源码包安装示例&#xff08…