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

wordpress游客不加载图片长沙百度快照优化排名

wordpress游客不加载图片,长沙百度快照优化排名,提升网站建设品质公司,免费做网站的好不好1. Mybatis中#和$的区别? #相当于对数据 加上 双引号,$相当于直接显示数据 1. #将传入的数据都当成一个字符串,会对自动传入的数据加一个双引号。如:order by #user_id#,如果传入的值是111,那么解析成sql时的值为orde…

1.  Mybatis中#和$的区别?

#相当于对数据 加上 双引号,$相当于直接显示数据 
1. #将传入的数据都当成一个字符串,会对自动传入的数据加一个双引号。如:order by #user_id#,如果传入的值是111,那么解析成sql时的值为order by "111", 如果传入的值是id,则解析成的sql为order by "id".

2.  $将传入的数据直接显示生成在 sql 中。如:order  by $user_id$,如果传入的值是 111,那么解析成 sql 时的值为order by user_id,  如果传入的值是id,则解析成的sql为order by id.

3. #方式能够很大程度防止sql注入。 

4.$方式无法防止Sql注入。 

5.$方式一般用于传入数据库对象,例如传入表名. 

6.一般能用#的就别用$. 

2.  Mybatis的编程步骤是什么样的?

1、创建SqlSessionFactory

2、通过SqlSessionFactory创建SqlSession 

3、通过sqlsession执行数据库操作 

4、调用session.commit()提交事务 

5、调用session.close()关闭会话 

3.  JDBC编程有哪些不足之处,MyBatis是如何解决这些问题的?

1. 数据库链接创建、释放频繁造成系统资源浪费从而影响系统性能,如果使用数据库链接池可解决此问题。  解决:在SqlMapConfig.xml中配置数据链接池,使用连接池管理数据库链接。 

2. Sql语句写在代码中造成代码不易维护,实际应用sql变化的可能较大,sql变动需要改变java代码。  解决:将Sql语句配置在XXXXmapper.xml文件中与java代码分离。 

3. 向 sql 语句传参数麻烦,因为 sql 语句的 where 条件不一定,可能多也可能少,占位符需要和参数一一对应。  解决: Mybatis自动将java对象映射至sql语句。 

4. 对结果集解析麻烦,sql变化导致解析代码变化,且解析前需要遍历,如果能将数据库记录封装成pojo对象解析比较方便。 

解决:Mybatis自动将sql执行结果映射至java对象。 

4.  使用MyBatis的mapper接口调用时有哪些要求?

1. Mapper接口方法名和mapper.xml中定义的每个sql的id相同 
2. Mapper接口方法的输入参数类型和mapper.xml中定义的每个sql 的parameterType的类型相同 3. Mapper接口方法的输出参数类型和mapper.xml中定义的每个sql的resultType的类型相同 4. Mapper.xml文件中的namespace即是mapper接口的类路径。 

5.  Mybatis中一级缓存与二级缓存?

1. 一级缓存: 基于 PerpetualCache 的  HashMap 本地缓存,其存储作用域为  Session,当  Session flush 或 close 之后,该Session中的所有  Cache 就将清空。 

2. 二级缓存与一级缓存其机制相同,默认也是采用  PerpetualCache,HashMap存储,不同在于其存储作用域为 Mapper(Namespace),并且可自定义存储源,如  Ehcache。作用域为namespance是指对该namespance对应的配置文件中所有的select操作结果都缓存,这样不同线程之间就可以共用二级缓存。启动二级缓存:在mapper配置文件中:<cache />。 

二级缓存可以设置返回的缓存对象策略:<cache readOnly="true">。当readOnly="true"时,表示二级缓存返回给所有调用者同一个缓存对象实例,调用者可以 update 获取的缓存实例,但是这样可能会造成其他调用者出现数据不一致的情况(因为所有调用者调用的是同一个实例)。当readOnly="false"时,返回给调用者的是二级缓存总缓存对象的拷贝,即不同调用者获取的是缓存对象不同的实例,这样调用者对各自的缓存对象的修改不会影响到其他的调用者,即是安全的,所以默认是readOnly="false"; 
3. 对于缓存数据更新机制,当某一个作用域(一级缓存Session/二级缓存Namespaces)的进行了  C/U/D 操作后,默认该作用域下所有  select 中的缓存将被clear。 

6.  MyBatis在insert插入操作时返回主键ID

数据库为MySql时: 

1. <insert id="insert" parameterType="com.test.User" keyProperty="userId"

useGeneratedKeys="true" >

“keyProperty”表示返回的id要保存到对象的那个属性中,“useGeneratedKeys”表示主键id为自增长模式。MySQL中做以上配置就OK了 

数据库为Oracle时: 

1. <insert id="insert" parameterType="com.test.User">

2.    <selectKey resultType="INTEGER" order="BEFORE" keyProperty="userId">

3.        SELECT SEQ_USER.NEXTVAL as userId from DUAL 

4.    </selectKey> 

5.     insert into user (user_id, user_name, modified, state)

6.     values (#{userId,jdbcType=INTEGER}, #{userName,jdbcType=VARCHAR},

#{modified,jdbcType=TIMESTAMP}, #{state,jdbcType=INTEGER}) 

7. </insert> 

由于 Oracle 没有自增长一说法,只有序列这种模仿自增的形式,所以不能再使用“useGeneratedKeys”属性。 而是使用<selectKey>将ID获取并赋值到对象的属性中,insert插入操作时正常插入id。 

http://www.qdjiajiao.com/news/435.html

相关文章:

  • 做静态网站有什么用24小时自助下单平台网站便宜
  • 西安互联网网站建设seo规范培训
  • 上海做网站好的公司域名比价网
  • 做简历比较好的网站济南seo公司
  • 安装好采集侠网站地图后在哪里查看网站地图cpa游戏推广联盟
  • 温州企业自助建站系统网络营销毕业论文范文
  • 南阳做网站优化哪家好站长工具app下载
  • 购物网站修改文案代刷网站推广
  • 动态网站建设 教学大纲公司网站设计公司
  • 网站空间去哪里买的公关公司经营范围
  • 南平网站建设网站优化怎么操作
  • 北京建设网站的公司兴田德润优惠长春网站建设技术托管
  • 网站建设违约怎么投诉惠州企业网站建设
  • 电商网站建设计划书上海关键词seo
  • 企业管理系统有前端优化
  • 企业模板网站建设seo型网站
  • 渭南做网站厦门seo网站排名优化
  • 普洱市交通建设集团官方网站长沙seo网络推广
  • 公司支付网站服务费怎么做分录aso优化推广
  • 湛江网站建设工作百度关键词排名怎么查
  • 百事通网做网站免费推广工具有哪些
  • 医院网站绿色模板网络营销师报名官网
  • 武汉网站排名优化广州谷歌推广
  • 网站免费建立提升神马seo关键词自然排名
  • dreamweaver网站制作教程私人浏览器
  • 手机网站模板下载免费郑州网站seo服务
  • 那个网站可以找人做设计师广州网页搜索排名提升
  • 用flash做网站超链接谷歌优化怎么做
  • 佛山顺德网站建设素材网
  • 目录网站做外链朋友圈软文