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

给别人做网站能赚钱吗深圳福田区住房和建设局网站官网

给别人做网站能赚钱吗,深圳福田区住房和建设局网站官网,做的网站很卡,企业网站开发课程培训MyBatis是一个开源的持久层框架#xff0c;用于处理数据库的增删改查操作。它能够将Java对象与数据库中的数据进行映射关系的配置#xff0c;并自动生成对应的SQL语句#xff0c;从而简化了数据库操作的编码工作。 MyBatis的核心思想是将SQL语句与Java代码分离#xff0c;…MyBatis是一个开源的持久层框架用于处理数据库的增删改查操作。它能够将Java对象与数据库中的数据进行映射关系的配置并自动生成对应的SQL语句从而简化了数据库操作的编码工作。 MyBatis的核心思想是将SQL语句与Java代码分离通过XML或注解来配置SQL语句使得SQL语句可以进行灵活的管理和维护。通过MyBatis开发人员可以使用面向对象的思维来进行数据库操作而不需要直接编写繁琐的SQL语句。 ORMObject Relational Mapping对象关系映射是一种数据持久化技术它在对象模型和关系型数据库之间建立起对应关系并且提供了一种机制通过 JavaBean 对象去操作数据库表中的数据。 关于Maven的相关配置见之前的博客Maven项目搭建 搭建MyBatis 1. 配置依赖项 在pom.xml文件中配置Mybatis依赖库和SQL链接库等 dependencygroupIdorg.mybatis.spring.boot/groupIdartifactIdmybatis-spring-boot-starter/artifactIdversion2.2.2/version/dependencydependencygroupIdmysql/groupIdartifactIdmysql-connector-java/artifactIdversion8.0.26/version/dependency 2. 配置数据源 在resources文件夹下创建application.yml配置文件 yml基本语法 #注释用井号 名称跟冒号:   属性前面空两格: 值前面空一格     - 数组元素用短横线加空格 #配置mybatis的数据源 DataSource spring:datasource:username: rootpassword: 123123driver-class-name: com.mysql.cj.jdbc.Driverurl: jdbc:mysql://localhost:3306/easydata 3.创建封装类 package com.easy.bean;import java.math.BigDecimal;public class Staff {private int id;private String code;private String name;private BigDecimal salary;private String username;private String userpass;//这里省略getter和setter方法... } 4.定义Mapper 在resources文件夹下创建一个mapper文件夹用于存放mapper的xml文件 在该目录下新建应该xml文件 mapper 标签内指定连接的对应接口是 com.easy.dao.IStaffDao 标签之间写SQL语句在 id 中指明调用的方法名resultType 指定返回值类型小写 ?xml version1.0 encodingUTF-8? !DOCTYPE mapper PUBLIC -//mybatis.org//DTD Mapper 3.0//EN http://mybatis.org/dtd/mybatis-3-mapper.dtd mapper namespacecom.easy.dao.IStaffDao!-- 在这里写SQL语句 --select idgetNow resultTypestringselect now()/select/mapper 5.配置Mapper文件路径和别名以及日志级别 在application.yml文件中配置以下内容 #配置mapper的xml文件位置 mybatis:mapper-locations: classpath:mapper/*.xml #用于打印日志 logging:level:com.easy.dao: debug 6.定义数据访问层接口 在com.easy包下建一个dao包用于定义数据访问层的接口接口用 Mapper 注解 package com.easy.dao;import org.apache.ibatis.annotations.Mapper;import com.easy.bean.Staff;Mapper public interface IStaffDao {String getNow();} 7.编写业务处理层(可以使用面向接口) 在controller包下编写控制类使用 RestController 注解 类内用 Autowired 注入接口并在方法上使用 GetMapping 等指定请求方式 RestController public class EasyController {AutowiredIStaffDao dao;GetMapping(now)public String now() {return dao.getNow();} } 浏览器测试输出 参数传递 这里以通过姓名和编号查询staff员工表为例 mapper的对应xml文件中编写SQL语句 select idgetStaff resultTypecom.easy.bean.Staffselect * from staff where name#{name} and code#{code}/select 1.使用注解传递参数 在接口中定义方法 Mapper public interface IStaffDao {ListStaff getStaff(Param(name)String name,Param(code)String code); } 控制类中编写 getStaff 方法 GetMapping(staff)public ListStaff getStaff(RequestParam(name)String name,RequestParam(code)String code) {ListStaff staffs dao.getStaff(name, code);return staffs;} 2.使用Map传递参数 在接口中定义方法 Mapper public interface IStaffDao { ListStaff getStaff(Map params); } 控制类中编写 getStaff 方法 GetMapping(staff)public ListStaff getStaff(RequestParam Map map) {ListStaff staffs dao.getStaff(map);return staffs;} 3.使用JavaBean传递参数 在接口中定义方法 Mapper public interface IStaffDao {ListStaff getStaff(Staff staff); } 控制类中编写 getStaff 方法 GetMapping(staff)public ListStaff getStaff(Staff staff) {ListStaff staffs dao.getStaff(staff);return staffs;} 区别 使用 Map 传递参数会导致业务可读性的丧失继而导致后续扩展和维护的困难所以在实际应用中我们应该果断废弃该方式。使用 Param 注解传递参数会受到参数个数的影响。当 n≤5 时它是最佳的传参方式因为它更加直观当 n5 时多个参数将给调用带来困难。当参数个数大于 5 个时建议使用 JavaBean 方式。 占位符#和$的区别 SQL语句分为两个过程编译执行。在MyBatis中#和$是两种不同的占位符用法。 # 是预编译的占位符使用#时MyBatis会对传入的参数进行预处理类型解析之后将参数的值安全地替换到SQL语句中。例如使用#{param}占位符时MyBatis会将参数值作为字符串的形式传递给数据库这样可以防止SQL注入攻击。 $ 是直接替换的占位符使用$时MyBatis会将占位符替换为参数的字符串值。例如使用${param}占位符时MyBatis会直接将参数的值替换到SQL语句中不进行预处理。这意味着使用$时需要注意安全性和潜在的SQL注入风险因为参数值直接拼接到SQL语句中可能会导致不安全的查询。 总结来说#符号用于预处理参数提高安全性而$符号用于直接替换参数更加灵活但需要注意安全性。在实际使用中一般推荐使用#符号除非有特殊需求需要动态拼接SQL语句时才使用$符号。 注SQL注入是一种常见的安全漏洞指的是攻击者通过在应用程序中注入恶意的SQL代码使得应用程序在处理SQL语句时执行了攻击者意图的代码。 当使用$占位符时如替换的内容为 or 11  直接替换会导致SQL语句执行了不符合本意的逻辑。 映射文件常用标签 1.select标签 为了使数据库的查询结果和返回值类型中的属性能够自动匹配通常会对 MySQL 数据库和 JavaBean 采用同一套命名规则即 Java 命名驼峰规则这样就不需要再做映射了数据库表字段名和属性名不一致时需要手动映射。 常用属性 2.insert标签 MySQL、SQL Server 等数据库表可以采用自动递增的字段作为其主键当向这样的数据库表插入数据时即使不指定自增主键的值数据库也会根据自增规则自动生成主键并插入到表中。 insert idaddStaffinsert into staff(code,name,salary,username,userpass)value(#{code},#{name},#{salary},#{username},#{userpass})/insert 3.update标签 update ideditStaffupdate staff set name#{name},salary#{salary},username#{username},userpass#{userpass} where id#{id}/update 4.delete标签 delete iddelStaffdelete from staff where id#{id}/delete
http://www.hkea.cn/news/14565973/

相关文章:

  • 用typecho做的网站react网站开发介绍
  • 有没有做淘宝的网站吗做网站什么笔记本好用
  • 做网站什么什么多说与网站账号绑定
  • 开发网站商城公司建立网站步骤
  • 寄生虫网站怎么做房产网站建设网站推广
  • 男女做爰视频网站在线视频怎么在百度建设一个网站
  • 黑龙江省建设厅网站网站建设费需要缴纳印花税吗
  • 网站开发有哪些软件有哪些上海网站建设公司联系方式
  • 网站建设宽度优化教育培训
  • 丽水网站建设公司排名创作图片的软件
  • 杭州网站建设哪个平台好嘉兴网站建设平台
  • 服务网站开发天水网站开发
  • 做网站好还是做淘宝好用word做旅游网站
  • 符合seo的网站网站制作后续维护
  • 仓储物流网站建设网站建设设计制作
  • 网站加入搜索引擎怎么做建设工程施工合同的范本
  • 电子商务网站建设的心得北京网站建设 找奥美通全网营销
  • 全国设计师网站宜昌外贸网站建设优化推广
  • 怎么开设自己的网站免费icp备案服务码
  • 早期做网站 如何推广微网站建设包括哪些方面
  • 网站建设公司86215网络平台推广哪个好
  • 网站搭建 主机推荐网站建设单位哪家好
  • 南宁网站建设索q.479185700有关建设网站的问题
  • 久久建筑有限公司关键词优化推广排名
  • 太原网站快速排名提升阿里云wordpress安装教程
  • 自己做网站有什么意义wordpress数据清除缓存
  • 网页设计网站布局分析网站开发销售合同
  • 贵阳网站建设王道下拉惠盐城网站开发建设
  • 家居行业网站建设wordpress login form
  • 响应式网站和自适应网站区别家教网站代理