当前位置: 首页 > news >正文

SQL经典面试题

这里写目录标题

  • 1 背概念
  • 2 学例子

1 背概念

1 事务 事务是最小的不可在分的工作单元,事务的操作要么同时成功,要么同时失败。
ACID: 原子性、一致性、隔离性、持久性
2 约束 主键约束;外键约束(少用,会增加程序的耦合性);唯一约束;非空约束
3 视图:视图是是表的一部分的集合,是保存在数据库中的已定义好的查询语句的结果集
create view vName as select name from table_name where condition;
3范式 关系数据库设计中一系列规范化的要求,逐步增强了数据的完整性和一致性。
1NF:数据表中的每个字段都必须是原子性的,不能再分解成更小的数据项。
2NF:在满足1NF基础上,非主键列不能依赖于部分主键,否则需将表拆分。
3NF:2NF的基础上,非主键列都不能依赖于其他非主键列,各字段之间没有传递依赖关系。

4分页limit:     limit  (page-1)*size,size  分别代表起始下标,显示记录数
-- 第21至30条记录: SELECT * FROM employees LIMIT 20,10;
删除:delete from 表名称 where 条件; drop table 表名称;
分组函数:MIN(); MAX(); COUNT(); AVG(); SUM();
单行函数:ABS(x),FLOOR(x) 返回小于或等于某个值的最大整数

5排序order by:默认升序,也可以设置成desc
SELECT last_name,hire_date FROM employees ORDER BY hire_date ;
去重 :select distinct name from user;
多表查询:外连接和内连接,等值连接和非等值连接,自连接和非自连接
外连接和内连接:内连接求两个表的交集(默认),外连接求补集,左外左边为主,右外右为主,满外连接Union关键字,返回一个并集,类似于A并B,会执行去重检索的操作
union all 返回并集加上交集 ,优点是效率比较高
等值连接和非等值连接:等:这多张表之间必须有相同的字段名,比方说一个表的主键是另一个表的外键 非等:SELECT last_name,salary,grade_level FROM employees e,job_grades j WHERE e.salary BETWEEN j.lowest_sal and j.highest_sal;
自连接和非自连接:自己多表自己自连接,一般很少自连接
6 jdbc:java连接数据库的一种标准,加载数据库驱动 --> 获得连接 --> 声明 SQL 语句对象 --> 执行语句对象, 接收查询结果 --> 关闭连接资源。
6 模糊查询:% 通配符
模糊匹配含有网:SELECT * from app_info where appName like ‘%网%’;
模糊匹配网结尾:like ‘%网’; 模糊匹配网开头 like ‘网%’
6 乱码出现原因:数据库存在多种格式,比方说latin和utf-8,设置有问题
2 db和dbms的区别:db是数据库的缩写,dbms是数据库管理系统
1 sql中常用数据类型的分类:整数类型 int,浮点类型float、double,字符型char,varchar;日期类型:date;文本类型txt,二进制文件类型blob
显示表结构:DESCRIBE employees;

2 学例子

– 建立一个数据表

create table employee(id int,name1 varchar(40),sex varchar(4),birthday date,entry_date date,salary decimal(8,2),resum text
);
drop table employee;
-- 插入数据
INSERT INTO employee(id,name1,sex,birthday,entry_date,,salary,resum)
VALUES(1,'zhangsan','male','1993-03-04','2016-11-10','1000','i am a developer');-- 给某一列插入数据
INSERT INTO employee(id) VALUES (6);
SELECT * FROM employee;-- 删除数据
DELETE from employee where job='zhangsan';
SELECT * from employee;
-- 删除所有数据,保存表结构
DELETE FROM employee;-- 改数据,有东西才能改,没有东西改不成
INSERT INTO employee(id,name1,sex,birthday,entry_date,salary,resum)
values (1,'zhangsan','male','1993-03-04','2016-11-10','1000','i am a developer');
INSERT INTO employee(id,name1,sex,birthday,entry_date,salary,resum)
values (1,'aaa','male','1993-03-04','2016-11-10','1000','i am a developer');-- 将所有员工工资修改为5000元
UPDATE  employee SET salary=5000;
-- 将张三员工工资设置为600
UPDATE employee SET salary=3000 where name1='张三';
-- 将aaa员工的薪水修改为4000元,id修改为2
UPDATE employee SET salary=4000,id=2 where name1='aaa'
-- 修改是可以做加减法的
UPDATE employee SET salary=salary+6000 WHERE name1='aaa';
http://www.lryc.cn/news/323546.html

相关文章:

  • Java基础知识总结(14)
  • MacOS - GCC 版本升级解决方案
  • 小程序绕过 sign 签名
  • 【Canvas与艺术】绘制动态太极图
  • Llama 2 模型
  • SQLiteC/C++接口详细介绍sqlite3_stmt类(十一)
  • 【理解机器学习算法】之Clustering算法(Agglomerative Clustering)
  • 千帆AppBuilder开发参考-应用API调用说明
  • python自定义日历库,与对应calendar库函数功能基本一致
  • css3鼠标悬停图片特效,图片悬停效果源码
  • 使用CSS3画出一个叮当猫HTML源码
  • Spring Boot 自动化单元测试类的编写过程
  • 复试专业前沿问题问答合集8-3——RNN、Hadoop、GPT大语言模型
  • 序列的使用
  • golang kafka sarama 源码解析
  • Flutter知识点整理
  • 现代游戏引擎架构
  • 深度学习:复杂工业场景下的复杂缺陷检测方法
  • CSDN个人简介优化 html font属性
  • 从哈希桶角度看 unordered_map 与 unordered_set 的实现
  • 飞天使-k8s知识点27-kubernetes温故知新2-deployment
  • 手机网页关键词视频爬虫采集软件可导出视频分享链接|视频无水印批量下载工具
  • 基于OpenCV的图像处理案例之图像矫正(Python)
  • 创建linux虚拟机系统:(安装Ubuntu镜像文件,包含语言设置、中文输入法、时间设置)
  • 3.0 V-22V 宽输入电压,高效率异步升压芯片-ZCC5429
  • Sphinx + Readthedocs 避坑速通指南
  • IPP-7010 表面贴装 90 度混合耦合器
  • 25.2 微服务Dubbo
  • CI/CD环境搭建
  • API调试管理工具Postman下载及操作介绍