1.group by
根据表里的字段名分类,相同字段名只显示一行记录,通常与聚集函数max、min合用选择最大值最小值,或者与having合用筛选,结果按照group by的字段排序
例:select * from examine group by e_date;
结果:
+-------------+------------+-----------+------------+---------------+
| e_id | e_name | h_id | e_date | e_teachername |
+-------------+------------+-----------+------------+---------------+
| 21500000201 | 急救学考核 | 215000002 | 2018-07-31 | 邹恩岑 |
| 21000000102 | 心理学 | 210000001 | 2018-08-20 | 陆卫忠 |
| 21500000101 | 护理学考核 | 215000001 | 2018-08-31 | 席雪峰 |
| 21000000101 | 病理学考核 | 210000001 | 2018-09-30 | 南顺丰 |
| 21500000103 | 康复学考核 | 215000001 | 2018-11-01 | 林芳 |
+-------------+------------+-----------+------------+---------------+
2.起别名
起别名分为为表起别名和为字段起别名,使用as关键字其中为字段起别名可以省略as关键字。
给字段起别名,结果中的字段名直接改为别名
例:select e_name as name
from examine group by e_date;
+------------+
| name |
+------------+
| 急救学考核 |
| 心理学 |
| 护理学考核 |
| 病理学考核 |
| 康复学考核 |
+------------+

给表起别名
例:select from examine
where examine.e_name = '心理学';和
select 
from examine e where e.e_name = '心理学';结果一样

3.连接查询
内连接
查询两张表匹配的内容 on是条件
select e.e_id ,e.e_name from examine e inner join hospital_info h on e.hid = h.h
id;
+-------------+--------------+
| e_id | e_name |
+-------------+--------------+
| 21000000101 | 病理学考核 |
| 21000000102 | 心理学 |
| 21500000101 | 护理学考核 |
| 21500000102 | 临床护理考核 |
| 21500000103 | 康复学考核 |
| 21500000201 | 急救学考核 |
+-------------+--------------+

外连接
分为左外连接和右外链接,表示以左边的表或者右边的表为基础,筛选出基准表中有的内容,非基准表里没有的内容显示为null。
交叉连接
返回两张表的笛卡尔积,效果相当于select * from table1,table2;

4.事务
事务的四个特性:
1.原子性
一组操作是一个整体,要么全部完成,要么全部放弃(回滚)
2.稳定性
操作出错时,有非法外键约束,事务撤回
3.隔离性
事务和事务相对独立
4.可靠性
事务提交后可以永久保存
提交事务 commit
回滚事务 rollback
事务自动提交autocommit = 1 0为关闭自动提交
开启事务 start transition 或者begin

5.事务的隔离级别
查看隔离级别:select @@tx_isolation
设置当前事务的隔离级别: set tx_isolation= “隔离级别”;
事务的隔离级别是为了避免出现脏读,幻读,不可重复读的问题
1.read uncommit 读未提交 什么都不能解决
2.read commit 读已提交 可避免脏读
3.repeatable read 可重复读 可避免脏读,不可重复读
4.serializable 串行化 可避免脏读,幻读,可重复读

6.乐观锁
默认数据不会出错,只有提交修改数据库时才回去判断会不会出错。底层使用version实现,比较修改的时version和取出 数据时version是否相同,另一种实现机制是时间戳。
7.聚集函数
Count()返回满足条件的列数
Max()返回最大
Min()返回最小值
Sun()返回和
Avg()返回平均值
8.索引
索引可以在创建表的时候指定,也可以使用语句创建
9.视图
视图使用create view as select创建
10.having
Where子句后面不能接聚合函数
Having后面接聚合函数
11.order by
排序

来源:https://blog.csdn.net/RobotBing/article/details/85157705

java面试_数据库的更多相关文章

  1. 【java面试】数据库篇

    1.SQL语句分为哪几种? SQL语句主要可以划分为以下几类: DDL(Data Definition Language):数据定义语言,定义对数据库对象(库.表.列.索引)的操作. 包括:CREAT ...

  2. Java面试10|数据库相关

    1.ID分配单点问题 系统使用一张表的自增来得到订单号,所有的订单生成必须先在这里insert一条数据,得到订单号.分库后,库的数量变多,相应的故障次数变多,但由于单点的存在,故障影响范围并未相应的减 ...

  3. java面试之数据库面试知识点【转】

    1. 主键 超键 候选键 外键 主 键: 数据库表中对储存数据对象予以唯一和完整标识的数据列或属性的组合.一个数据列只能有一个主键,且主键的取值不能缺失,即不能为空值(Null). 超 键: 在关系中 ...

  4. [Java面试十一]数据库总结.

    问题及描述: --1.学生表 Student(SID,Sname,Sage,Ssex) --SID 学生编号,Sname 学生姓名,Sage 出生年月,Ssex 学生性别 --2.课程表 Course ...

  5. Java面试系列

    如果你的面试简历是如下这样写的,请务必准备回答下面的所有问题. 面试职位:Java高级工程师 专业技能: (1)牢固掌握Java基础知识,如集合.并发.I/O等,并对Java源码有一定的研究. (2) ...

  6. Java 面试知识点解析(六)——数据库篇

    前言: 在遨游了一番 Java Web 的世界之后,发现了自己的一些缺失,所以就着一篇深度好文:知名互联网公司校招 Java 开发岗面试知识点解析 ,来好好的对 Java 知识点进行复习和学习一番,大 ...

  7. Java面试准备十六:数据库——MySQL性能优化

    2017年04月20日 13:09:43 阅读数:6837 这里只是为了记录,由于自身水平实在不怎么样,难免错误百出,有错的地方还望大家多多指出,谢谢. 来自MySQL性能优化的最佳20+经验 为查询 ...

  8. Java面试宝典(6)混合(前端 + 数据库)

    包括html & JavaScript & Ajax部分/Java web部分/数据库部分 三. html&JavaScript&ajax部分 1. 判断第二个日期比第 ...

  9. java面试④数据库部分

    2.3.1 数据库的分类及常用的数据库 数据库分为:关系型数据库和非关系型数据库 关系数据库:mysql,oracle,sqlServer 非关系型:redis,mongoDB 2.3.2 简单介绍一 ...

随机推荐

  1. 记录:Android中StackOverflow的问题

    最近新作的项目上线,出现了一个让人抓狂的问题.在此记录一下! 现在的项目中,制作了一个界面非常复杂.整个结构是最外层一个Layout,封装了Menu键吊起的菜单,整个内容使用一个FrameLayout ...

  2. 二维树状数组的区间加减及查询 tyvj 1716 上帝造题的七分钟

    详细解释见小结.http://blog.csdn.net/zmx354/article/details/31740985 #include <algorithm> #include < ...

  3. java消息中间件之ActiveMQ初识

    目录 消息中间件简介 解耦合和异步 可靠性和高效性 JMS P2P Pub/Sub AMQP JMS和AMQP对比 常见消息中间件 ActiveMQ RabbitMQ Kafka 综合比较 标签(空格 ...

  4. Linux系统控制文件 /etc/sysctl.conf详解

    /etc/sysctl.conf这个目录主要是配置一些系统信息,/etc/sysctl.conf参数解释: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 1 ...

  5. MySQL四-1:数据类型

    阅读目录 一 介绍 二 数值类型 三 日期类型 四 字符串类型 五 枚举类型与集合类型 一 介绍 存储引擎决定了表的类型,而表内存放的数据也要有不同的类型,每种数据类型都有自己的宽度,但宽度是可选的 ...

  6. macOS 安装安卓模拟器 并用charles抓包

    mac上面安装安卓模拟器并能使用charles抓包软件调研 一.Genymotion 1.先下载Virtua Box虚拟机 https://www.virtualbox.org/wiki/Downlo ...

  7. 调整jvm内存

    1.使用解压tomcat     在catalina.bat的第一行增加:    set JAVA_OPTS=-Xms64m -Xmx256m -XX:PermSize=128M -XX:MaxNew ...

  8. git add . git add -u git add -A命令区别图解

    git版本不同会有所区别: Git Version 1.x:  Git Version 2.x:  git add .  修改(modified)以及新文件(new),但不包括被删除的文件. git ...

  9. PHP面试题总结

    2017年5月15日19:20:26 1.请用最简单的语言告诉我PHP是什么? PHP全称:Hypertext Preprocessor,是一种用来开发动态网站的服务器脚本语言. 2. 面试题地址:h ...

  10. jsp安全性问题

    jsp项目不同jsp之间假设只通过超链接进行跳转,安全性太低,不能满足现实生活中对安全性的要求! 为了提高安全性.能够通过Servlet进行跳转,进行跳转的时候为了进一步实现其安全性,能够通过间jsp ...