SQL的组成分有哪几部分?

数据库就是存储数据的仓库,其本质是一个文件系统,数据按照特定的格式将数据存储起来,用户可以对数据库中的数据进行增加,修改,删除及查询操作。

  • 将该配置项关闭后,文件会正常生成在 /tmp/mysql.sock 文件中。

MySQL 5.7 安装完成之后,默认的 4 个数据库:

  • information_schema:是一个信息数据库,这个数据库保存了所有数据库信息。如:数据库名、数据库表、访问权限等。
  • mysql:是一个系统库,主要负责存储数据库的用户,权限设置等。
  • DDL:数据定义语言,用来建立数据库,数据对象和定义其列。如 create alter drop
  • 表是数据库中的数据组成的单位,类似于 Java 中的类,每个字段都有对应的数据类型。
  • 在客户端中写完创建表的 SQL 语句后客户端会把 SQL 语句交给 DBMS(MySQL);
  • DBMS(MySQL) 解析后会在数据库中创建语句中的表和表中字段。
  • InnoDB:支持数据库的高级处理包括事务外键等。(表默认的引擎就是 InnoDB)
  • Myisam:只支持数据的基本存储。

创建表时指定表的字符集和引擎

  • varchar:可变长字符串类型。
  • char:固定字符串类型。
  • float:浮点类型。
  • primary key:设置主键,具有唯一性。


在成绩表最后添加字段:


修改成绩表字段名和类型:


修改成绩表类型和顺序:

  • 如想修改到某个位置,使用 alter table 成绩表 modify 字段名 新字段类型 after 年龄(就是将字段修改到年龄后面)。


修改成绩表引擎和字符集:

}

小伙伴你们有没有在网上寻找Java面试题,因为面试题的不完全,杂乱而烦恼?

我帮大家找到了一个很全的面试题,需要的同学往下看↓↓↓↓↓↓

先给大家复习一下基础题!!!

Java基础是java初学者的起点,是帮助你从小白入门到精通必学基础课程!

B站的Java300集 适合准备入行开发的零基础员学习Java,基于最新JDK13、IDEA平台讲解的,视频中穿插多个实战项目。每一个知识点都讲解的通俗易懂,由浅入深。不仅适用于零基础的初学者,有经验的程序员也可做巩固学习。

1、面向对象编程有哪些特征?
3、Java 有哪几种基本数据类型?
12、如何跳出 Java 中的循环?
13、如何跳出 Java 中的多层嵌套循环?
15、2 * 8 最有效率的计算方法是什么?
17、怎么理解值传递和引用传递?
18、Java 到底是值传递还是引用传递?
19、一个 ".java" 源文件的类有什么限制?
20、Java 中的注释有哪些写法?
22、static 变量和普通变量的区别?
23、static 可以修饰局部变量么?
24、final 关键字有哪些用法?
28、char 类型可以存储中文汉字吗?
29、重载和重写有什么区别?
30、构造器可以被重写和重载吗?
31、main 方法可以被重写和重载吗?
32、私有方法能被重载或者重写吗?
34、Java 异常有哪些分类?
36、Java 中常见的异常有哪些?
37、Java 中常见的运行时异常有哪些?
38、运行时异常与受检查异常有什么区别?
39、什么时候会发生空指针异常?
40、你知道有哪些避免空指针的方法?
45、什么是包装类型?有什么用?
46、什么是自动装厢、拆厢?
47、你怎么理解 Java 中的强制类型转换?
48、你怎么理解 Java 中的自动类型转换?
49、你怎么理解 Java 中的类型提升?
53、String 属于基础的数据类型吗?
54、String 类的常用方法都有那些?
55、String 的底层实现是怎样的?
56、String 是可变的吗?为什么?
58、String 真的是不可变的吗?
59、String 字符串如何进行反转?
60、String 字符串如何实现编码转换?
61、String 有没有长度限制?是多少?
62、为什么不能用 + 拼接字符串?
65、Java 所有类的祖先类是哪个?
66、Object 类有哪些常用的方法?
67、普通类和抽象类有什么区别?
68、静态内部类和普通内部类有什么区别?
69、静态方法可以直接调用非静态方法吗?
70、静态变量和实例变量有什么区别?
71、内部类可以访问其外部类的成员吗?
72、接口和抽象类有什么区别?
73、接口是否可以继承接口?
74、接口里面可以写方法实现吗?
75、抽象类必须要有抽象方法吗?
76、抽象类能使用 final 修饰吗?
77、抽象类是否可以继承具体类?
78、抽象类是否可以实现接口?
79、怎么查看一个 Java 类的字节码?
81、Java 类初始化顺序是怎样的?
82、为什么成员变量命名不建议用 isXXX?
90、Java 常用的元注解有哪些?
91、Java 泛型中的 T、R、K、V、E 分别指什么?
92、Java 金额计算怎么避免精通丢失?
93、Java 语法糖是什么意思?
95、如何实现对象克隆?
96、对象克隆浅拷贝和深拷贝的区别?
97、Java 反射机制有什么用?
98、Java 反射机制的优缺点?
100、Java 反射可以访问私有方法吗?
101、Java 反射可以访问私有变量吗?
103、什么是宏变量和宏替换?
104、什么是逃逸分析?
105、什么是伪共享?有什么解决方案?
107、Java 中有没有指针的概念?
111、Java 8 都新增了哪些新特性?
116、Java 8 中的方法引用是指什么?
117、Java 8 中的函数式编程怎么用?

1、Java 为什么能一次编写,处处运行?
4、JVM 内存区域分类哪些?
5、堆和栈区别是什么?
6、JVM 哪块内存区别不会发生内存溢出?
7、什么情况下会发生栈内存溢出?
8、对象都是在堆上分配的吗?
9、你怎么理解强、软、弱、虚引用?
10、常用的 JVM 参数有哪些?
11、Java 8 中的内存结构有什么变化?
12、Java 8 中的永久代为什么被移除了?
13、什么是类加载器?
14、类加载器的分类及作用?
15、什么是双亲委派模型?
16、为什么要打破双亲委派模型?
18、什么是 JVM 内存模型?
19、JVM 内存模型和 JVM 内存结构的区别?
20、什么是指令重排序?
21、内存屏障是什么?
23、GC 是什么?为什么需要 GC?
25、一次完整的 GC 流程是怎样的?
26、JVM 如何判断一个对象可被回收?
27、常用的垃圾收集器有哪些?
28、常用的垃圾回收算法有哪些?
29、什么是内存泄漏?
30、为什么会发生内存泄漏?
31、如何防止内存泄漏?
32、什么是直接内存?
33、直接内存有什么用?
34、怎样访问直接内存?
35、常用的 JVM 调优命令有哪些?
36、常用的 JVM 问题定位工具有哪些?
37、常用的主流 JVM 虚拟机都有哪些?

1、进程和线程的区别?
2、什么是原子性、可见性、有序性?
3、为什么要使用多线程?
4、创建线程有哪几种方式?
6、线程的状态有哪几种?怎么流转的?
7、线程的优先级有什么用?
8、我们常说的 JUC 是指什么?
9、i++ 是线程安全的吗?
10、join 方法有什么用?什么原理?
11、如何让一个线程休眠?
17、怎么理解 Java 中的线程中断?
18、你怎么理解多线程分组?
20、同步和异步的区别?
25、什么是线程饥饿?
27、阻塞和非阻塞的区别?
28、并发和并行的区别?
29、为什么不推荐使用 stop 停止线程?
30、如何优雅地终止一个线程?
36、公平锁和非公平锁的区别?
37、有哪些锁优化的方式?
39、什么是轻量级锁?
43、什么是重量级锁?
45、使用线程池有什么好处?
46、创建一个线程池有哪些核心参数?
47、线程池的工作流程是怎样的?
48、Java 里面有哪些内置的线程池?
49、为什么阿里不让用 Executors 创建线程池?
50、线程池的拒绝策略有哪几种?
51、如何提交一个线程到线程池?
53、如何查看线程池的运行状态?
54、如何设置线程池的大小?
55、如何关闭线程池?
57、AQS 的底层原理是什么?
69、Java 中原子操作的类有哪些?
70、什么是 ABA 问题?怎么解决?
71、Java 并发容器,你知道几个?
72、什么是阻塞队列?
73、阻塞队列有哪些常用的应用场景?
74、Java 中的阻塞的队列有哪些?

2、常用的 IO 类有哪些?
5、Java 有哪几种类型的流?
6、字节流和字符流的区别?
7、Java 序列化是什么?
8、怎么序列化一个对象?
9、Java 有哪两种序列化方式?
10、怎么控制类中的某些变量不被序列化?
11、静态变量能不能被序列化?
12、OSI 的七层模型都有哪些?
14、tcp 为什么要三次握手,两次不行吗?

5、Servlet 的生命周期是怎样的?
6、Servlet 有哪些核心的方法?
12、JSP 有哪些内置对象?
13、JSP 有哪些基本动作?
14、JSP 有哪几种作用域?
15、JSP 有哪些常用指令?
16、如何实现隐藏的表单域?
17、AJAX 应用和传统 Web 应用有什么不同?
18、怎么优化 Web 前端的性能?
19、什么是 MVC?分别代表什么?
20、拦截器和过滤器的区别?
22、什么是跨域?有哪些解决方案?

3、Dubbo 里面有哪几种节点角色?
4、Dubbo 停止维护了吗?
5、Dubbo 必须依赖的包有哪些?
6、Dubbo 支持哪些注册中心?推荐哪种?
7、Dubbo 内置了哪几种服务容器?
9、Dubbo 的服务注册和发现流程?
10、Dubbo 服务暴露的过程?
11、Dubbo 有哪几种配置方式?
12、Dubbo 核心的配置有哪些?
14、Dubbo 启动时依赖的服务不可用会怎样?
15、Dubbo 都支持什么协议,推荐用哪种?
16、Dubbo 支持什么通信框架?默认哪种?
17、Dubbo 支持的序列化框架有哪些?
18、Dubbo 有哪些集群容错方案,默认哪种?
19、Dubbo 有哪些负载均衡策略,默认哪种?
20、有多个同名服务时,如果连接指定的服务?
21、Dubbo 支持服务多协议吗?
22、Dubbo 服务上线怎么兼容旧版本?
23、Dubbo 一个服务接口有多种实现怎么区分?
24、Dubbo 可以对结果进行缓存吗?
25、Dubbo 服务之间的调用是阻塞的吗?
26、Dubbo 支持分布式事务吗?
28、Dubbo 支持服务降级吗?
30、Dubbo 服务提供者失效自动下线是什么原理?
31、Dubbo 服务调用链过长如何解决?
32、Duboo 服务读写容错策略怎么做?
33、Dubbo 的管理控制台能做什么?
35、Dubbo 使用过程中都遇到了些什么问题?
36、Dubbo 的源码你有读过吗?
38、Dubbo 你们的推荐用法有哪些?
40、Dubbo 之外,你还了解别的 RPC 框架吗?

1、主键、外键有什么区别?
2、怎么理解三范式和反范式?
3、范式和反范式的优缺点?
5、事务有哪几个特性?
6、什么是脏读、幻读、不可重复读?
7、MySQL 有哪些事务隔离级别?
8、MySQL 默认的事务隔离级别是?
11、索引为什么能提高查询效率?
12、索引的设计有哪些原则?
13、什么情况下应不建或少建索引?
14、MySQL 索引的种类有哪些?
15、MySQL 索引最左匹配原则怎么理解?
16、MySQL 数据库引擎怎么选择?
17、MySQL 默认数据库引擎是什么?
21、MySQL 怎么实现分页查询?
22、MySQL 的高可用方案有哪些?
23、如何分析一条 SQL 语句的执行计划和性能?
24、MySQL 查询优化有哪些方法?
26、MySQL 为什么尽量选择最小数据类型?
27、怎么理解数据库中的乐观锁和悲观锁?
31、MySQL 支持哪三种级别的锁?
33、MySQL 中的表锁有哪些?
34、MySQL 中的行锁有哪些?
35、MySQL 中的意向锁有什么用?
36、MySQL 中的意向锁的分类?
37、MySQL 中的意向锁是表锁还是行锁?
38、MySQL 中的自增锁有什么用?
39、MySQL 行锁是锁的是什么?
40、MySQL 行锁实现的几种算法?
41、MySQL 什么情况会发生死锁?
48、表分区有什么好处?
49、表分区与分表的区别?
50、MySQL 支持的分区类型有哪些?
51、MySQL 分区表有哪些限制因素?
52、MySQL 为什么要分库分表?
53、MySQL 分库分表怎么做?
54、MySQL 分库分表工具有哪些?
55、MySQL 分库分表会产生哪些问题?
56、MySQL 批量插入,如何不插入重复数据?

2、Redis 有哪些应用场景?
4、Redis 为什么这么快?
5、Redis 主要消耗什么物理资源?
6、Redis 到底是单线程还是多线程?
8、Redis 支持哪些数据类型?
9、Redis 默认支持多少个数据库?怎么修改?
13、Redis 事务相关的命令有哪几个?
14、Redis 持久化有什么用?
15、Redis 有哪几种持久化方式?
16、Redis 持久化方式如何选择?
17、Redis 内存满了怎么办?
18、Redis 有哪些淘汰策略?
20、Redis 如何实现大量数据插入?
21、Redis 的回收进程如何工作的?
22、Redis 中的管道有什么用?
23、Redis 有哪些高可用方案?
24、Redis 集群如何选择数据库?
25、Redis 哈希槽怎么理解?
31、Redis 如何设置密码访问?
32、Redis 如何分析慢查询操作?
33、什么是缓存预热和热备?
34、什么是缓存雪崩,如何解决?
35、什么是缓存穿透,如何解决?
36、什么是缓存击穿,如何解决?
37、什么是缓存抖动,如何解决?
38、什么是缓存无底洞现象,如何解决?
39、Redis 和数据库双写一致性问题如何解决?
40、Redis 有哪些危险命令?如何防范?
41、Redis 如何统计独立用户访问量?

2、SOA 和微服务架构有什么区别?
3、什么是 CAP 原则?
8、分布式系统下会遇到哪些问题?
9、分布式 Session 共享怎么实现?
10、分布式唯一 ID 怎么实现?
11、什么是分布式事务?
12、分布式事务的解决方案有哪些?
14、微服务架构有什么优势?
15、微服务架构有什么缺点?
16、什么是服务治理?
17、什么是服务降级?
18、服务降级的方案有哪些?
19、什么是服务雪崩?
20、什么是服务熔断?

1、消息队列有什么用?
2、消息队列有哪些应用场景?
3、消息队列有什么优缺点?
4、消息队列怎么选型?
5、有了多线程,为什么还要消息队列?
6、消息队列和多线程应该怎么选择呢?
7、使用消息队列会遇到哪些问题?
8、消息队列如何处理消息重复消费问题?
9、消息队列为什么会产生消息丢失?
10、消息队列如何解决消息丢失问题?
11、消息队列如何保证消息顺序消费?
12、消息延迟推送有哪些应用场景?
13、什么是拉模式和推模式?
14、什么是消息持久化?
15、消息持久化有什么缺点?
24、RabbitMQ 怎么保证消息的稳定性?
26、RabbitMQ 事务消息在什么情况下无效?
27、RabbitMQ 接收到消息之后必须消费吗?
28、RabbitMQ 如何确保每个消息能被消费?
31、RabbitMQ 队列中的消息是否有数量限制?
32、RabbitMQ 怎么实现消息延迟推送?

3、Linux 系统有哪些优势?
4、Linux 怎么查看内核版本?
7、Linux 环境变量配置有哪几种方式?
8、Linux 安装软件有哪几种方式?
9、Linux 普通用户怎么以管理员身份执行指令?
16、Linux 怎么显示目录下的文件?
22、Linux 怎么切换到之前所在的目录?
23、Linux 怎么切换到当前用户主目录?
24、Linux 怎么查看当前目录所在路径?
25、Linux 下的权限有哪几种?
26、Linux 文件调用权限分为哪 3 级?
27、Linux 怎么修改文件权限?
28、Linux 怎么修改文件所有者和所属组?
29、Linux 怎么查看磁盘的使用情况?
30、Linux 怎么查看内存的使用情况?
31、Linux 怎么查看资源消耗最多的进程?
32、Linux 怎么看端口被哪个进程占用?
33、Linux 怎么查找某个进程?
34、Linux 怎么结束某个进程?
36、Linux 控制台怎么设置超时自动注销?
39、Linux 软链接和硬链接区别?
40、Linux 怎么创建软、硬链接?
41、Linux 中的零拷贝是指什么?

}

SQL是一个关系数据库查询语言的标准,而SQL方言则是各种DBMS在SQL标准上进行的扩展,如增加新的关键字、查询功能、特有的数据类型、支持过程化的控制流语句等。例如SQL Server的T-SQL和Oracle的PL/SQL都是常见的SQL方言。
这就好比ANSI C标准与各种编译器实现的C语言的差别。但不同SQL方言之间的差异远大于不同C编译器之间的差异。SQL方言之间的差异,对于跨DBMS的学习和开发,都是必须注意的。

3.5. 语句、表达式和断言

语句(statement)是SQL中一个可以单独执行的单元。如SELECT * FROM table;即是一个语句,其中包含了SELECT子句(clause)和FROM子句。SQL标准规定用分号作为语句的结束,但在目前的T-SQL中,语句结束的分号是可选的。

表达式(expression)是SQL中的一个值(可能是变量、常量、查询字段或计算结果),对应一种特定的数据类型。SQL中的表达式分为标量表达式和表值表达式,其中表值表达式作为单独语句则是SELECT语句,作为语句的一部分则称为子查询。比如0, col + 2, DATEADD(second, 30, GETDATE())都是(标量)表达式。

}

我要回帖

更多关于 sql的功能包括哪四个部分 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信