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

购物网站开发意义seo网站制作优化

购物网站开发意义,seo网站制作优化,石家庄网站营销,找工程承包1、起别名 在MyBatis中&#xff0c;<typeAliases>元素用于定义类型别名&#xff0c;它可以将Java类名映射为一个更简短的别名&#xff0c;这样在映射文件中可以直接使用别名而不需要完整的类名。 下面是一个示例&#xff1a; 在mybatis核心配置文件中配置typeAliases标…

1、起别名

在MyBatis中,<typeAliases>元素用于定义类型别名,它可以将Java类名映射为一个更简短的别名,这样在映射文件中可以直接使用别名而不需要完整的类名。

下面是一个示例:

在mybatis核心配置文件中配置typeAliases标签

<typeAliases><typeAlias alias="Acount" type="duhong.entity.Account"/>
</typeAliases>

为duhong.entity.Account类指定了别名Account。

定义了这些别名后,我们可以在映射文件中直接使用这些别名来引用对应的Java类,例如:

<resultMap id="AccountMap" type="Account">

通过使用别名,我们可以简化映射文件中的配置,并提高代码可读性和可维护性。

2、mybatis核心配置文件加载映射文件的其他方式

<package name="duhong.dao"/>

这种声明方式,会使mybatis查找duhong/dao下对应的xml文件,不过这种方式要求xml资源目录与dao层目录一致,而且xml名称要与mapper接口名称一致。

3、#{}与${}的区别

在MyBatis中,#{} 和 ${} 用于处理SQL语句中的参数,但是它们在作用和安全性方面有所不同。

  1. #{} 语法:
    在MyBatis中,当你使用 #{} 来表示一个参数占位符时,MyBatis会在运行时将其替换为一个参数的值,并且会使用预处理语句(PreparedStatement)来处理参数。也就是说,不管参数值是什么,它都会被视为一个字符串值并且正确地转义。
SELECT * FROM some_table WHERE id = #{id}
  1. ${} 语法:
    与 #{} 不同,当你使用 ${} 时,MyBatis会直接将这个位置替换为变量的字面值。也就是说,如果你的变量中包含了特定的SQL关键词或结构,它将不做任何转义直接嵌入SQL语句中。
SELECT * FROM ${tableName} WHERE column = #{value}

测试:

dao层添加接口

//查询所有,按降序排列
List<Account> selectAllByDesc(String key);

mapper中添加查询语句

resultMap id="AccountMap" type="duhong.entity.Account">
<id property="id" column="id"></id>
<result property="accountNumber" column="account_number"></result>
<result property="accountType" column="account_type"></result>
<result property="balance" column="balance"></result>
</resultMap>
<select id="selectAllByDesc" resultMap="AccountMap">select * from account ORDER BY balance ${order};
</select>

添加junit,测试

SqlSession sqlSession= SqlSessionUtil.openSession();@Test
public void test(){AccountDao mapper = sqlSession.getMapper(AccountDao.class);List<Account> account = mapper.selectAllByDesc("DESC");for (Account account1 : account) {System.out.println(account);}}

将${}换成#{},执行出错,原因在于DESC是sql语句的关键字,而#{}会将参数转化为字符串。

4、模糊查询

<select id="selectLikeAll" resultMap="AccountMap">select * from account where account_number like '%${key}%';
</select>
//模糊查询
List<Account> selectLikeAll(String key);
@Test
public void likeTest(){AccountDao accountDao=sqlSession.getMapper(AccountDao.class);List<Account> accounts = accountDao.selectLikeAll("1");System.out.println(accounts);
}

同样直接使用#{}也会出错,#{}在' '中并不会被赋值

改进方式sql中使用concat拼接字符串

<select id="selectLikeAll" resultMap="AccountMap">select * from account where account_number like concat('%',#{key},'%');
</select>
http://www.hengruixuexiao.com/news/5848.html

相关文章:

  • 博星卓越电子商务网站建设实训平台怎么做公司网站
  • 网站开发公司取名西安疫情最新通知
  • 保山公司做网站上百度推广的网站要多少钱
  • 吉林手机版建站系统价格查排名的网站
  • 建设一个网站的所有代码seo外链购买
  • 腾讯云做视频网站吗个人网站免费推广
  • 在淘宝上做的网站要转出世界足球排名
  • wordpress连接pgsqlseo关键词优化软件合作
  • 先做网站还是服务器广告营销方式有哪几种
  • 汽车配件响应式网站百度seoo优化软件
  • 如何免费自学网站建设成品网站源码
  • 蒙牛企业网站建设规划书网络安全培训机构哪家好
  • 铭万魔方做网站怎么样合肥关键词快速排名
  • php网站后台建设兰州网络推广公司哪家好
  • html完整网站开发万州网站建设
  • 网站建设好吗seo研究中心论坛
  • 做绿植o2o网站怎么样什么建站程序最利于seo
  • wordpress 宝典 pdf关键词排名优化工具
  • 从事网站开发方向谷歌seo课程
  • ip动态地址做网站专业海外网站推广
  • 深圳宝安西乡网站建设seo实战教程
  • 呼和浩特百度公司seo1新地址在哪里
  • 春考网站建设seoshanghai net
  • 北京网站设计权威乐云践新seo网站推广服务
  • 黄江建设网站seo1现在怎么看不了
  • 义乌建设公司网站说说seo论坛
  • 手机wap网页游戏seo技术好的培训机构
  • 聊城网站公司重庆百度seo整站优化
  • 白云网站建设多少钱福州seo推广
  • 受欢迎的建网站公司厦门seo代运营