网站首页 > 技术文章 正文
本系统为@牛旦教育IT课堂在微头条上的内容,
为便于查阅,特辑录于此,都是常用SQL基本用法。。
前两篇连接:
(三):常用SQL系列之(三):记录叠加、匹配、外连接及笛卡尔等
(四):常用SQL系列之:Null值、插入方式、默认值及复制等
(五):常用SQL系列之(五):多表和禁止插入、批量与特殊更新等
(六):常用SQL系列之(六):删除方式、数据库、表及索引元信息查询等
SQL点滴(42):如何直接通过SQL语句查看数据表的约束信息?
也就是说,我想查看数据库中某一表的约束定义以及所基于的约束列信息,那在数据库中如何实现呢?
1)在MySQL中,可以通过这样系统表(information_schema.table_constraints 和information_schema.key_column_usage)进行关联查询。参考语句如下:
SELECT
a.table_name,
a.constraint_name,
b.column_name,
a.constraint_type
FROM
information_schema.TABLE_CONSTRAINTS a,
information_schema.key_column_usage b
WHERE
a.TABLE_NAME = 'tx_department'
AND a.TABLE_SCHEMA = 'test'
AND a.TABLE_NAME = b.TABLE_NAME
AND a.TABLE_SCHEMA = b.TABLE_SCHEMA
AND a.CONSTRAINT_NAME = b.CONSTRAINT_NAME
以上实现也可以直接适用SQL Server和PostgreSQL。
2)在Oracle中,通过查询系统表SYS.ALL_CONSTRAINTS和SYS.ALL_CONS_COLUMNS参考语句如下所示:
select a.table_name,a.constraint_name,b.column_name,a.constraint_type
from all_constraints a, all_cons_columns b
where a.table_name = 'mytable'
and a.owner = 'mydb'
and a.table_name = b.table_name
and a.owner = b.owner
and a.constraint_name = b.constraint_name ;
3)在DB2中,通过查询系统表SYSCAT.TABCONST和SYSCAT.COLUMNS来查看约束,具体实现,自己动手来试试吧。
SQL点滴(43):数据表中对数字列的平均值计算问题 。
如果我们我们要对员工表的 薪资列进行平均值进行统计计算,需要注意如下问题:
1)按部门计算各部门的薪资平均值,参考SQL如下:
select deptno,avg(salary) as avg_sal from employee group by deptno ;
注意这里是按部门进行分组在进行平均值计算的;
2)对所有员工进行平均值进行计算,参考SQL如下:
select avg(salary) as avg_sal from employee ;
不带where子句,对所有非null值进行计算;
3)若要对null值也进行平均计算,你可以使用我们前面说过的函coalesce函数,参考如下:
select avg(coalesce(salary,0)) from employee ;
需要注意,group by 列 不一定要包含在select列表中。
好了,你自己操练一把吧。^_^
SQL点滴(44):如何找出某列中的最大/最小值 ?
比如计算雇员列表中薪资列中的最大值和最小值。当然你还可以扩展每个部门的最高值和最低值。要实现这个目的,我们可以这么干,参考SQL如下:
select min(salary) as min_sal,max(salary) as max_sal from employee ;
若要查看每个部门的最高工资和最低工资,那要怎么做?也就是要根据部门分组再进行类似上面的查询,参考SQL如下:
select deptno, min(salary) as min_sal,max(salary) as max_sal
from employee group by deptno ;
特别注意:min和max函数会忽略null值。假设上述有两个部门10和99的,而salary为null,那上面的结果就会有只有部门号而没有大小值的行出现。
好了今天的一则分享就这些,试试看看。^_^
SQL点滴(45):如何计算数据表中某列非NULL值的数量?
也就是说,数据表某类的列值,可以有值,也可以为空,如何只计算非空的列数呢?
其实这是个细节问题,只要稍加注意就可计算出。当我们用count(*)来计算行时,是包含null值和非null值的的。但如果是指明列明,则就不会把null计算在内。所以,为了完成上述任务,比如想计算有奖金的员工数量,可以这样来实现:
select count(reward) from bonus.
就这么简单,试试吧。
本篇就辑录到这,点个赞分享出去吧。
猜你喜欢
- 2025-07-10 分布式之系统底层原理(上)(底层分布式技术)
- 2025-07-10 MySQL面试题整理:从基础到高级的全面覆盖
- 2025-07-10 MySQL从入门到实战:表设计、索引优化与高频面试解析
- 2025-07-10 Spring框架基础知识-第三节内容(spring框架用法)
- 2025-07-10 一个非教条式的TDD例子(一个非一个虫)
- 2025-07-10 SQL 开发必学:深度解析 NULL 值处理的 6 大核心规则与避坑指南
- 2025-07-10 关系型数据库设计要领(值得收藏)(关系型数据库有哪些设计范式)
- 2025-07-10 Oracle数据库中判断字段不为空?(oracle数据库中判断字段不为空的函数)
- 2024-10-17 oracle数据库设计总结|三大范式 oracle数据库设计规范
- 2024-10-17 数据库(Oracle)序列(Sequence)的基本使用
你 发表评论:
欢迎- 07-10Oracle 与 Google Cloud 携手大幅扩展多云服务
- 07-10分享收藏的 oracle 11.2.0.4各平台的下载地址
- 07-10Oracle 和 Microsoft 推出 Oracle Exadata 数据库服务
- 07-10Oracle Database@Azure 推进到南美等新区域并增加了新服务
- 07-10Oracle宣布推出 Oracle Database@AWS 的有限预览版
- 07-10Oracle与Nextcloud合作,推出主权云上的安全协作平台
- 07-10NodeRED魔改版连接MsSql、PostgreSQL、MySQL、OracleDB存储无忧
- 07-10对于企业数据云备份,“多备份”承诺的是成本更低,管理更高效#36氪开放日深圳站#
- 601℃几个Oracle空值处理函数 oracle处理null值的函数
- 593℃Oracle分析函数之Lag和Lead()使用
- 581℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 578℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 573℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 566℃【数据统计分析】详解Oracle分组函数之CUBE
- 552℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 547℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
-
- Oracle 与 Google Cloud 携手大幅扩展多云服务
- 分享收藏的 oracle 11.2.0.4各平台的下载地址
- Oracle 和 Microsoft 推出 Oracle Exadata 数据库服务
- Oracle Database@Azure 推进到南美等新区域并增加了新服务
- Oracle宣布推出 Oracle Database@AWS 的有限预览版
- Oracle与Nextcloud合作,推出主权云上的安全协作平台
- NodeRED魔改版连接MsSql、PostgreSQL、MySQL、OracleDB存储无忧
- 对于企业数据云备份,“多备份”承诺的是成本更低,管理更高效#36氪开放日深圳站#
- 解读丨《归档文件整理规则》— 电子文件元数据存储
- Data Guard跳归档恢复的实践(dataguard failover)
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- 前端获取当前时间 (50)
- Oracle RAC (76)
- oracle恢复 (77)
- oracle 删除表 (52)
- oracle 用户名 (80)
- oracle 工具 (55)
- oracle 内存 (55)
- oracle 导出表 (62)
- oracle约束 (54)
- oracle 中文 (51)
- oracle链接 (54)
- oracle的函数 (57)
- 前端调试 (52)
本文暂时没有评论,来添加一个吧(●'◡'●)