发表于: 2017-06-12 21:43:35
1 1340
java
今天是学了Spring的概念
,什么是spring框架
spring是J2EE应用程序框架,是轻量级的IoC和AOP的容器框架,主要是针对JavaBean的生命周期进行管理的轻量级容器,可以单独使用,也可以和Struts框架,ibatis框架等组合使用。
有DAO,ORM,JEE,WEB,AOP,CORE,CONtext 7个部分
组成 Spring 框架的每个模块(或组件)都可以单独存在,或者与其他一个或多个模块联合实现。每个模块的功能如下:
- 核心容器:核心容器提供 Spring 框架的基本功能。核心容器的主要组件是
BeanFactory
,它是工厂模式的实现。BeanFactory
使用控制反转 (IOC) 模式将应用程序的配置和依赖性规范与实际的应用程序代码分开。 - Spring 上下文:Spring 上下文是一个配置文件,向 Spring 框架提供上下文信息。Spring 上下文包括企业服务,例如 JNDI、EJB、电子邮件、国际化、校验和调度功能。
- Spring AOP:通过配置管理特性,Spring AOP 模块直接将面向方面的编程功能集成到了 Spring 框架中。所以,可以很容易地使 Spring 框架管理的任何对象支持 AOP。Spring AOP 模块为基于 Spring 的应用程序中的对象提供了事务管理服务。通过使用 Spring AOP,不用依赖 EJB 组件,就可以将声明性事务管理集成到应用程序中。
- Spring DAO:JDBC DAO 抽象层提供了有意义的异常层次结构,可用该结构来管理异常处理和不同数据库供应商抛出的错误消息。异常层次结构简化了错误处理,并且极大地降低了需要编写的异常代码数量(例如打开和关闭连接)。Spring DAO 的面向 JDBC 的异常遵从通用的 DAO 异常层次结构。
- Spring ORM:Spring 框架插入了若干个 ORM 框架,从而提供了 ORM 的对象关系工具,其中包括 JDO、Hibernate 和 iBatis SQL Map。所有这些都遵从 Spring 的通用事务和 DAO 异常层次结构。
- Spring Web 模块:Web 上下文模块建立在应用程序上下文模块之上,为基于 Web 的应用程序提供了上下文。所以,Spring 框架支持与 Jakarta Struts 的集成。Web 模块还简化了处理多部分请求以及将请求参数绑定到域对象的工作。
- Spring MVC 框架:MVC 框架是一个全功能的构建 Web 应用程序的 MVC 实现。通过策略接口,MVC 框架变成为高度可配置的,MVC 容纳了大量视图技术,其中包括 JSP、Velocity、Tiles、iText 和 POI。
由于实在看不懂spring这个框架是具体怎么操作,听了师兄的说,还是取在深入翻看之前看到JDBC
package jdbc;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;
public class TestJDBC {
public static void main(String[] args) {
try {
Class.forName( "com.mysql.jdbc.Driver" );
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
try (
Connection c = DriverManager.getConnection(
"jdbc:mysql://127.0.0.1:3306/db1?characterEncoding=UTF-8&useSSL=false", "root", "luozeying"
);
Statement s = c.createStatement();
) {
String sql = "delete from table1 where id = 'sad'";
s.execute( sql );
} catch (SQLException e) {
e.printStackTrace();
}
}
}
今天从新对JDBC在重新学习一次,发现了很多自己忽略的小问题,和之前纠结很久的没run的代码也可以run了。比如try-with-resource的方式自动关闭连接。今天其实的问题主要集中在增删改查的SQL语句无法正确的执行,用了之前在navicat的方法也已经不适用了,在师兄的帮助下得知可以在cmd里面试试能不能执行SQL语句,发现cmd里面可以正确执行,此时在回到intellij上执行也成功了,发现sql语句不能乱加单引号,只可以在字段是字符串的时候加上才有用。
明天的计划:继续学习增删改查和预编Statement
今天的遇到的问题:
1:SQL语句无法正确执行
String sql = "delete from table1 where id = 'sad'";
在table1上加了单引号和id也加了单引号,我一直无法run。后在cmd上用正确的sql语句后成功执行了,就马上返回intellij上试了试了,果然可以了,由于之前的方法是在navicat上翻日志找来的sql语句copy到intellij上执行成功的,属于不规范的sql语句。所以日后会用正确的sql语句去操作
2:
try (
Connection c = DriverManager.getConnection(
"jdbc:mysql://127.0.0.1:3306/db1?characterEncoding=UTF-8&useSSL=false", "root", "luozeying"
);
发现Connection下滑波浪线变红。
后来问师兄,得知自己没有定义才会这样
收获:今天的收获还是很大的,因为看不懂spring也不会弄,在师兄提醒下,去重新学习JDBC,过程中发现好多问题都能解决,也知道了navicat设计表里的不是null 可以不填 “√”,然后在自增ID列 要是随便插入数据的话的可以随便填写一个数值。今天打的代码之前那些try-with-resource也能通过。
评论