JAVA-软开-常见八股文(2)-数据库相关

这篇具有很好参考价值的文章主要介绍了JAVA-软开-常见八股文(2)-数据库相关。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1 Drop Delete Truncate三者之间的区别和联系

drop删除整张表,包括表结构和表数据。用法 drop table 表名

truncate表示清空数据,不会删除表结构。truncate table 表名

delete表示删除数据,不会删除表结构。delete from 表名 where 列名 = 值,

那么,truncate和delete的区别:

            truncate属于 DDL(数据定义语言)语句,操作立即生效,原数据不放到 rollback segment 中,不能回滚,操作不触发 trigger。由DBA所使用。不产生日志信息

            delete 语句是 DML (数据库操作语言)语句,这个操作会放到 rollback segment 中,事务提交之后才生效。开发人员日常使用较为频繁。产生数据的binlog日志。
 

一般来说执行效率:drop > truncate > delete。

2 SQL查询语句中的Limit关键词的用法。

select _column,_column from _table [where Clause] [limit N][offset M] select * : 返回所有记录

limit N : 返回 N 条记录

offset M : 跳过 M 条记录, 默认 M=0, 单独使用似乎不起作用

limit N,M : 相当于 limit M offset N , 从第 N 条记录开始, 返回 M 条记录

以下表示均为找表table_a的前5行数据。

    1 select * from table_a limit 5;    --> limit n; 表示前n行数据

    2 select * from table_a limit 0, 5;  --> limit m , n ;表示第m+1,到第m+ n行的n条数据

    3 select * from table_a limit 5 offset 5;  --> limit n offset m ;  表示的是偏移m行,从第m+1到第n行的n条数据。

常见的分页查询

select * from _table limit (page_number-1)*lines_perpage, lines_perpage

或

select * from _table limit lines_perpage offset (page_number-1)*lines_perpage

3. where group by和Having的先后顺序

SELECT cust_name, COUNT() AS num 
FROM Customers 
WHERE cust_email IS NOT NULL 
GROUP BY cust_name 
HAVING COUNT() >= 1;

having:

having 用于对汇总的 group by 结果进行过滤。 having 一般都是和 group by 连用。 

having vs where:

where:过滤过滤指定的行,后面不能加聚合函数(分组函数)。where 在group by 前。 having:过滤分组,一般都是和 group by 连用,不能单独使用。having 在 group by 之后

执行顺序: where---->group by---->Having ,聚合函数只能用在Having, select

此外:order by 和 where的顺序,先where - order by

完整的顺序:Where, Group By, Having, Order by


 

4.SQL语句中Like通配符%和下划线_的用法

% :表示任意0个或多个字符,可匹配任意类型和长度的字符。

_ : 表示任意单个字符。

注意:如果要搜索 字符中有下划线的,需要对_进行转义

  1. select * from t where x like '%\_%' escape ''; 搜索中间含有下划线的查询条件,通过escape进行转义。
  2. Like对应的否定是NOT LIKE (类似于判断字符串是否为空,IS NULL / IS NOT NULL)

5.内连接 外连接 之间的关系

JAVA-软开-常见八股文(2)-数据库相关,数据库,java

ON 和 WHERE 的区别:

连接表时,SQL 会根据连接条件生成一张新的临时表。ON 就是连接条件,它决定临时表的生成。

WHERE 是在临时表生成以后,再对临时表中的数据进行过滤,生成最终的结果集,这个时候已经没有 JOIN-ON 了。所以总结来说就是:SQL 先根据 ON 生成一张临时表,然后再根据 WHERE 对临时表进行筛选。

如果不加任何修饰词,只写 JOIN,那么默认为 INNER JOIN。

对于 INNER JOIN 来说,还有一种隐式的写法,称为 “隐式内连接”,也就是没有 INNER JOIN 关键字,使用 WHERE 语句实现内连接的功能。

隐式内连接

select c.cust_name, o.order_num
from Customers c, Orders o 
where c.cust_id = o.cust_id 
order by c.cust_name;

显式内连接

select c.cust_name, o.order_num
from Customers c 
inner join Orders o 
using(cust_id) 
order by c.cust_name;

6.IN 和EXISTS查询的区别

1 IN后面的子查询返回的结果集是单个列表值的集合;而EXISTS所跟的是查询的结果集

2 IN是先进行内部查询,再根据结果进行外部查询;而EXISTS则从外部表开始遍历每一行,判断其是否满足条件

3 IN主要的查询效率是依赖于外表的索引,而EXISTS的查询效率是依赖于内表的索引。

4 因此,当子查询结果集较大,而外表较小时,EXISTS的性能较好;

当子查询结果集较小,而外部表较大的时候。IN的性能较好文章来源地址https://www.toymoban.com/news/detail-742052.html

到了这里,关于JAVA-软开-常见八股文(2)-数据库相关的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • java八股文面试[数据库]——MySQL死锁的原因和处理方法

    1) 表的死锁 产生原因 : 用户A访问表A(锁住了表A),然后 又访问表B ;另一个用户B访问表B(锁住了表B),然后企图 访问表A ;这时用户A由于用户B已经锁住表B,它必须等待用户B释放表B才能继续,同样用户B要等用户A释放表A才能继续,这就死锁就产生了。 用户A--》A表(表

    2024年02月09日
    浏览(47)
  • java八股文面试[数据库]——可重复读怎么实现的(MVCC)

    可重复读(repeatable read)定义: 一个事务执行过程中看到的数据,总是 跟这个事务 在 启动时 看到的数据是一致的。 MVCC MVCC, 多版本并发控制 , 用于实现 读已提交 和 可重复读 隔离级别。 MVCC的核心就是 Undo log多版本链 + Read view ,“MV”就是通过 Undo log来保存数据的历史版

    2024年02月09日
    浏览(51)
  • java八股文面试[数据库]——B树和B+树的区别

    B树是一种树状数据结构,它能够存储数据、对其进行排序并允许以 O(logn) 的时间复杂度进行查找、顺序读取、插入和删除等操作。 B树中允许一个结点中包含多个key,可以是3个、4个、5个甚至更多,并不确定,需要看具体的实现。现在我们选 择一个参数M,来构造一个B树,我

    2024年02月09日
    浏览(57)
  • 面试八股文Mysql:(2)数据库调优

    数据库优化在提升系统性能是很重要的一个方面,不管是MySQL还是MongoDB还是其它的数据库。 SQL优化在提升系统性能中是成本最低 优化效果最明显的途径,可以让 吞吐量更大,响应速度更快 。如果你的团队在SQL优化这方面搞得很优秀,对你们整个大型系统可用性方面无疑是一

    2024年02月13日
    浏览(46)
  • 面试数据库八股文五问五答第四期

    作者:程序员小白条,个人博客 相信看了本文后,对你的面试是有一定帮助的! ⭐点赞⭐收藏⭐不迷路!⭐ 1)什么情况下 mysql 会索引失效? 不使用索引列进行查询:当查询条件不包含索引列时,MySQL无法使用索引进行快速查找,而会进行全表扫描,导致索引失效。 使用函

    2024年02月04日
    浏览(39)
  • 计算机复试面试基础知识(八股文)(数据库、数据结构、操作系统、计网、机组等)

    数据库绪论 1、简述三层模式、两级映射,分别有什么作用? 模式(逻辑模式):是数据库中全体数据的逻辑结构和特征的描述,是数据库系统模式结构的中间层,即不涉及数据的物理存储细节,也与具体应用程序开发工具语言无关。 外模式(用户模式):是用户能看见和使

    2023年04月09日
    浏览(119)
  • 前端常见面试八股文

    1、H5新增标签有哪些? 一、语义化标签 header、footer、nav、aside、section、article 语义化的意义? 1、更适合搜索引擎的爬虫爬取有效的信息,利于SEO。 2、对开发团队很友好,增加了标签的可读性,结构更加的清晰,便于团队的开发和维护。 二、多媒体标签 视频标签:video 属性

    2023年04月08日
    浏览(85)
  • java八股文面试[数据结构]——集合框架

    Java集合类主要由两个根接口Collection和Map派生出来的。 Collection派生出了三个子接口: Map接口派生: Map代表的是存储key-value对的集合,可根据元素的key来访问value。  因此Java集合大致也可分成 List、Set、Queue、Map四种接口体系 。 List代表了有序可重复集合,可直接根据元素的索

    2024年02月11日
    浏览(41)
  • java八股文面试[数据结构]——HashMap扩容优化

         知识来源: 【2023年面试】HashMap在扩容上做了哪些优化_哔哩哔哩_bilibili  

    2024年02月11日
    浏览(39)
  • java八股文面试[数据结构]——ArrayList和LinkedList区别

      ArrayList和LinkedList的异同 二者的线程都不安全,相对线程安全的Vector,执行效率高。此外,ArrayList时实现了基于动态数组的数据结构,LinkedList基于链表的数据结构,对于随机访问get和set,ArrayList觉得优于LinkedList比较占优势,因为LinledList要移动指针。对于新增和删除操作add

    2024年02月11日
    浏览(49)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包