一、新建maven-web项目导入依赖

pom.xml

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>cn.ssm</groupId><artifactId>ssm</artifactId><version>1.0-SNAPSHOT</version><packaging>war</packaging><name>ssm Maven Webapp</name><properties><project.build.sourceEncoding>UTF-8</project.build.sourceEncoding><maven.compiler.source>1.8</maven.compiler.source><maven.compiler.target>1.8</maven.compiler.target></properties><dependencies><!--springmvc依赖,包含:Spring,SpringMVC相关依赖--><dependency><groupId>org.springframework</groupId><artifactId>spring-webmvc</artifactId><version>5.2.22.RELEASE</version></dependency><!--servlet和jstl依赖--><dependency><groupId>javax.servlet</groupId><artifactId>javax.servlet-api</artifactId><version>3.1.0</version><scope>provided</scope></dependency><dependency><groupId>javax.servlet</groupId><artifactId>jstl</artifactId><version>1.2</version></dependency><!--JSON相关依赖--><dependency><groupId>com.fasterxml.jackson.core</groupId><artifactId>jackson-core</artifactId><version>2.9.8</version></dependency><dependency><groupId>com.fasterxml.jackson.core</groupId><artifactId>jackson-databind</artifactId><version>2.9.8</version></dependency><!--spring整合mybatis相关依赖--><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>8.0.21</version></dependency><dependency><groupId>org.mybatis</groupId><artifactId>mybatis</artifactId><version>3.5.6</version></dependency><dependency><groupId>org.mybatis</groupId><artifactId>mybatis-spring</artifactId><version>2.0.6</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-jdbc</artifactId><version>5.2.22.RELEASE</version></dependency><!--连接池--><dependency><groupId>com.alibaba</groupId><artifactId>druid</artifactId><version>1.1.10</version></dependency><!--fileupload依赖(上传文件),暂时用不到就注释了--><!--<dependency><groupId>commons-fileupload</groupId><artifactId>commons-fileupload</artifactId><version>1.4</version></dependency><dependency><groupId>commons-io</groupId><artifactId>commons-io</artifactId><version>2.4</version></dependency>--><!--aop,暂时用不到注释--><!--<dependency><groupId>org.aspectj</groupId><artifactId>aspectjweaver</artifactId><version>1.8.8</version></dependency>--><!--日志依赖--><dependency><groupId>log4j</groupId><artifactId>log4j</artifactId><version>1.2.17</version></dependency><!--Spring的测试包--><dependency><groupId>org.springframework</groupId><artifactId>spring-test</artifactId><version>5.2.22.RELEASE</version></dependency><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version></dependency></dependencies>
</project>

二、spring和springmvc的整合

1.编写controller

package cn.ssm.controller;
import ...
@Controller
public class HelloController {@RequestMapping("/hello")@ResponseBodypublic String hello(){return "hello ssm";}
}

2.在resources目录中新增配置文件:applicationContext-mvc.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xmlns:context="http://www.springframework.org/schema/context"xmlns:mvc="http://www.springframework.org/schema/mvc"xsi:schemaLocation="http://www.springframework.org/schema/beanshttp://www.springframework.org/schema/beans/spring-beans.xsdhttp://www.springframework.org/schema/contexthttp://www.springframework.org/schema/context/spring-context.xsdhttp://www.springframework.org/schema/mvchttp://www.springframework.org/schema/mvc/spring-mvc.xsd"><!--扫描controller--><context:component-scan base-package="cn.ssm.controller"/><!--开启mvc相关注解--><mvc:annotation-driven/><!--放行静态资源:html,css,js,图片等--><mvc:default-servlet-handler/><!--视图解析器--><bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"><!--前缀--><property name="prefix" value="/WEB-INF/views/"></property><!--后缀--><property name="suffix" value=".jsp"></property></bean>
</beans>

3.在web.xml配置核心控制器和处理编码

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaeehttp://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"version="4.0"><!--配置前端控制器:加载springmvc配置文件--><servlet><servlet-name>springmvc</servlet-name><servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class><init-param><param-name>contextConfigLocation</param-name><param-value>classpath:applicationContext-mvc.xml</param-value></init-param><load-on-startup>1</load-on-startup></servlet><servlet-mapping><servlet-name>springmvc</servlet-name><url-pattern>/</url-pattern></servlet-mapping><!--配置编码--><filter><filter-name>encodingFilter</filter-name><filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class><init-param><param-name>encoding</param-name><param-value>UTF-8</param-value></init-param></filter><filter-mapping><filter-name>encodingFilter</filter-name><url-pattern>/*</url-pattern></filter-mapping>
</web-app>

4.测试 http://localhost:8080/hello ,返回hello ssm 表示成功。

三、spring和mybatis的整合

spring整合mybatis时需要注意包版本的对应关系,具体详情参考MyBatis整合Spring:http://mybatis.org/spring/zh/index.html

准备一个员工表做测试

CREATE TABLE `employee` (`id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '员工编号,主键',`name` varchar(50) DEFAULT NULL COMMENT '员工姓名',`age` int(11) DEFAULT NULL COMMENT '员工年龄',`sex` int(1) DEFAULT NULL COMMENT '性别:1表示男,0表示女',`phone` varchar(50) DEFAULT NULL COMMENT '员工电话',`address` varchar(50) DEFAULT NULL COMMENT '住址',`create_date` datetime DEFAULT NULL COMMENT '新建时间',PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8;

实体类:

package cn.ssm.domain;
import ...
public class Employee {private Long id;private String name;private Integer age;private Integer sex;private String phone;private String address;private Date createDate;//get set toString...
}

3.1 编写mapper接口

package cn.ssm.mapper;
public interface EmployeeMapper {//查询全部List<Employee> selectAll();
}

3.2 编写xml映射文件

resources/mappers/EmployeeMapper.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="cn.ssm.mapper.EmployeeMapper"><!--List<Employee> selectAll();--><select id="selectAll" resultType="Employee">select * from employee</select>
</mapper>

3.3 在resources中准备相关配置文件

数据库连接参数文件:db.properties

datasource-driver=com.mysql.cj.jdbc.Driver
datasource-url=jdbc:mysql://localhost:3306/数据库名?useUnicode=true&useSSL=false&characterEncoding=utf8&serverTimezone=Asia/Shanghai
datasource-username=root
datasource-password=123456
datasource-maxActive=5
datasource-initialSize=2

日志配置文件:log4j.properties

#设置日志级别,优先级从高到低分别是ERROR、WARN、INFO、DEBUG、TRACE
log4j.rootLogger=DEBUG, myLog
#设置对谁打印日志
log4j.logger.cn.ssm=debug
log4j.logger.org.springframework=info
#日志打印到控制台
log4j.appender.myLog=org.apache.log4j.ConsoleAppender
#使用自定义布局
log4j.appender.myLog.layout=org.apache.log4j.PatternLayout
#设置输出内容格式
log4j.appender.myLog.layout.ConversionPattern=%d [%t] %5p [%c] - %m%n

mybatis的核心配置文件:mybatis-config.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configurationPUBLIC "-//mybatis.org//DTD Config 3.0//EN""http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration><settings><!--把数据库中字段名的下划线转为bean属性的驼峰命名--><setting name="mapUnderscoreToCamelCase" value="true" /></settings>
</configuration>

3.4 spring整合mybatis

在resources目录中新增:applicationContext.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xmlns:context="http://www.springframework.org/schema/context"xmlns:aop="http://www.springframework.org/schema/aop"xmlns:tx="http://www.springframework.org/schema/tx"xsi:schemaLocation="http://www.springframework.org/schema/beanshttp://www.springframework.org/schema/beans/spring-beans.xsdhttp://www.springframework.org/schema/contexthttp://www.springframework.org/schema/context/spring-context.xsdhttp://www.springframework.org/schema/aophttp://www.springframework.org/schema/aop/spring-aop.xsdhttp://www.springframework.org/schema/txhttp://www.springframework.org/schema/tx/spring-tx.xsd"><!--1.引入外部配置文件--><context:property-placeholder location="classpath:db.properties"/><!--2.创建druid连接池--><bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource"><property name="driverClassName" value="${datasource-driver}"/><property name="url" value="${datasource-url}"/><property name="username" value="${datasource-username}"/><property name="password" value="${datasource-password}"/><!--最大连接数--><property name="maxActive" value="${datasource-maxActive}"/><!--初始化连接数--><property name="initialSize" value="${datasource-initialSize}"/><!--显示sql执行日志,不写不显示--><property name="filters" value="log4j"/></bean><!--3.整合mybatis:配置session工厂bean --><bean class="org.mybatis.spring.SqlSessionFactoryBean"><!--配置数据源--><property name="dataSource" ref="dataSource"/><!--配置mapper映射文件xml--><property name="mapperLocations" value="classpath:mappers/*.xml"/><!--配置别名--><property name="typeAliasesPackage" value="cn.ssm.domain"/><!--配置mybatis的配置文件--><property name="configLocation" value="classpath:mybatis-config.xml"/></bean><!--4.整合mybatis:配置mapper接口扫描器,生成代理对象--><bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"><property name="basePackage" value="cn.ssm.mapper"/></bean></beans>

3.4 测试

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration("classpath:applicationContext.xml")
public class MyTest {@Autowiredprivate EmployeeMapper employeeMapper;@Testpublic void t1(){employeeMapper.selectAll().forEach(System.out::println);}
}

3.5 监听器加载spring配置文件

刚才咱们已经可以让spring来管理mybatis了,但是总不能每次使用的时候,自己写个测试类加载配置文件从而让spring管理mybatis。所以applicationContext.xml不应该我们自己来加载。同时项目结构目前还缺少service层。

3.5.1 service层

接口:

package cn.ssm.service;
import ...
public interface IEmployeeService {List<Employee> selectAll();
}

实现类:

package cn.ssm.service.impl;
import ...
@Service
public class EmployeeServiceImpl implements IEmployeeService {@Autowiredprivate EmployeeMapper employeeMapper;@Overridepublic List<Employee> selectAll() {return employeeMapper.selectAll();}
}

3.5.2 controller层

package cn.ssm.controller;
import ...
@Controller
public class EmployeeController {@Autowiredprivate IEmployeeService employeeService;@RequestMapping("/employee/list")public String list(Model model){List<Employee> employees = employeeService.selectAll();model.addAttribute("employees",employees);return "empList";}
}

3.5.3 添加页面

WEB-INF/views/empList.jsp

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<html>
<head><title>Title</title>
</head>
<body>
<table><tr><th>序号</th><th>员工编号</th><th>姓名</th><th>年龄</th><th>性别</th><th>电话</th><th>地址</th><th>新建时间</th></tr><c:forEach items="${employees}" var="emp" varStatus="empStatus"><tr><td>${empStatus.count}</td><td>${emp.id}</td><td>${emp.name}</td><td>${emp.age}</td><td><c:if test="${emp.sex==1}">男</c:if><c:if test="${emp.sex==0}">女</c:if></td><td>${emp.phone}</td><td>${emp.address}</td><td>${emp.createDate}</td></tr></c:forEach>
</table>
</body>
</html>

3.5.4 使用监听器加载spring配置文件

1.在applicationContext.xml中添加:

<!--扫描service层-->
<context:component-scan base-package="cn.ssm.service"/>

2.使用监听器加载spring配置文件,在web.xml添加

<!--监听器:加载spring配置文件-->
<listener><listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<context-param><param-name>contextConfigLocation</param-name><param-value>classpath:applicationContext.xml</param-value>
</context-param>

3.5.5 测试

http://localhost:8080/employee/list

到此,整合ssm就结束了。

四、SSM整合ajax

如果不想使用jsp的方式去实现数据展示,我们还可以使用ajax异步的方式发送请求,服务端返回json,客户端根据返回的json来进行相关的处理,从而做到职责更加单一,同时从同步变为异步请求和局部刷新的方式,用户体验度也会更好。

4.1 ajax介绍

AJAX 是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术。
AJAX = Asynchronous JavaScript and XML。
AJAX 是一种用于创建快速动态网页的技术。
AJAX 通过在后台与服务器进行少量数据交换,使网页实现异步更新。这意味着可以在不重载整个页面的情况下,对网页的某些部分进行更新。
传统的网页(不使用 AJAX)如果需要更新内容,必须重载整个页面。

4.2 ajax的使用

① 原生JS实现ajax请求发送

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>原生ajax</title>
</head>
<body><button onclick="doGet()">点击发送get请求</button><button onclick="doPost()">点击发送post请求</button><script>function doGet(){//1.创建XMLHttpRequest对象let xhr = null;if (window.XMLHttpRequest){ // IE7+, Firefox, Chrome, Opera, Safari 浏览器执行的代码xhr=new XMLHttpRequest();}else{  //IE6, IE5 浏览器执行的代码xhr=new ActiveXObject("Microsoft.XMLHTTP");}//2.open()中参数1:请求方式,参数2:url,参数3:异步true(默认)/同步falsexhr.open("GET","/doGet?id=1&name=tom");//3.监听服务端返回xhr.onreadystatechange=function(){// xhr.readyState==4 :表示客户端已经接收服务端返回的数据,可以获取返回结果// 0:请求未初始化// 1:服务器连接已建立// 2:服务端请求已收到// 3:服务端正在处理请求// 4:请求已完成且客户端响应已就绪// xhr.status==200 : 表示http状态码为200if (xhr.readyState==4 && xhr.status==200){//获取服务端返回结果(字符串)let result = xhr.responseText;//将json字符串转为json对象let jsonObj = JSON.parse(result);console.log(jsonObj);}}//4.执行发送xhr.send();}function doPost(){//1.创建XMLHttpRequest对象let xhr = null;if (window.XMLHttpRequest){xhr=new XMLHttpRequest();}else{xhr=new ActiveXObject("Microsoft.XMLHTTP");}//2.设置请求方式 和 urlxhr.open("POST","/doPost");//因为post请求参数是从请求体中传递,所以必须设置content-typexhr.setRequestHeader('content-type','application/x-www-form-urlencoded');//3.监听服务端返回xhr.onreadystatechange=function(){if (xhr.readyState==4 && xhr.status==200){//获取服务端返回结果(字符串)let result = xhr.responseText;console.log(result);}}//4.执行发送时添加post的参数xhr.send("id=1&name=tom");}</script>
</body>
</html>

② jQuery的方式实现ajax请求发送

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>jQuery实现ajax</title><script src="https://code.jquery.com/jquery-3.6.0.min.js"></script>
</head>
<body><button onclick="doGet()">点击发送get请求</button><button onclick="doPost()">点击发送post请求</button><script>function doGet(){//参数1:url,参数2:请求参数(没有可以不写),参数3:成功时的回调函数,data为返回数据$.get( "/doGet",{id:1,name:"tom"},function( data ) {console.log(data);});}function doPost(){//参数1:url,参数2:请求参数(没有可以不写),参数3:成功时的回调函数,data为返回数据$.post( "/doGet",{id:1,name:"tom"},function( data ) {console.log(data);});}//jQuery还提供了 $.ajax的方法是发送请求/*$.ajax({url:"请求地址",type:"get/post/...",data:{请求参数},success:function (data){console.log(data);}});*/</script>
</body>
</html>

③ 服务端接收并相应结果

@Controller
public class AjaxController {@RequestMapping("/doGet")@ResponseBodypublic List<Employee> get(Integer id,String name){//接收客户端参数System.out.println("id:"+id+",name:"+name);//模拟假数据,返回客户端List<Employee> lists = new ArrayList<>();lists.add(new Employee(1L,"tom",30,1,"17788889999","xx",new Date()));lists.add(new Employee(2L,"jack",30,1,"17788889999","xx",new Date()));lists.add(new Employee(3L,"rose",30,1,"17788889999","xx",new Date()));return lists;}@RequestMapping("/doPost")@ResponseBodypublic List<Employee> post(Integer id,String name){//接收客户端参数System.out.println("id:"+id+",name:"+name);//模拟假数据,返回客户端List<Employee> lists = new ArrayList<>();lists.add(new Employee(1L,"tom",30,1,"17788889999","xx",new Date()));lists.add(new Employee(2L,"jack",30,1,"17788889999","xx",new Date()));lists.add(new Employee(3L,"rose",30,1,"17788889999","xx",new Date()));return lists;}
}

五、Spring事务管理

5.1 开启事务管理

applicationContext.xml中添加配置,开启事务。

<!--配置事务管理器,id必须是:transactionManager -->
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"><property name="dataSource" ref="dataSource"/>
</bean>
<!--开启事务注解,配合@Transactional使用-->
<tx:annotation-driven/>

5.2 使用注解修饰业务方法

在业务层实现类方法上注解 @Transactional ,可以修饰类或者方法

@Service
//@Transactional  //修饰类为该类中的所有方法添加事务管理
public class EmployeeServiceImpl implements IEmployeeService {@Autowiredprivate EmployeeMapper employeeMapper;@Transactional //修饰方法仅为当前方法添加事务管理@Overridepublic void delete(Long id) {employeeMapper.delete(id);}
}

5.3 @Transactional说明

public @interface Transactional {...//传播特性:REQUIREDPropagation propagation() default Propagation.REQUIRED;//只读为:falseboolean readOnly() default false; ...
}

Spring的事务7大传播特性:
Propagation_REQUIRED:支持当前事务,如果当前没有事务,则新建一个事务(默认)。
Propagation_SUPPORTS:支持当前事务,如果当前有事务则加入到这个事务,没有则以非事务的方式运行。
Propagation_REQUIRES_NEW:开启一个新事物,如果当前有事务则挂起。
Propagation_NEVER : 不支持事务,如果当前有事务,则抛出异常。
Propagation_MANDATORY:需要事务,如果当前没有事务则抛出异常。
Propagation_NOT_SUPPORTED:不支持事务,总是以非事务的方式运行。
Propagation_NESTED:嵌套事务。

基于此,在读方法上,我们可以使用readOnly = true,propagation = Propagation.SUPPORTS的组合,而在写方法上则使用readOnly = false,propagation = Propagation.REQUIRED组合。

@Service
@Transactional(readOnly = true,propagation = Propagation.SUPPORTS) //读事务
public class XxxServiceImpl ...{@Autowired...@Transactional  //写事务//写方法1@Transactional  //写事务//写方法2//读方法1//读方法2//读方法3//读方法4
}

05-Java框架-SSM整合相关推荐

  1. java框架ssm整合_SSM三大框架整合详细教程(Spring+SpringMVC+MyBatis)

    使用 SSM ( Spring . SpringMVC 和 Mybatis )已经有三个多月了,项目在技术上已经没有什么难点了,基于现有的技术就可以实现想要的功能,当然肯定有很多可以改进的地方.之前没 ...

  2. Java SSM6——SSM整合

    Java SSM6--SSM整合 1.Mybatis 1.1.数据库准备 CREATE TABLE person(id INT PRIMARY KEY,NAME VARCHAR(10),PASSWOR ...

  3. java框架ssm面试题2016_Java面试-框架篇(SSM-SpringMVC)

    1.讲下SpringMvc的核心入口类是什么,Struts1,Struts2的分别是什么 SpringMvc的是DispatchServlet,Struts1的是ActionServlet,Strut ...

  4. 9. 都什么时候了,你还不会框架SSM整合

    9 都什么时候了,你还不会整合SSM

  5. Day88 Java框架 SSM分布式案例--商城(一)介绍

    电商行业技术特点 一.特点 技术新 技术范围广 分布式 高并发,集群,负载均衡,高可用 海量数据 业务复杂 系统安全 商城介绍 一.名词解释 传统行业: OA, CRM, ERP, 医药采购管理系统, ...

  6. java框架ssm_【Java】SSM框架整合 附源码

    前言 前面已经介绍Spring和Mybatis整合,而本篇介绍在IDEA下Spring.Spring MVC.Mybatis(SSM)三个框架的整合,在阅读本篇之前,建议大家先去了解一下Spring. ...

  7. SSM框架——详细整合教程(Spring+SpringMVC+MyBatis)

    登录 | 注册 收藏成功 确定 收藏失败,请重新收藏 确定 查看所有私信查看所有通知 暂没有新通知 想要绕过微信小程序开发中的坑吗?不妨来听这个,今晚8点,1小时帮你搞定! 14小时以前 CSDN日报 ...

  8. [转]SSM框架——详细整合教程(Spring+SpringMVC+MyBatis)

    使用SSM(spring.SpringMVC和Mybatis)已经有三个多月了,项目在技术上已经没有什么难点了,基于现有的技术就可以实现想要的功能,当然肯定有很多可以改进的地方.之前没有记录SSM整合 ...

  9. SSM整合框架实现发送邮件功能

    SSM整合框架实现发送邮件功能 1.导入发送邮件的依赖 <!-- 发送邮件jar包--><!--spring支持--><dependency><groupId ...

最新文章

  1. java i 底层原理,《Java基础知识》Java Hash底层原理
  2. html表格判断,lua table 长度解析
  3. rax+react hook 实现分页效果
  4. IOS多线程任务(综述篇)
  5. Linux内核分析 - 网络[十一]:ICMP模块
  6. js中递归调用返回值为undefined问题
  7. 部门树_神奇!十堰这个小山村竟然藏着两棵500多年的爱情树!
  8. element时间范围选择添加限制条件
  9. IOS APP 上传到AppStore
  10. Imagenet与ILSVRC数据集介绍
  11. xp怎样修改计算机mac地址,WinXP系统MAC地址修改的方法
  12. 处理不连续单元格,如sum,sumif,countif
  13. 【微信小程序】上传字体文件自定义字体family
  14. pandas笔记(7)DataFrame数学运算
  15. NPOI 在word中插入 表格 包括 合并单元格
  16. Aocoda-RCF7/F7 MINI飞控无法解锁的疑难杂症-使用 Betaflight 10.8.0调参软件地面站刷写固件以及AOCODAF722MINI 配置文件
  17. 如何设置对话框的最大(小)高度与宽度
  18. 51单片机开发实例 基于51单片机的万年历
  19. message: Content type 'multipart/form-data;boundary=----WebKitFormBoundaryksbSBUwTCB6eHI3j;charse
  20. Shell脚本读取mysql结果集各数据项的值

热门文章

  1. office简单钓鱼与cve2017-11882
  2. java满了怎么清空_Win 10 C 盘突然爆满,怎么清理?
  3. 8g内存一般占用多少_4/8/16/32GB 玩游戏多少内存才够用?实测大吃一惊
  4. 企业邮箱大概多少钱?如何开通企业邮箱,要钱吗?
  5. mysql按照中文姓名排序
  6. python实现tailf或者filebeat功能
  7. Call to a member function num_rows() on boolean in ...
  8. RocketMQ——MQ基础知识
  9. 移动互联网,还是离农村还有点远
  10. 阿里架构师花近十年时间整理出来的Java核心知识pdf(Java岗)