mybatis学习笔记续

tech2022-09-11  109

设计思想如下:要将数据库的配置和数据库操作语句隔离开来,这些都和代码无关所以最好放在xml格式的文件中,这里就引出一个问题解决xml文件的解析,解析内容有数据库的连接对象,相关连接配置,数据库操作,有无返回值,有无参数这些可以根据相关性进行分类,但这些都属于连接数据库然后进行操作的过程最好定义在一个大类中,接下来做的事情就是将这些元素代入到jdbc规范中,上面用的是代理设计的方式来实现,就能实现操作了,思想很清楚,从另一种角度上说明jdbc很重要,没有这个以上的设计就没有作用了

接下来就是对设计思想的实现

有什么办法就xml文件进行解析

先对xml文件进行了解,为什么使用xml文件来进行配置文件

(可扩展标记语言XML与Access,Oracle和SQL Server等数据库不同,数据库提供了更强有力的数据存储和分析能力,例如:数据索引、排序、查找、相关一致性等,XML的宗旨传输数据的,而与其同属标准通用标记语言的HTML主要用于显示数据。事实上XML与其他数据表现形式最大的不同是:他极其简单。这是一个看上去有点琐细的优点,但正是这点使XML与众不同。 XML的简单使其易于在任何应用程序中读写数据,这使XML很快成为数据交换的唯一公共语言,虽然不同的应用软件也支持其它的数据交换格式,但不久之后他们都将支持XML,那就意味着程序可以更容易的与Windows、Mac OS, Linux以及其他平台下产生的信息结合,然后可以很容易加载XML数据到程序中并分析他,并以XML格式输出结果。)

上面的重点是:XML的简单使其易于在任何应用程序中读写数据

如何解析xml,这就需要用到解析器

解析器是一段程序,它接受某些数据的物理表示,并将其转换为内存中的形式供程序作为整体使用。解析器在软件中无处不在。XML解析器是一种解析器,它被设计用来读取XML并为程序使用XML创建一种方法。有不同的类型,每一种都有其优点。除非程序简单而盲目地将整个XML文件作为一个单元进行复制,否则每个程序都必须实现或调用XML解析器。 解析器的主要类型有一些有趣的名称:SAX、DOM和pull。对于每种类型,都有一些优秀的实现,可以自由地用于各种语言,包括java、C++、C语言、VB(实际上,任何.NET语言)、PHP、Perl、Python、Ruby等等。

什么是SAX? Stylus Studio中的SAX解析器 SAX代表XML的简单API。它的主要特点是,当它读取XML的每个单元时,它会创建一个调用程序可以使用的事件。这允许调用程序忽略它不关心的部分,只保留或使用它喜欢的。缺点是调用程序必须跟踪它可能需要的一切。SAX通常用于某些高性能应用程序或XML大小可能超过运行程序可用内存的区域。 设计灵感和随后的协调是由davemegginson完成的,他继续维护SAX项目网站。SAX标准目前的版本是2.0。 SAX在Stylus Studio®中随处可见。它用于为XSLT和XQuery映射器构建特定的XML结构表示,也广泛用于XML转换器中。 有许多SAX解析器的实现。Apache项目已经赞助了一些,包括CyrsEngon及其继任者XeCES(在C++和java中都可用)。作者Michael Kay博士自己写了一篇LFRESD——另一个SAX解析器。

什么是DOM? Stylus Studio中的DOM解析器 DOM代表文档对象模型。它与SAX的不同之处在于它在内存中构建整个XML文档表示,然后将整个内存块交给调用程序。DOM可能是非常占用内存的;当您计算管理节点关系的开销时,您的内存使用量可能是原始文档的4倍到8倍。 Stylus Studio®中有些地方需要DOM。XML编辑器中的树视图以及所有XSLT和XQuery处理器,无论是什么品牌,但有两个明显的例外。底层的Saxon引擎和datadirectxquery都支持pull解析,这将在下面介绍。XML Pipeline deployer非常聪明;它知道每个组件的最佳表示形式是什么,并将努力工作以确保尽可能节省内存,避免从DOM到SAX再到SAX的不必要的转换。 实现包括XECES(又在C++和java中),以及微软的MSXML和系统.Xml类。 DOM(目前已达到3.0级)因过于复杂而受到广泛批评;它试图为任何实现它的语言维护相同的编程接口,即使它违反了该语言的一些约定。这导致了一些类似DOM的实现,这些实现更符合本地语言的理念。Java中的例子包括TinyTree(仅在Saxon中使用)、JDOM、DOM4J和XOM。

什么是pull解析器? Stylus Studio中的XML拉式解析器 SAX是一个推送解析器,因为它将事件推送到调用应用程序。另一方面,拉解析器坐在那里等待应用程序调用。它们请求下一个可用的事件,应用程序基本上会循环,直到用完XML为止。 拉式解析器在流式应用程序中很有用,这些应用程序要么数据太大而无法放入内存,要么数据正被及时地组装起来,以便下一阶段使用它。它被设计用于大型数据源,与SAX返回每个事件不同,pull解析器可以选择跳过它不感兴趣的事件(或者在某些实现中,跳过文档的整个部分)。转换器设计为同时使用SAX和pull解析器接口。 在Java中,流式解析器目前的主要竞争对手似乎是StAX,而在Microsoft的.Net平台中系统.XmlXmlReader是内置的。

StAX-XML流式API StAX pull解析器已经在Java世界中通过一个名为JSR-173的标准实现。Saxon和datadirectxquery都支持拉解析。在某些情况下,特别是在DataDirect的实现中,pull解析可以显著提高性能,但是这两个实现都经过了高度优化,因此对于任何给定的应用程序,在SAX、DOM和StAX之间进行选择都是一个需要测试的问题。由于在Stylus Studio®XML Enterprise Suite中,XML管道构造函数知道管道中每个节点的功能,因此会自动为您处理此选择。

使用的话,我是用idea开发,是用maven来下载的

在pox.xml编辑:

<dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>3.4.5</version> </dependency>

相关性的编辑有

<dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.16</version> </dependency> <dependency> <groupId>org.apache.logging.log4j</groupId> <artifactId>log4j-api</artifactId> <version>2.13.3</version> </dependency> <dependency> <groupId>org.apache.logging.log4j</groupId> <artifactId>log4j-core</artifactId> <version>2.13.3</version> </dependency> <dependency> <groupId>log4j</groupId> <artifactId>log4j</artifactId> <version>1.2.12</version> </dependency> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.10</version> </dependency> <dependency> <groupId>dom4j</groupId> <artifactId>dom4j</artifactId> <version>1.6.1</version> </dependency> <dependency> <groupId>jaxen</groupId> <artifactId>jaxen</artifactId> <version>1.1.6</version> </dependency>

手工的如XMLConfigBuilder类:

代理类的代码如下:

T object= (T)Proxy.newProxyInstance(daoInterfaceClass.getClassLoader(), new Class[]{daoInterfaceClass},new MapperProxy(cfg.getMappers(),connection));
最新回复(0)