撩课-Java每天5道面试题第12天
91.如何提升数据查询的效率?
1.首先检查表的结构是否合理,
因为采用多表查询的时候,
看主外键的引用关系是否适当.
如果不适当则重新设置表结构.
如果是应用中的系统,
则不需要更改表的字段,
只更改主外键关系.
如果数据库中有较多的数据,
还应采用索引提高查询效率. 2.利用索引(index)
对查询进行优化,
index可以避免对表数据的全面扫描,
当你以某个字段建立一个索引的时候,
数据库就会生成一个索引页,
索引页不单单保存索引的数据,
还保存了索引在数据库的
具体的物理地址,
能够很快的定位查找到要找的记录 3. 如果表的列很少,
不适合建索引.
表数据很少查询,
而经常做insert、delete、update动作,
不适合建所以。
因为Oracle需要对索引额外维护。
建立索引后,select会快,
当执行过多次的insert,delete,update后,
会出现索引碎片,
影响查询速度,我
们应该对索引进行重组
(即drop掉索引重新create) 4.索引的类型分为: B-树索引:
适合于大量的增、删、改,
大多数数据的索引默认类型。 位图索引:
适合于决策支持系统 HASH索引、分区索引等。
92.什么是数据库事务?
事务是作为一个逻辑单元
执行的一系列操作,
要么一起成功,要么一起失败。 一个逻辑工作单元必须有四个属性,
称为 ACID:
原子性、
一致性、
隔离性
持久性
属性,
只有这样才能成为一个事务。 原子性 :
事务必须是原子工作单元;
对于其数据修改,
要么全都执行
,要么全都不执行。 一致性 :
事务在完成时,
必须使所有的数据都保持一致状态。
在相关数据库中,
所有规则都必须应用于事务的修改,
保持所有数据的完整性。
事务结束时,
所有的内部数据结构
(如 B 树索引或双向链表)
都必须是正确的。 隔离性 :
由并发事务所作的修改
必须与任何其它并发事务
所作的修改隔离。
事务查看数据时数据所处的状态,
要么另一并发事务修改它之前的状态,
要么是另一事务修改它之后的状态,
事务不会查看中间状态的数据。
这为可串行性,
因为它能够重新装载起始数据,
并且重播一系列事务,
以使数据结束时的状态
与原始事务执的状态相同。 持久性 :
事务完成之后,
它对于系统的影响是永久性的。
该修改即使出现系统故障也将一直保持。
93.什么是数据库事务的隔离级别?
多个线程开启各自事务操作数据库中数据时,数
据库系统要负责隔离操作,
以保证各个线程在获取数据时的准确性。 数据库共定义了四种隔离级别:
Serializable:(串行化)
可避免脏读、
不可重复读、
虚读情况的发生 Repeatable read:(可重复读) 可避免脏读、
不可重复读情况的发生。 Read committed:(读已提交)
可避免脏读情况发生。 Read uncommitted:(读未提交)
最低级别,
以上情况均无法保证。
94.如何删除表中的重复数据,只保留一条记录?
1、查找表中多余的重复记录,
重复记录是根据单个字段(peopleId)来判断
select * from people
where peopleId in (
select peopleId from people
group by peopleId
having count(peopleId) > 1
) 2、删除表中多余的重复记录, 重复记录是根据单个字段(peopleId)来判断,
只留有rowid最小的记录 delete from people where peopleName in ( select peopleName from people group by peopleName having count(peopleName) > 1 ) and peopleId not in ( select min(peopleId) from people group by peopleName having count
(peopleName)>1 ) 3、查找表中多余的重复记录(多个字段) select * from vitae a where (a.peopleId,a.seq) in ( select peopleId,seq from vitae group by peopleId,seq having count(*) > 1 ) 4、删除表中多余的重复记录(多个字段),只留有rowid最小的记录 delete from vitae a where (a.peopleId,a.seq) in ( select peopleId,seq from vitae group by peopleId,seq having count(*) > 1 ) and rowid not in ( select min(rowid) from vitae
group by peopleId,seq having count(*)>1 ) 5、查找表中多余的重复记录(多个字段),不包含rowid最小的记录 select * from vitae a where (a.peopleId,a.seq) in ( select peopleId,seq from vitae group by peopleId, seq having count(*) > 1 ) and rowid not in ( select min(rowid) from vitae
group by peopleId, seq having count(*)>1 ) 6.消除一个字段的左边的第一位: update tableName set [Title]=Right([Title],(len([Title])-1)) where Title like '村%' 7.消除一个字段的右边的第一位: update tableName set [Title]=left([Title],(len([Title])-1)) where Title like '%村' 8.假删除表中多余的重复记录(多个字段), 不包含rowid最小的记录 update vitae set ispass=-1 where peopleId in ( select peopleId from vitae group by peopleId )
95.如何通过sql语句完成分页?
客户端通过传递start(页码),
PageSize(每页显示的条数)两个参数
去分页查询数据库表中的数据,
那我们知道MySql数据库提供了
分页的函数limit m,n,
但是该函数的用法和我们的需求不一样,
所以就需要我们根据实际情况
去改写适合我们自己的分页语句,
具体的分析如下: 比如:
查询第1条到第10条的数据的sql是:
select * from table limit 0,10;
对应我们的需求就是查询第一页的数据:
select * from table limit (1-1)*10,10; 查询第10条到第20条的数据的sql是:
select * from table limit 10,20;
对应我们的需求就是查询第二页的数据:
select * from table limit (2-1)*10,10; 查询第20条到第30条的数据的sql是:
select * from table limit 20,30;
对应我们的需求就是查询第三页的数据:
select * from table limit (3-1)*10,10; 二:通过上面的分析,
可以得出符合我们自己需求的分页
sql格式是:
select * from table limit (start-1)*PageSize,PageSize;
其中start是页码,
PageSize是每页显示的条数。
撩课-Java每天5道面试题第12天的更多相关文章
- 撩课-Java每天5道面试题第13天
撩课Java+系统架构点击开始学习 96.JDBC操作数据库的步骤 ? .加载数据库驱动 .创建并获取数据库链接 .创建jdbc statement对象 .设置sql语句 .设置sql语句中的参数(使 ...
- 撩课-Java每天5道面试题第15天
撩课Java+系统架构点击开始学习 106.什么是Hibernate的并发机制?怎么去处理并发问题? a.Hibernate的Session对象是非线程安全的, 对于单个请求,单个会话, 单个的工作单 ...
- 撩课-Java每天5道面试题第10天
撩课Java+系统架构 视频 点击开始学习 81.Servlet的会话机制? HTTP 是一种无状态协议, 这意味着每次客户端检索网页时, 都要单独打开一个服务器连接, 因此服务器不会记录下 先前客户 ...
- 撩课-Java每天5道面试题第9天
撩课Java+系统架构 视频 点击开始学习 76.XML技术的作用? XML技术用于数据存储. 信息配置. 数据交换三方面. 可以将数据存储在XML中, 通过节点. 元素内容. 属性标示数据内容及关系 ...
- 撩课-Java每天5道面试题第8天
撩课Java+系统架构 视频 点击开始学习 71.jsp有哪些内置对象?作用分别是什么? Page, pageContext, request, response, session, applicat ...
- 撩课-Java每天10道面试题第7天
撩课Java+系统架构 视频 点击开始学习 61.什么是并发修改异常? 什么是并发修改异常: 当我们在遍历实现了collection接口 与iterator接口的集合时(List.Set.Map), ...
- 撩课-Java每天10道面试题第4天
撩课Java+系统架构 视频 点击开始学习 31.静态变量和实例变量的区别? 静态变量也叫类变量, 这种变量前加了static修饰符. 可以直接用类名调用, 也可以用对象调用, 而且所有对象的同一个类 ...
- 撩课-Java每天5道面试题第17天
116.说下Struts的设计模式 MVC模式: web应用程序启动时 就会加载并初始化ActionServler. 用户提交表单时, 一个配置好的ActionForm对象被创建, 并被填入表单相应的 ...
- 撩课-Java每天5道面试题第24天
151.springMVC和struts2的区别有哪些? .springmvc的入口是一个servlet即前端控制器(DispatchServlet), 而struts2入口是一个filter过虑器( ...
随机推荐
- CodeChef April Challenge 2019题解
传送门 \(Maximum\ Remaining\) 对于两个数\(a,b\),如果\(a=b\)没贡献,所以不妨假设\(a<b\),有\(a\%b=a\),而\(b\%a<a\).综上, ...
- BZOJ3210: 花神的浇花集会(坐标系变换)
题面 传送门 题解 坐标系变换把切比雪夫距离转化为曼哈顿距离 那么对于所有的\(x\)坐标中,肯定是中位数最优了,\(y\)坐标同理 然而有可能这个新的点不合法,也就是说不存在\((x+y,x-y)\ ...
- day 02 ---class - homework
# -*- coding: utf-8 -*-# @Time : 2018/12/20 14:34# @Author : Endless-cloud# @Site : # @File : day 02 ...
- bzoj4842: [Neerc2016]Delight for a Cat
bzoj4842 这是一道网络流的题(大家都看出来了吧) 首先我们简化一下题目,选出最关键的部分(就是知道什么和要求什么,还有条件) 我们在这里把睡觉设为0,至少有t0时间在睡觉,把打隔膜设为1,至少 ...
- 架构师养成记--37.简单shell编程
一.HelloWord.sh echo 表示打印,可以在sh文件中写诸如pwd.ls 这样的命令,使用命令的时候尽量使用全路径. #!/bin/sh #this is my first sh echo ...
- C#-进制转化
(一)数制 计算机中采用的是二进制,因为二进制具有运算简单,易实现且可靠,为逻辑设计提供了有利的途径.节省设备等优点,为了便于描述,又常用八.十六进制作为二进制的缩写.一般计数都采用进位计数,其特点是 ...
- Docker安装MongoDb
1.下载镜像 docker pull mongo 2.运行mongo docker run --name mongo -v /data/mongodb:/data/db -p : -d mongo - ...
- 2018-2019 20165226 Exp7 网络欺诈防范
2018-2019 20165226 Exp7 网络欺诈防范 目录 一.实验内容说明及基础问题回答 二.实验过程 1.简单应用SET工具建立冒名网站 2.ettercap DNS spoof 3.结合 ...
- css左右布局,左侧固定,右侧自适应
实现布局的几种方法,见代码: <!DOCTYPE html> <html lang="cn"> <head> <meta charset= ...
- Python 全栈开发:day3 作业与默写
# 1.有变量name = "aleX leNb" 完成如下操作:name = 'aleX leNb'# 1)移除 name 变量对应的值两边的空格,并输出处理结果print(na ...