Mysql1 晨考题

Mysql1 晨考题

1.描述主键、外键、候选主键、超键分别是什么 ?

(1)主键:数据库表中对存储数据对象给予唯一完整标识的数据列或属性的组合。一个数据列只能有一个主

键,且主键的取值不能缺失,即不能为空值(Null)。

(2)外键:在一个表中存在的另一个表的主键称为此表的外键。

(3)候选主键:是最小超键,即没有冗余元素的超键。

(4)超键:在关系中能唯一标识元素的属性集称为关系模式的超键。一个属性可以为作为一个超键,多个属性组

合在一起也可以作为一个超键。超键包含候选键和主键。

2.drop,delete 与 truncate 的区别 ?

(1)drop:用来删除表。

(2)delete:用来删除表中的数据。

(3)truncate:把表中的数据清空。

3.SQL 中的 UNION 和 UNION ALL 区别 ?

(1)union 去除重复数据,union all 不去除重复数据。

(2)union 将会按照字段的顺序进行排序,而 union all 只是简单的将两个结果合并后就返回。

4.exists、in、any 和 all 的区别 ?

(1)exists 表示存在判断,在使用 exists 的时候,如果子查询返回的结果集为真,则主查询返回结果。

(2)in 表示返回所有包含在 in 中的数据。

(3)any 表示满足任意一个条件。

(4)all 表示满足所有的条件。

5.SQL 语句的执行顺序 ?

SQL 语句执行顺序为:from—where—group by—having—select—order by—limit

6.count(*) 和 count(1) 和 count(id) 的区别 ?

(1)count(*) 表示查询有多少行数据,null 值也计入其中。

(2)count(1) 表示统计表中所有的记录数,null 值也计入其中。

(3)count(id) 表示根据 id 字段查询有多少行数据,null 值不计人其中。

7.SQL 语句优化(不少于6条)?

(1)应尽量避免在 where 子句中使用 or 来连接条件。

(2)应尽量避免在 where 子句中对字段进行函数操作。

(3)应尽量避免在 where 子句中对字段进行 null 值判断,否则将导致引擎放弃使用索引而进行全表扫描。

(4)任何地方都不要使用 select * ,用具体的字段列表代替 “*”,不要返回用不到的任何字段。

(5)尽可能的使用 varchar/nvarchar 代替 char/nchar ,因为首先变长字段存储空间小,可以节省存储空间。

(6)其次对于查询来说,在一个相对较小的字段内搜索效率显然要高些。

(7)尽量避免向客户端返回大量数据,若数据量过大,应该考虑相应需求是否合理。

(8)尽量避免大事务操作,提高系统并发能力

8.SQL 常用的函数有哪些 ?

SQL 常用的函数有 sum、max、min、avg、count、day

9.SQL 中用于拼接字符串的语句是 ?

concat (str,…,strN)

10.左连接,右连接和内连接的区别 ?

(1)左连接:左表无条件完全显示,右表满足条件连接,不满足条件的右表补 null 显示。

(2)右连接:右表无条件完全显示,左表满足条件连接,不满足条件的左表补 null 显示。

(3)内连接:只有满足条件的数据才会显示。

1.什么是索引 ?

(1)索引是一种特殊的文件,包含着数据表里所有记录的引用指针。

(2)索引是数据库管理系统中一个用于排序的数据结构,能够快速查询和更新数据库表中数据,索引的实现通常

使用 B 树及其 B+ 树。

2.索引的种类有哪些 ?区别是什么 ?

(1)主键索引:数据列不允许重复,不允许为 Null ,一个表中只能有一个主键。

(2)唯一索引:数据列不允许重复,允许为 Null ,一个表中允许多个列创建唯一索引。

(3)普通索引: 基本的索引类型,没有唯一性的限制,允许为 Null。

(4)全文索引:主要用来查找文本中的关键字,而不是直接与索引中的值相比较。

3.描述索引的优缺点 ?

(1)优点:可以大大加快数据的检索速度,通过使用索引可以在查询的过程中,使用优化隐藏器提高系统的性

能。

(2)缺点:创建和维护索引需要耗费时间,当对表中的数据进行操作时,会降低增删改查的执行效率,索引需要

占用物理空间。

4.设计索引的原则 ?(不少于4条)

(1)如果对字符串列进行索引,应该指定一个前缀长度。

(2)利用最左前缀 。

(3)不要过度使用索引。

(4)对于经常查询的字段建议创建索引。

(5)不要在区分度低的字段中使用索引。

5.什么情况下索引会失效 ?(不少于4条)

(1)条件中有 or。

(2)以 % 开头的 like 查询。

(3)where 子句中使用操作符。

(4)where 子句中对字段进行函数操作。

6.数据库优化方案 ?(至少3条)

(1)将含有字段的表进行分表。

(2)建立合理索引。

(3)增加中间表。

(4)使用缓存。

(5)保留冗余字段。

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

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

相关文章

C语言关键字

C语言do、while、for关键字—循环 C 语言中循环语句有三种:while 循环、do-while 循环、for 循环。while 循环:先判断while 后面括号里的值,如果为真则执行其后面的代码;否则不执行。while(1)表示死循环。…

C语言字符篇(五)内存函数

memcpy不可以把目的地址写成本身但是memmove可以,因为它是先保存到临时空间 #include <string.h> void *memcpy(void *dest, const void *src, size_t n);将内存src拷贝n个字符到内存destvoid *memmove(void *dest, const void *src, size_t n);将内存src的前n个数据拷贝…

GMQ交易平台大力探索区块链技术,进一步推动产业繁荣

近年来&#xff0c;区块链技术作为金融科技的中坚力量&#xff0c;受到了产业界的热切关注&#xff0c;其实验开展和应用研发正在如火如荼的进行。 在此背景下&#xff0c;各地涌现出一大批优秀的企业投入到区块链产业中&#xff0c;各类企业投融 资活动十分活跃&#xff0c;充…

java 笔试题

JAVA-2003笔试题 一、选择题&#xff08;每小题2&#xff0c;共10分&#xff09; 下列语句序列执行后&#xff0c;m 的值是&#xff08; C &#xff09; int a10, b3, m5; if( ab ) ma; else ma*m; A.15 B.50 C.55 D.5若已定义byte[]x{11,22,33,-66}其中0≤k≤3&#xff0c;则…

objectdatasouce的温故

在做ecxel的时候&#xff0c;需要前台做一个联动的效果。 记录一下这个数据源的用法&#xff0c;大学时候用的&#xff0c;忘得差不多了 首先就是往页面拖拽一个objectdatasouce的控件 然后配置数据源&#xff1a; 选择业务对象(其实就是选择你要用的哪个类&#xff0c;如果下拉…

都会五星回评,欢迎留下地址-博客之星

欢迎五星回评地址https://bbs.csdn.net/topics/603961857

jQuery核心

jQuery(selector) jQuery 的核心功能都是通过这个函数实现的。 jQuery中的一切都基于这个函数&#xff0c;或者说都是在以某种方式使用这个函数。这个函数最基本的用法就是向它传递一个表达式&#xff08;通常由 CSS 选择器组成&#xff09;&#xff0c;然后根据这个表达式来查…

Feign api调用方式

Feign使用简介 基本用法 基本的使用如下所示&#xff0c;一个对于canonical Retrofit sample的适配。 interface GitHub {// RequestLine注解声明请求方法和请求地址,可以允许有查询参数RequestLine("GET /repos/{owner}/{repo}/contributors")List<Contributor&g…

预处理

C语言##预算符 和#运算符一样&#xff0c;##运算符可以用于宏函数的替换部分。这个运算符把两个语言符号组合成单个语言符号。看例子&#xff1a;#define XNAME(n) x ## n如果这样使用宏&#xff1a;XNAME(8)则会被展开成这样&#xff1a;x8看明白了没&#xff1f; ##就是个粘合…

Lambda表达式使用2

1.概述    本篇主要介绍lambda中常用的收集器&#xff0c;收集器的作用就是从数据流中生成需要的数据接口。    最常用的就是Collectors.toList()&#xff0c;只要将它传递给collect()函数&#xff0c;就能够使用它了。    在我们使用收集器的时候经常会用到“方法…

notepad++ 使用去掉自动检查红线

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程。 notepad新升级了之后就有自动判断的红线&#xff0c;单词拼错了就给提示&#xff0c;看着这红线实在难受 在 菜单选项&#xff1a;[插件…

cAdvisor+InfluxDB+Grafana 监控Docker

容器的监控方案其实有很多&#xff0c;有docker自身的docker stats命令、有Scout、有Data Dog等等&#xff0c;本文主要和大家分享一下比较经典的容器开源监控方案组合&#xff1a;cAdvisorInfluxDBGrafan 一、概念 1). InfluxDB是什么nfluxDB是用GO语言编写的一个开源分布式时…

C语言return关键字

return 用来终止一个函数并返回其后面跟着的值。return &#xff08;Val&#xff09;&#xff1b;//此括号可以省略。但一般不省略&#xff0c;尤其在返回一个表达式的值时。return 可以返回些什么东西呢&#xff1f;看下面例子&#xff1a;char * Func(void){char str[30];…r…

win7旗舰版怎么降级到专业版

一、操作准备及注意事项 1、UltraISO光盘制作工具9.5 2、备份C盘及桌面文件 二、win7旗舰版改成专业版的步骤 1、当前系统为Win7 SP1 64位旗舰版&#xff1b; 2、按WinR打开运行&#xff0c;输入regedit打开注册表编辑器&#xff0c;定位到HKEY_LOCAL_MACHINE\Software\Microso…

JPA criteria 查询:类型安全与面向对象

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程。 JPA的标准查询,名为:JPA criteria查询. 相比JPQL,其优势是类型安全,更加的面向对象.使用标准查询,开发人员可在编译的时候就检查 查询的…

Algs4-1.4.18数组的局部最小元素

1.4.18数组的局部最小元素。编写一个程序&#xff0c;给定一个含有N个不同整数的数组&#xff0c;找到一个局部最小元素:满足a[i]<a[i-1],且a[i]<a[i1]的索引i。程序在最坏情况下所需的比较次数为~2lgN。答&#xff1a;检查数组的中间值a[N/2]以及和它相邻的元素a[N/2-1]…

编程技能和做员工的技能——哪个更重要?

摘要&#xff1a;不管我们程序员如何认识这个问题&#xff0c;如果你想在给别人编程打工中获得事业成功&#xff0c;编程技能不是第一重要的。学会如何做一个好的员工才是重要的&#xff0c;甚至是非常重要的。从最最基本的层面上讲&#xff0c;每个员工都应该为最求两种基本的…

nginx-exporter安装使用

一、没有vts的启动方式 #nginx_exporter -telemetry.address:9113 -nginx.scrape_uri"http://127.0.0.1:10000/nginx_statusnginx_exporter -telemetry.address:9113 -nginx.scrape_uri"https://xx.xx.xx.xx:18443" -insecure #端口9113应该是nginx_exporter监…

spring data jpa 的 in 查询 Specification 实现

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程。 只是一个简单需求&#xff1a; 查询所有部门id 属于 idList 的数据 Page<WorkWeight> page workWeightRepository.findAll(new…

在移动互联网上赚钱,行不行

移动互联网已被证实是互联网产业发展的大趋势。不过&#xff0c;究竟如何赚钱&#xff0c;对海外企业与中国企业来说都是难题。本月初&#xff0c;几位业界大佬与风投来了一番讨论&#xff0c;议题还是一个“在移动互联网上赚钱&#xff0c;行还是不行”。 百度试图通过用户习惯…