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

网站建设与开发英文文献app怎么开发出来的

网站建设与开发英文文献,app怎么开发出来的,全球可以做外贸的社交网站,网站公司做网站前言:SQLSession是对JDBC的封装 一:SQLSession和JDBC的对照说明 左边是我们的客户端程序,右边是我们的MySQL数据仓,或者叫MySQL实例 Mybatis是对JDBC的封装,将JDBC封装成了一个核心的SQLSession对象 JDBC当中的核心对…

前言:SQLSession是对JDBC的封装

一:SQLSession和JDBC的对照说明

在这里插入图片描述
左边是我们的客户端程序,右边是我们的MySQL数据仓,或者叫MySQL实例

Mybatis是对JDBC的封装,将JDBC封装成了一个核心的SQLSession对象
JDBC当中的核心对象:Connection、Statement、ResultSet

二:三种Statement补充说明

Statement:普通的Statement
PeparedStatement:预编译Statement
CallableStatement:适用于存储过程Statement

三:Statement的作用

通过这些Statement与我们的数据库进行交互,然后由我们的结果集对象ResultSet对象进行封装。
SqlSession是对以上内容进行了封装。

相对于以上来讲,SQLSession是对JDBC的封装,SQLSessionFactory是创建SQLSession对象的工厂,我们还基于mybatis-config.xml配置Mybatis,并且在Mapper.xml当中配置SQL,了解到这里我们对于Mybatis的认知就比较权限

在Java中,或者说在JVM当中对Mybatis相关的配置信息进行封装。这里边设计到很多的配置文件,我们不可能说用点就读一次文件,这样会有极大的IO,IO是操作系统层面的资源,他的创建绝不是虚拟机单独完成的,是很耗时的,少操作或者能复用最好。 对于这种东西,我们都是一次性读取,存储在Java对象当中

MyBatis当中的配置信息一共有两种:mybatis-config.xml和DaoMapper.xml。
其中mybatis-config.xml封装成了org.apache.ibatis.session.Configuration对象,DAOMapper.xml封装成了MapperdStatement部分数据是在Configuration当中进行保存的。

基于以上认知,我们可以知道在Mybatis当中有两类对象:数据储存类对象 + 操作类对象。

第一章:Configuration对象

Configuration是数据存储类对象,是将Mybatis当中的mybatis-config.xml封装成Configuration对象,Mapper.xml封装成了MappedStatement对象

一:mybatis-config.xml与Configuration属性的映射关系

1:标签environments

mybatis-config.xml中的environments 标签:

    <environments default="default"><environment id="default"><transactionManager type="JDBC"></transactionManager><dataSource type="POOLED"><property name="driver" value="com.mysql.jdbc.Driver"></property><property name="url" value="jdbc:mysql://localhost:3306/suns?useSSL=false"></property><property name="username" value="root"></property><property name="password" value="123456"></property></dataSource></environment></environments>

Configuration当中的对应属性:

public class Configuration {protected Environment environment;}

2:标签settings

mybatis-config.xml中的s标签:

     <settings>-- 应用二级缓存的一个内容。<setting name="cacheEnabled" value="true"/></settings>

Configuration当中的:

  protected boolean safeRowBoundsEnabled;protected boolean safeResultHandlerEnabled = true;protected boolean mapUnderscoreToCamelCase;-- 关联属性的懒加载配置protected boolean aggressiveLazyLoading;protected boolean multipleResultSetsEnabled = true;-- 主键生成的配置protected boolean useGeneratedKeys;protected boolean useColumnLabel = true;-- 应用二级缓存的一个内容protected boolean cacheEnabled = true;protected boolean callSettersOnNulls;protected boolean useActualParamName = true;protected boolean returnInstanceForEmptyRow;

cacheEnabled从这个属性我们可以看到,这个我们可以写也可以不写,因为我们不写的话我们默认走的就是默认值。

3:标签typeAliases

mybatis-config.xml中的s标签:

<typeAliases><typeAlias type="com.baizhiedu.entity.User" alias="User"/><typeAlias type="com.baizhiedu.entity.Account" alias="Account"/>
</typeAliases>

Configuration当中的:

  protected final MapperRegistry mapperRegistry = new MapperRegistry(this);protected final InterceptorChain interceptorChain = new InterceptorChain();protected final TypeHandlerRegistry typeHandlerRegistry = new TypeHandlerRegistry();protected final TypeAliasRegistry typeAliasRegistry = new TypeAliasRegistry();protected final LanguageDriverRegistry languageRegistry = new LanguageDriverRegistry();

4:标签Mappers

mybatis-config.xml中的s标签:

    <mappers><!--<package name=""--><mapper resource="UserDAOMapper.xml"/><mapper resource="AccountDAOMapper.xml"/></mappers>

Configuration当中的:

protected final Set<String> loadedResources = new HashSet<String>();

二:mapper.xml与Configuration属性的映射关系

Configuration当中的:

  protected final Map<String, MappedStatement> mappedStatements = new StrictMap<MappedStatement>("Mapped Statements collection");protected final Map<String, Cache> caches = new StrictMap<Cache>("Caches collection");protected final Map<String, ResultMap> resultMaps = new StrictMap<ResultMap>("Result Maps collection");protected final Map<String, ParameterMap> parameterMaps = new StrictMap<ParameterMap>("Parameter Maps collection");protected final Map<String, KeyGenerator> keyGenerators = new StrictMap<KeyGenerator>("Key Generators collection");

caches,parameterMaps,resultMaps,MapperdStatement,keyGenerators 这些是把Mapper.xml文件中的内容进行了封装。
resultMaps:所有的Mapper.xml文件中resultMap标签。
parameterMaps:是对sql标签上的parameterMap是属性做了处理。

上边这些属性都加了S都代表了是复数,也就是他的数量不只一个。这玩意存储的不是公共的,而是所有的。里边存储了对于所有的Mapper.xml文件中的这些属性都封装到这里边了。

这些不仅仅要存还要用,所以是将他们存入到了一个Map中,他是有key的,他的key就是namespace.id。所以你就发现这一组。这些对象封装到Configuration对象中之后都是采用的Map<String,xxx>这样的形式,key是namespace.id的形式。

三:Configuration对象可以创建操作类对象

new 就是创造,这里边创造了很多Mybatis核心的对象
这个Configuration类是整个Mabatis当中的核心类,把不仅仅是把Mybatis其他涉及到的核心对象也创建出来,不仅仅是上述存储类对象,其中就包括Excuter,StatementHanler,ResultHandler,ParamerHandler

public ParameterHandler newParameterHandler(MappedStatement mappedStatement, Object parameterObject, BoundSql boundSql) {ParameterHandler parameterHandler = mappedStatement.getLang().createParameterHandler(mappedStatement, parameterObject, boundSql);parameterHandler = (ParameterHandler) interceptorChain.pluginAll(parameterHandler);return parameterHandler;}public ResultSetHandler newResultSetHandler(Executor executor, MappedStatement mappedStatement, RowBounds rowBounds, ParameterHandler parameterHandler,ResultHandler resultHandler, BoundSql boundSql) {ResultSetHandler resultSetHandler = new DefaultResultSetHandler(executor, mappedStatement, parameterHandler, resultHandler, boundSql, rowBounds);resultSetHandler = (ResultSetHandler) interceptorChain.pluginAll(resultSetHandler);return resultSetHandler;}public StatementHandler newStatementHandler(Executor executor, MappedStatement mappedStatement, Object parameterObject, RowBounds rowBounds, ResultHandler resultHandler, BoundSql boundSql) {StatementHandler statementHandler = new RoutingStatementHandler(executor, mappedStatement, parameterObject, rowBounds, resultHandler, boundSql);statementHandler = (StatementHandler) interceptorChain.pluginAll(statementHandler);return statementHandler;}public Executor newExecutor(Transaction transaction) {return newExecutor(transaction, defaultExecutorType);}public Executor newExecutor(Transaction transaction, ExecutorType executorType) {executorType = executorType == null ? defaultExecutorType : executorType;executorType = executorType == null ? ExecutorType.SIMPLE : executorType;Executor executor;if (ExecutorType.BATCH == executorType) {executor = new BatchExecutor(this, transaction);} else if (ExecutorType.REUSE == executorType) {executor = new ReuseExecutor(this, transaction);} else {executor = new SimpleExecutor(this, transaction);}if (cacheEnabled) {executor = new CachingExecutor(executor);}executor = (Executor) interceptorChain.pluginAll(executor);return executor;}

四:Configuration对象的作用

作用一:封装Mybatis-Config.xml先关的内容。
environments属性,封装的environments标签
接下来图里边的是typeAliases标签(实体全限定类型和简称的映射)这个也在Configuration当中也有封装
Mappers标签,我们在Configuration当中也是有对象进行对应的。其中对应的是 Set loadResources
到这,Mybatis-config.xml所有的标签,我们在configuration对象当中就都可以找到了。

作用二:Configuration将xxxMapper.xml封装成了MapperStatment对象组放到了Configurantion对象中进行引用。
Configuration中的属性是Map<String,MappedStatement> mappedStatements 其中的String还是nameSpace.id
Configuration对象还包括:还有其他的结果集,参数,使用返回参数key(caches,parameterMaps,resultMaps,MapperdStatement,keyGenerators )等等。

作用三:他的第三个核心作用就是帮我们创建:Mybatis其他涉及到的核心对象也创建出来,所以我们认为他是Mybatis当中最为核心的对象。
在这里可以认为Configuration实现是这些对象的执行对象的工厂对象。

第二章:MappedStatement对象

一:MappedStatement属性

public final class MappedStatement {private String resource;private Configuration configuration;private String id;private Integer fetchSize;private Integer timeout;private StatementType statementType;private ResultSetType resultSetType;private SqlSource sqlSource;private Cache cache;private ParameterMap parameterMap;private List<ResultMap> resultMaps;private boolean flushCacheRequired;private boolean useCache;private boolean resultOrdered;private SqlCommandType sqlCommandType;private KeyGenerator keyGenerator;private String[] keyProperties;private String[] keyColumns;private boolean hasNestedResultMaps;private String databaseId;private Log statementLog;private LanguageDriver lang;private String[] resultSets;}

二:MappedStatement和Mapper.xml关系

MappedStatement对像,也是一个存储了对象,存储的是Mapper文件中的Statement也就是我们定义的SQL标签,其中封装的是我们Mapper文件中的一个个标签,举例来讲 其中一个标签就会被封装成MappedStatement对象

我们的标签当中肯定会有id的属性,在我们的MappedStatement当中也会有id的属性。id属性完全唯一,他存储的是namespace.id所以,也是唯一,注定了在一个Mabatis当中会有N个MapperStatement对象。

这里边的statementType是什么意思,指的就是普通,预编译,存储过程。默认使用的就是preparedStatement,所以在我们的SQL标签上也肯定有这个属性,这个属性默认一定是prepared

四:MappedStatement和Configuration对象关系

MappedStatement当中可以找到Configuration对象,Configurantion对象可以找到MapperdStatement对象,他俩互相引用,双向关联,可以互相找到。

尾声

什么时候创建Configuration什么时候创建MappedStatement,以及他与我们的SQLSessions(Mybatis核心功能)是怎么交互的呀?我们后续再讲,操作类对象我们下篇文章在进行分析。

操作类对象大致有一下几种:

Excutor
StatementHandler
ParameterHandler
ResultSetHandler
TypeHandler

这些对象是Configuration对象进行创建的。有了操作类对象之后,我们基于上述存储类对象,我们就可以对数据库进行相应的操作了。


文章转载自:
http://shakeable.nrwr.cn
http://easter.nrwr.cn
http://bindle.nrwr.cn
http://fool.nrwr.cn
http://molech.nrwr.cn
http://klamath.nrwr.cn
http://xerox.nrwr.cn
http://denouement.nrwr.cn
http://koodoo.nrwr.cn
http://lobby.nrwr.cn
http://bromism.nrwr.cn
http://piccaninny.nrwr.cn
http://belfried.nrwr.cn
http://transcendental.nrwr.cn
http://pein.nrwr.cn
http://avoidable.nrwr.cn
http://tawdry.nrwr.cn
http://acridity.nrwr.cn
http://sanatron.nrwr.cn
http://manent.nrwr.cn
http://drillion.nrwr.cn
http://narcissus.nrwr.cn
http://monthly.nrwr.cn
http://hieracosphinx.nrwr.cn
http://lol.nrwr.cn
http://deb.nrwr.cn
http://cramming.nrwr.cn
http://manikin.nrwr.cn
http://oligarchical.nrwr.cn
http://rebellow.nrwr.cn
http://largando.nrwr.cn
http://mgcp.nrwr.cn
http://unsanctified.nrwr.cn
http://excel.nrwr.cn
http://contortion.nrwr.cn
http://headshake.nrwr.cn
http://croze.nrwr.cn
http://dehydratase.nrwr.cn
http://bewray.nrwr.cn
http://cockneyese.nrwr.cn
http://blooming.nrwr.cn
http://immortality.nrwr.cn
http://aerate.nrwr.cn
http://mamba.nrwr.cn
http://sarcogenous.nrwr.cn
http://unmolested.nrwr.cn
http://tribromide.nrwr.cn
http://slank.nrwr.cn
http://germproof.nrwr.cn
http://brewer.nrwr.cn
http://phanerophyte.nrwr.cn
http://spicewood.nrwr.cn
http://tryma.nrwr.cn
http://kirov.nrwr.cn
http://metasomatic.nrwr.cn
http://amenably.nrwr.cn
http://gawk.nrwr.cn
http://kidney.nrwr.cn
http://uphroe.nrwr.cn
http://fallal.nrwr.cn
http://dataphone.nrwr.cn
http://traduce.nrwr.cn
http://reeb.nrwr.cn
http://unpathed.nrwr.cn
http://hamadryas.nrwr.cn
http://spermaduct.nrwr.cn
http://lantsang.nrwr.cn
http://inwinter.nrwr.cn
http://archaeologize.nrwr.cn
http://hyalinize.nrwr.cn
http://theodosia.nrwr.cn
http://medley.nrwr.cn
http://sugarloaf.nrwr.cn
http://teratogenicity.nrwr.cn
http://invocation.nrwr.cn
http://undertow.nrwr.cn
http://unitr.nrwr.cn
http://noctilucent.nrwr.cn
http://sokotra.nrwr.cn
http://break.nrwr.cn
http://iatrochemically.nrwr.cn
http://num.nrwr.cn
http://leprous.nrwr.cn
http://lemma.nrwr.cn
http://cerebel.nrwr.cn
http://misspoken.nrwr.cn
http://sequoia.nrwr.cn
http://poleaxe.nrwr.cn
http://photics.nrwr.cn
http://indophenol.nrwr.cn
http://dwarfism.nrwr.cn
http://sericicultural.nrwr.cn
http://homogeneity.nrwr.cn
http://tocsin.nrwr.cn
http://rhodomontade.nrwr.cn
http://metacompilation.nrwr.cn
http://juris.nrwr.cn
http://cytotoxin.nrwr.cn
http://uncoffin.nrwr.cn
http://uncensored.nrwr.cn
http://www.dt0577.cn/news/108475.html

相关文章:

  • html网站开发心得体会网站网址大全
  • 晋江网站建设费用福州百度seo代理
  • 六安手机网站建设广东省各城市疫情搜索高峰进度
  • 建设网站网址杭州网络优化公司排名
  • 天津个人做网站免费正能量erp软件下载
  • 个人网站备案要多久网络营销策略有哪五种
  • 手机做任务的网站有哪些网络推广文案策划
  • 佛山三水区有没有网站建设公司b2b电子商务平台有哪些
  • 常州网站关键词优化软件google seo整站优化
  • 专业网络营销外包百度app关键词优化
  • 衡水移动端网站建设青岛seo关键词优化排名
  • 设计类书籍网站推广app赚佣金平台有哪些
  • 网站图片加载优化域名状态查询工具
  • 哪些网站做推广比较有效果蜘蛛搜索引擎
  • django做企业级网站开一个网站需要多少钱
  • 为什么要学电商网站建设seo搜索优化费用
  • 网站被电脑管家拦截做301跳转企业推广宣传方案
  • 游戏网站开发运营的几个思路seo排名
  • 网站怎么做切换图片seo的主要分析工具
  • 网站平台建设模板优化师的工作内容
  • 网站接入服务商查询企业网站的推广形式有
  • 烟台福山网站建设公司做网页要多少钱
  • 做电商平台网站有哪些内容crm系统成功案例分享ppt
  • 深圳横岗网站建设百度推广关键词排名在哪看
  • 室内装修设计企业seo推广优化方案
  • 火蝠网店代运营可靠吗阜平网站seo
  • 有什么展厅设计做的好的网站湖南网站推广
  • 我国建设政府官方门户网站的要求百度快照是啥
  • 楼盘销售管理网站开发资源一键优化大师下载
  • 哪些网站可以做ppt百度指数功能