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

电商运营seo是什么网站快速优化

电商运营seo是什么,网站快速优化,二级域名wordpress,登封市城乡建设路网站#{}:预编译SQL。 ${}: 即时SQL。 当用户发送一条SQL语句给服务器后,大致流程如下: 1.解析SQL语句的语法和语义,校验SQL语句是否正确。 2.优化SQL语句,制定执行计划。 3.编译SQL语句。 4.执行SQL并返回结果。 一…

#{}:预编译SQL。

${}: 即时SQL。

当用户发送一条SQL语句给服务器后,大致流程如下:

1.解析SQL语句的语法和语义,校验SQL语句是否正确。

2.优化SQL语句,制定执行计划。

3.编译SQL语句。

4.执行SQL并返回结果。

一个SQL如果是上述流程,我们称之为即时SQL。

#{}的优点:

1.性能更高

在大多数情况下,某一天SQL会被反复执行,或者每次执行只是个别的值不同,如果每次都要将上述几步全部走完,效率就会比较低。

预编译SQL就是编译一次之后就会将编译后的SQL语句缓存起来(不执行1,2,3步了),后面再次执行这条SQL语句时,就不会再次编译,从而提高了性能。

*2.更安全(防止SQL注入)

这是#{}最主要的一个优点。

SQL注入:是通过操作输入的数据来修改事先定义好的SQL语句,以达到执行代码对服务器进行攻击的方法。

关于SQL注入,首先需要明白的是${}是将参数直接拼接到SQL语句后的,也就是没有“”,而#{}是在执行 SQL 时,MyBatis 会把#{}替换成?,再使用预编译语句(PreparedStatement)给?赋值。这样能有效防止 SQL 注入攻击,因为参数会被当作一个整体来处理,会自动对特殊字符进行转义。

例如:使用#{}时

<select id="queryUserByusername" resultType="com.example.mybatisxml.Model.UserInfo">select id,age,username,password from user_info by #{username}</select>

实际上执行的是:

SELECT * FROM user——info WHERE username = ?

然后再将输入的参数赋值给?

使用${}时:

<select id="queryUserByusername" resultType="com.example.mybatisxml.Model.UserInfo">select id,age,username,password from user_info where username = ${username}</select>

输入参数“zhangsan”,运行结果报错,其中一句提示是这样的:

可以看出${}是将zhangsan直接拼接到了 = 的后面,这也意味着可以通过写“‘’;drop database****;”这类语句来攻击服务器,因为服务器会将后面的drop database ****;识别为一句SQL语句。

${}应用的场景:

1.排序功能

对于SQL语句:select id, username from user_info order by id #{sort}.

List<UserInfo> queryUserBySort(String sort)

如果我们传入参数“asc”,IDEA就会报错,因为#{sort}会给asc自动添加引号,从而导致SQL错误。(因为参数类型为String,会自动加上引号)。

除此之外,如果将表名作为参数时,也会加上引号。

2.like查询

如果使用#{}:

 <select id="queryUserlike" resultType="com.example.mybatisxml.Model.UserInfo">select id,age,username,password from user_info where username like '%#{username}%'</select>List<UserInfo> queryUserlike(String username);

会报个这样的错误:

但是使用${}的话,则正常运行:

但是MySql内置了一个函数concat()来处理:

 <select id="queryUserlike2" resultType="com.example.mybatisxml.Model.UserInfo">select id,age,username,password from user_info where username like concat('%',    #{username},'%')</select>List<UserInfo> queryUserlike2(String username);

运行结果:


总结来说,当参数类型为String且不需要‘’的时候,使用${},不过需要注意SQL注入问题。


文章转载自:

http://31MM3Ff7.qkqjz.cn
http://ZklyIxmi.qkqjz.cn
http://i9fWrdAg.qkqjz.cn
http://BU02AsRG.qkqjz.cn
http://eWOmpgS6.qkqjz.cn
http://BkT5WmLz.qkqjz.cn
http://h2VPEBQf.qkqjz.cn
http://q9M82xy2.qkqjz.cn
http://IeV1aqYA.qkqjz.cn
http://CpXCk9Mu.qkqjz.cn
http://9dwpDfC9.qkqjz.cn
http://smOt02NJ.qkqjz.cn
http://qGc0dAOh.qkqjz.cn
http://5L6dvY5G.qkqjz.cn
http://QUYw4rZs.qkqjz.cn
http://uHBavbiS.qkqjz.cn
http://AiJAtEvO.qkqjz.cn
http://zOsjD7Gy.qkqjz.cn
http://1ic3pxZp.qkqjz.cn
http://qIBXCReC.qkqjz.cn
http://IbNsAvwB.qkqjz.cn
http://F328isjk.qkqjz.cn
http://pcZ4RRs4.qkqjz.cn
http://27ijUJnZ.qkqjz.cn
http://zElzKg9y.qkqjz.cn
http://pkclNnyf.qkqjz.cn
http://geK9m4rV.qkqjz.cn
http://Gx4s91zL.qkqjz.cn
http://XsBqZhOv.qkqjz.cn
http://uuhzN23p.qkqjz.cn
http://www.dtcms.com/wzjs/642725.html

相关文章:

  • 自己如何做网站教程长沙企业网站建设优度
  • 百度云服务器挂网站自己建网站卖东西好卖吗
  • 免费建站的方法西方设计网站
  • 电脑做ppt模板下载网站北京市装修公司前10名
  • 黄页网络的推广网站有哪些好站长查询站长工具
  • 网站建设后台编程协同开发平台
  • 小程序做跳转微网站公司网站与营销网站
  • 简洁的企业网站免费奖励自己的网站
  • 泉州网站建设企业温州哪里有做网站的公司4000-262-
  • 公司做网站有用吗英文网站建设大概多少钱
  • 天津网站优化收费销售网站建设常遇到的问题
  • 山东烟台建设厅网站网站开发怎么对接客户
  • 电子商务网站建设感悟深圳全网营销网站
  • 嘉兴网站建设嘉兴做网站要求什么条件
  • 怎么让百度快速收录网站wordpress网页缓存插件
  • 咨询装修常州seo建站
  • 2008 iis 添加 网站 权限网站制作培训
  • 小皮搭建本地网站wordpress绑定域名收费
  • 可以做产品设计网站百度首页排名优化平台
  • 快速提高网站权重无锡百度快速排名
  • 已经有备案的公司网站 还能不能加网站字节小程序开发教程
  • 网页制作一个网站八个页面咋做旅游网站制作文献
  • 想做网站找哪个公司好网站外链建设周期
  • 做网站推广优化哪家好目前最新的营销模式有哪些
  • 网站开发方向和移动开发方向那个好棋牌源码搭建论坛
  • 怀化网站优化加徽信xiala5效果好安卓开发
  • 网站开放培训结构设计网站推荐
  • 自己做返利网站宜春做网站 黑酷seo
  • 2002年做网站多少钱搜狗站长工具平台
  • 备案用的网站建设方案书怎么写电商网店代运营