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

网站顶部轮播怎么做的旅游网站建设策划

网站顶部轮播怎么做的,旅游网站建设策划,网站图片做多大,一元购物网站开发一、MyBatis 连接池:提升数据库访问效率 1. 连接池的本质与作用 本质:连接池是存储数据库连接的 “容器”,负责创建、管理连接,避免频繁创建 / 销毁连接带来的性能损耗。核心问题:若无连接池,每次执行 SQ…

 一、MyBatis 连接池:提升数据库访问效率

1. 连接池的本质与作用

  • 本质:连接池是存储数据库连接的 “容器”,负责创建、管理连接,避免频繁创建 / 销毁连接带来的性能损耗。
  • 核心问题:若无连接池,每次执行 SQL 都需新建 Connection,耗时且影响程序性能。连接池通过复用连接,大幅提升数据库操作效率。

 2. MyBatis 内置连接池分类

 

 二、动态 SQL:灵活拼接查询条件

 MyBatis 的动态 SQL 允许根据参数动态生成 SQL 语句,避免硬编码,提升代码复用性。以下是常用标签及示例:

1. if 标签:条件判断

  • 场景:根据参数是否存在动态拼接查询条件(如用户名、性别过滤)。

 示例:

<select id="findByWhere" parameterType="User" resultType="User">SELECT * FROM user<where><if test="username != null and username != ''">AND username LIKE #{username}</if><if test="sex != null and sex != ''">AND sex = #{sex}</if></where>
</select>
  • 核心where 标签自动处理首个 AND 前缀,避免 WHERE 1=1 硬编码。

2. foreach 标签:批量操作 

  • 场景:处理 IN 条件或批量参数(如根据多个 ID 查询用户)。

 示例 1:OR 拼接

<select id="findByIds" parameterType="User" resultType="User">SELECT * FROM user<where><foreach collection="ids" open="id = " separator=" OR id = " item="i">#{i}</foreach></where>
</select>
  • 生成 SQL:SELECT * FROM user WHERE id = 1 OR id = 2 OR id = 3

 示例 2:IN 集合

<select id="findByIds" parameterType="User" resultType="User">SELECT * FROM user<where><foreach collection="ids" open="id IN (" separator="," close=")" item="i">#{i}</foreach></where>
</select>
  • 生成 SQL:SELECT * FROM user WHERE id IN (1, 2, 3)

 3. sql 标签:提取公用 SQL

  • 作用:将重复 SQL 片段定义为公用模板,通过 <include> 引用,减少代码冗余。

 示例:

<!-- 定义公用 SQL -->
<sql id="findAllSql">SELECT * FROM user
</sql><!-- 引用公用 SQL -->
<select id="findAll" resultType="User"><include refid="findAllSql" />
</select>

三、多表查询:从一对一到多对多

 MyBatis 支持通过 resultMap 实现复杂的多表关联查询,将查询结果映射为包含关联对象的 JavaBean。

 1. 多对一查询(Account → User)

  • 场景:查询账号信息时,关联显示用户名称和地址(如 “账号属于哪个用户”)。

步骤: 

 1、在 Account 类中添加 User 属性:

public class Account {private Integer id;private Integer uid;private Double money;private User user; // 关联用户对象
}

2、使用 association 标签映射关联对象:

<select id="findAll" resultMap="accountMap">SELECT a.*, u.username, u.address FROM account a JOIN user u ON a.uid = u.id
</select><resultMap id="accountMap" type="Account"><result property="id" column="id" /><association property="user" javaType="User"><result property="username" column="username" /><result property="address" column="address" /></association>
</resultMap>

 2. 一对多查询(User → Accounts)

  • 场景:查询用户信息时,关联显示该用户的所有账号(如 “用户拥有哪些账号”)。

步骤: 

1、 在 User 类中添加 List<Account> 属性:

public class User {private Integer id;private String username;private List<Account> accounts; // 关联账号列表
}

2、使用 collection 标签映射集合对象:

<select id="findOneToMany" resultMap="userMap">SELECT u.*, a.money FROM user u LEFT JOIN account a ON u.id = a.uid
</select><resultMap id="userMap" type="User"><result property="id" column="id" /><collection property="accounts" ofType="Account"><result property="money" column="money" /></collection>
</resultMap>

3. 多对多查询(User ↔ Role)

  • 场景:用户与角色是多对多关系(如 “用户拥有多个角色,角色属于多个用户”)。
  • 表结构:通过中间表 user_role 关联 user 和 role 表。

 步骤: 

1、在 User 和 Role 类中分别添加对方的集合属性:

public class User {private List<Role> roles; // 用户拥有的角色列表
}
public class Role {private List<User> users; // 角色关联的用户列表
}

2、使用 collection 标签双向映射:

<!-- 查询角色及关联用户 -->
<select id="findAll" resultMap="roleMap">SELECT r.*, u.username FROM role r JOIN user_role ur ON r.id = ur.rid JOIN user u ON ur.uid = u.id
</select><resultMap id="roleMap" type="Role"><collection property="users" ofType="User"><result property="username" column="username" /></collection>
</resultMap>

四、核心配置文件:SqlMapConfig.xml 要点

1. 数据库连接配置(properties

  • 外部文件引入:将数据库参数(驱动、URL、用户名、密码)存储在 jdbc.properties 中,避免硬编码:
<properties resource="jdbc.properties" />
<dataSource type="POOLED"><property name="driver" value="${jdbc.driver}" /><property name="url" value="${jdbc.url}" />
</dataSource>

2. 类型别名(typeAliases

 简化类名:为实体类设置别名,减少配置中的全路径书写:

<!-- 为单个类设置别名 -->
<typeAlias type="com.qcbyjy.domain.User" alias="user" />
<!-- 为包下所有类自动生成别名(类名小写) -->
<package name="com.qcbyjy.domain" />

3. 映射文件加载(mappers

 引入方式:通过 resource 或 class 引用 Mapper 文件:

<mappers><mapper resource="mappers/UserMapper.xml" /><mapper class="com.qcbyjy.mapper.AccountMapper" /> <!-- 接口与映射文件同名且同路径时可用 -->
</mappers>


文章转载自:

http://AR5MztlB.kghhL.cn
http://x0T4gW8T.kghhL.cn
http://nTH1xeKJ.kghhL.cn
http://cvcIZWan.kghhL.cn
http://rwjqBOcS.kghhL.cn
http://k9EZWQpQ.kghhL.cn
http://lDaMcDcO.kghhL.cn
http://Ri3R9bva.kghhL.cn
http://QWcHaIzg.kghhL.cn
http://AE3FxlPJ.kghhL.cn
http://fe8Z3VCI.kghhL.cn
http://yRhlXjLp.kghhL.cn
http://SFrTbFnp.kghhL.cn
http://XXV9W6n6.kghhL.cn
http://GI1O1TPs.kghhL.cn
http://dGCqURPW.kghhL.cn
http://pSTsOk1D.kghhL.cn
http://ePGYjZsz.kghhL.cn
http://rK74bHx3.kghhL.cn
http://Bcni6wzQ.kghhL.cn
http://suyLDzGX.kghhL.cn
http://eVE0dVo4.kghhL.cn
http://Ni8M5yXM.kghhL.cn
http://lrOcq4fX.kghhL.cn
http://IoWSCqMq.kghhL.cn
http://RuVkymyT.kghhL.cn
http://Kqk82Hh5.kghhL.cn
http://muFuyflg.kghhL.cn
http://KQCjUTNJ.kghhL.cn
http://d6aN47Zp.kghhL.cn
http://www.dtcms.com/wzjs/761619.html

相关文章:

  • 淘宝上做淘宝客的网站网站建设+太原
  • 江苏省建设局网站证件查询电子商务网站如何建设
  • 建网站来做什么淘宝开店流程步骤图片
  • 邵阳网站seo大连城乡建设网官网
  • 简单的网站建设公司网站推广成本
  • 免费网站建设魔坊中山网站建设文化策划书
  • 阿里备案网站国内网站没备案
  • 凡科做网站的方法游戏网站建设流程图
  • 皋兰县城乡和住房建设局网站WordPress修改笔记
  • c 可以做网站吗织梦做公司网站要钱吗
  • 怎么创建一个网站卖东西html期末大作业个人网站制作
  • wordpress建站安全性卡盟代网刷24小时自助下单
  • 网站推广专家十年乐云seowordpress添加跳转页面模板
  • 哪些网站可以免费做产品推广网站怎么做充值系统
  • 竞价网站与竞价网站之间做友情链接做网站源码流程
  • xml网站地图格式saas建站平台
  • 工程建设造价全过程监督网站旅游产业网站app建设的市场分析
  • 国际贸易官方网站个人网站建设怎么赚钱
  • 谷歌搜索排名seo怎样才能优化网站
  • 官网建站网站园区 网站建设策划方案
  • 企业网络营销策略深圳关键词推广整站优化
  • 广东睿营建设有限公司网站三室两厅两卫装修实景
  • 大型门户网站建设 费用做网站背景图片浪漫爱情
  • 广州网站制作开发公司济南制作网站企业
  • 58同城网站招聘怎么做企业的网站建设文章
  • 肇庆住房和城乡建设部网站什么样的资质做电子商务网站
  • 江苏省张家港保税区建设厅网站html单页模板
  • 装修网站怎么做长链接在线转化短链接
  • 省级建设网站软件开发工程师证书怎么考
  • 网站后台登录不显示验证码关于进一步优化 广州