9.spring-boot之mybatis-logback-freemarker

盲目的拾荒者      2022-05-17     241

关键词:

初始化SQL
DROP TABLE IF EXISTS `user`;

CREATE TABLE `user` (

`id` int(11) NOT NULL AUTO_INCREMENT,

`name` varchar(50) DEFAULT NULL,

`password` varchar(32) DEFAULT NULL,

`age` int(11) DEFAULT NULL,

`phone` varchar(32) DEFAULT NULL,

PRIMARY KEY (`id`)

) ENGINE=InnoDB AUTO_INCREMENT=9 DEFAULT CHARSET=utf8;



-- ----------------------------

-- Records of user

-- ----------------------------

INSERT INTO `user` VALUES (1, 张三, 123456, 23, 15094037891);

INSERT INTO `user` VALUES (3, 李四, 123456, 24, 1509403791);

INSERT INTO `user` VALUES (5, 赵六, 12345, 34, 15094037891);

INSERT INTO `user` VALUES (8, 2323, 123456, 445, 44);

 

1.pom.xml

<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>springboot</groupId>

<artifactId>testSpringBoot</artifactId>

<version>0.0.1-SNAPSHOT</version>

<packaging>war</packaging>

<name>testSpringBoot</name>

<url>http://maven.apache.org</url>

<properties>

<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>

</properties>

<!-- 继承父包 -->

<parent>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-starter-parent</artifactId>

<version>1.5.2.RELEASE</version>

<relativePath></relativePath>

</parent>

<dependencies>

<dependency>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-starter-web</artifactId>

</dependency>

<!--jdbc -->

<dependency>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-starter-jdbc</artifactId>

</dependency>

<!-- Spring Boot Mybatis 依赖 -->

<dependency>

<groupId>org.mybatis.spring.boot</groupId>

<artifactId>mybatis-spring-boot-starter</artifactId>

<version>1.2.0</version>

</dependency>

<!--mysql驱动 -->

<dependency>

<groupId>mysql</groupId>

<artifactId>mysql-connector-java</artifactId>

</dependency>

<!--连接池 -->

<dependency>

<groupId>com.alibaba</groupId>

<artifactId>druid</artifactId>

<version>1.0.25</version>

</dependency>

<dependency>

<groupId>org.apache.commons</groupId>

<artifactId>commons-lang3</artifactId>

<version>3.2</version>

</dependency>

<!-- freemarker -->

<dependency>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-starter-freemarker</artifactId>

</dependency>

<!--alibab json -->

<dependency>

<groupId>com.alibaba</groupId>

<artifactId>fastjson</artifactId>

<version>1.2.44</version>

</dependency>

<!--单元测试 -->

<dependency>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-starter-test</artifactId>

</dependency>

<dependency>

<groupId>junit</groupId>

<artifactId>junit</artifactId>

<scope>test</scope>

</dependency>

</dependencies>

<!--maven的插件 -->

<build>

<plugins>

<plugin>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-maven-plugin</artifactId>

</plugin>

</plugins>

<pluginManagement>

<plugins>

<plugin>

<!-- 配置java版本 不配置的话默认父类配置的是1.6 -->

<artifactId>maven-compiler-plugin</artifactId>

<configuration>

<source>1.7</source>

<target>1.7</target>

</configuration>

</plugin>

<!-- 配置Tomcat插件 -->

<plugin>

<groupId>org.apache.tomcat.maven</groupId>

<artifactId>tomcat7-maven-plugin</artifactId>

<version>2.2</version>

</plugin>

</plugins>

</pluginManagement>

</build>

</project>

 

技术图片

2.logback.xml

<configuration>

<!-- %m输出的信息,%p日志级别,%t线程名,%d日期,%c类的全名,%i索引【从数字0开始递增】,,, -->

<!-- appender是configuration的子节点,是负责写日志的组件。 -->

<!-- ConsoleAppender:把日志输出到控制台 -->

<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">

<encoder>

<pattern>%d %p (%file:%line)- %m%n</pattern>

<!-- 控制台也要使用UTF-8,不要使用GBK,否则会中文乱码 -->

<charset>UTF-8</charset>

</encoder>

</appender>

<!-- RollingFileAppender:滚动记录文件,先将日志记录到指定文件,当符合某个条件时,将日志记录到其他文件 -->

<!-- 以下的大概意思是:1.先按日期存日志,日期变了,将前一天的日志文件名重命名为XXX%日期%索引,新的日志仍然是sys.log -->

<!-- 2.如果日期没有发生变化,但是当前日志的文件大小超过1KB时,对当前日志进行分割 重命名-->

<appender name="syslog"

class="ch.qos.logback.core.rolling.RollingFileAppender">

<File>d:/springbootlog/springboot.log</File>

<!-- rollingPolicy:当发生滚动时,决定 RollingFileAppender 的行为,涉及文件移动和重命名。 -->

<!-- TimeBasedRollingPolicy: 最常用的滚动策略,它根据时间来制定滚动策略,既负责滚动也负责出发滚动 -->

<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">

<!-- 活动文件的名字会根据fileNamePattern的值,每隔一段时间改变一次 -->

<!-- 文件名:log/sys.2017-12-05.0.log -->

<fileNamePattern>log/springboot.%d.%i.log</fileNamePattern>

<!-- 每产生一个日志文件,该日志文件的保存期限为30天 -->

<maxHistory>30</maxHistory>

<timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">

<!-- maxFileSize:这是活动文件的大小,默认值是10MB,本篇设置为1KB,只是为了演示 -->

<maxFileSize>1KB</maxFileSize>

</timeBasedFileNamingAndTriggeringPolicy>

</rollingPolicy>

<encoder>

<!-- pattern节点,用来设置日志的输入格式 -->

<pattern>

%d %p (%file:%line)- %m%n

</pattern>

<!-- 记录日志的编码 -->

<charset>UTF-8</charset> <!-- 此处设置字符集 -->

</encoder>

</appender>

<!-- 控制台输出日志级别 -->

<root level="info">

<appender-ref ref="STDOUT" />

</root>

<!-- 指定项目中某个包,当有日志操作行为时的日志记录级别 -->

<!-- com.niugang为根包,也就是只要是发生在这个根包下面的所有日志操作行为的权限都是DEBUG -->

<!-- 级别依次为【从高到低】:FATAL > ERROR > WARN > INFO > DEBUG > TRACE -->

<logger name="com.niugang" level="DEBUG">

<appender-ref ref="syslog" />

</logger>

</configuration>

 

技术图片

3.application.properties

#web项目名称

server.contextPath=/myweb

#配置freemaker

spring.freemarker.template-loader-path=/WEB-INF/view

spring.freemarker.cache=false

spring.freemarker.charset=UTF-8

spring.freemarker.check-template-location=true

spring.freemarker.content-type=text/html

spring.freemarker.expose-request-attributes=true

spring.freemarker.expose-session-attributes=true

spring.freemarker.request-context-attribute=request

spring.freemarker.suffix=.html

#引入jdbc相关配置

spring.profiles.active=jdbc

#mybatis.config = mybatis 配置文件名称

#mybatis.mapperLocations = mapper xml 文件地址

#mybatis.typeAliasesPackage = 实体类包路径

#mybatis.typeHandlersPackage = type handlers 处理器包路径

#mybatis.check-config-location = 检查 mybatis 配置是否存在,一般命名为 mybatis-config.xml

#mybatis.executorType = 执行模式。默认是 SIMPLE

## Mybatis 配置

mybatis.typeAliasesPackage=com.niugang.entity

mybatis.mapperLocations=classpath:mapper/*.xml

#logback配置

#===================================== log =============================

logging.config=classpath:logback-boot.xml

#修改默认HTTP编码,之前是在web.xml中过滤的,两个必须同时使用

spring.http.enconding.charset=UTF-8

spring.http.encoding.force=true

 

技术图片

4.application-jdbc.properties

# 驱动配置信息

spring.datasource.type=com.alibaba.druid.pool.DruidDataSource

spring.datasource.url = jdbc:mysql://localhost:3306/springboot?useUnicode=true&characterEncoding=utf-8

spring.datasource.username = root

spring.datasource.password = 123456

spring.datasource.driverClassName = com.mysql.jdbc.Driver

#连接池的配置信息

## 初始化大小,最小,最大

spring.druid.initialSize=5

spring.druid.minIdle=5

spring.druid.maxActive=20

## 配置获取连接等待超时的时间

spring.druid.maxWait=60000

# 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒

spring.druid.timeBetweenEvictionRunsMillis=60000

# 配置一个连接在池中最小生存的时间,单位是毫秒

spring.druid.minEvictableIdleTimeMillis=300000

spring.druid.validationQuery=SELECT 1 FROM DUAL

spring.druid.testWhileIdle=true

spring.druid.testOnBorrow=false

spring.druid.testOnReturn=false

spring.druid.poolPreparedStatements=true

spring.druid.maxPoolPreparedStatementPerConnectionSize=20

# 配置监控统计拦截的filters,去掉后监控界面sql无法统计,‘wall‘用于防火墙

spring.druid.filters=stat,wall,log4j

# 通过connectProperties属性来打开mergeSql功能;慢SQL记录

spring.druid.connectionProperties=druid.stat.mergeSql=true;druid.stat.slowSqlMillis=5000

 

技术图片

5.springboot启动类

package com.niugang;



import org.mybatis.spring.annotation.MapperScan;

import org.springframework.boot.SpringApplication;

import org.springframework.boot.autoconfigure.SpringBootApplication;

import org.springframework.boot.web.support.SpringBootServletInitializer;

//解决包tomcat冲突

//@EnableAutoConfiguration(exclude={WebMvcAutoConfiguration.class})

//组件扫描,会自动扫描springboot启动类包及其子包下的注解文件

//@ComponentScan("com.niugang.controller")

//springboot注解

//springboot1.2+之后用@SpringBootApplication替代了三个注解

@SpringBootApplication

//mapper 接口类扫描包配置

@MapperScan(value={"com.niugang.dao"})

public class Application extends SpringBootServletInitializer{

public static void main(String[] args) {

SpringApplication.run(Application.class,args);

}



}

 

技术图片

6.实体类

package com.niugang.entity;



public class User {

private int id;

private String name;

private Integer age;

private String phone;

private String password;

public String getPassword() {
return password;
}
public void setPassword(String password) {

this.password = password;

}

public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {

return name;

}

public void setName(String name) {
this.name = name;
}

public Integer getAge() {
return age;
}

public void setAge(Integer age) {
this.age = age;
}

public String getPhone() {
return phone;
}

public void setPhone(String phone) {
this.phone = phone;
}

}

 

技术图片

7.mapper文件

<?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="com.niugang.dao.UserDao">

<resultMap id="BaseResultMap" type="com.niugang.entity.User">

<result column="id" property="id" />

<result column="name" property="name" />

<result column="age" property="age" />

<result column="phone" property="phone" />

</resultMap>



<!--查询字段 -->

<sql id="Base_Column_List">

id, name, age,phone

</sql>

<!-- 查询条件 -->

<sql id="queryCondition">

<where>

<if test="id!=null">

and id=#{id}

</if>

<if test="name!=null">

and name=#{name}

</if>

<if test="age!=null">

and age=#{age}

</if>

<if test="phone!=null">

and phone=#{phone}

</if>

</where>

</sql>



<select id="queryList" resultMap="BaseResultMap" parameterType="com.niugang.entity.User">

select

<include refid="Base_Column_List" />

from user

<include refid="queryCondition" />

</select>



<insert id="save" parameterType="com.niugang.entity.User">

insert into user (name,password,age,phone)

values(#{name},#{password},#{age},#{phone})

</insert>



<delete id="delete" parameterType="int">

delete from user where id =#{id}

</delete>



<select id="get" parameterType="int" resultMap="BaseResultMap">

select

<include refid="Base_Column_List" />

from user

where id =#{id}

</select>



</mapper>

 

技术图片

8.dao层

package com.niugang.dao;

import java.util.List;

import org.springframework.stereotype.Repository;

import com.niugang.entity.User;

@Repository

public interface UserDao {

List<User> queryList(User user);

User get(Integer id);

void save(User user);

void delete(Integer id);

}

 

技术图片

9.service层

package com.niugang.service;

import java.util.List;

import javax.annotation.Resource;

import org.slf4j.Logger;

import org.slf4j.LoggerFactory;

import org.springframework.stereotype.Service;

import com.niugang.dao.UserDao;

import com.niugang.entity.User;

@Service

public class UserService {



private static Logger logger = LoggerFactory.getLogger(UserService.class);

@Resource

private UserDao userDao;

public List<User> queryList(User user) {

logger.info("访问queryList方法");

return userDao.queryList(user);

}

public void save(User user) {

logger.info("访问save方法");

userDao.save(user);

}

public User get(Integer id) {

logger.info("访问get方法");

return userDao.get(id);

}

public void delete(Integer id) {

logger.info("访问delete方法");

userDao.delete(id);

}

}

 

技术图片

10.controller层

package com.niugang.controller;

import java.util.List;

import javax.annotation.Resource;

import org.apache.commons.lang3.StringUtils;

import org.springframework.stereotype.Controller;

import org.springframework.ui.ModelMap;

import org.springframework.web.bind.annotation.PathVariable;

import org.springframework.web.bind.annotation.RequestMapping;

import org.springframework.web.bind.annotation.RequestMethod;

import com.niugang.entity.User;

import com.niugang.service.UserService;

@Controller

public class IndexController {

@Resource

private UserService userService;

/**

* 跳转到登录页面

*

* @param map

* @return

*/

@RequestMapping(value = "/login", method = RequestMethod.GET)

public String toLogin(ModelMap map) {

return "login";

}



/**

* 登录信息校验

*

* @param map

* @return

*/

@RequestMapping(value = "/login", method = RequestMethod.POST)

public String login(ModelMap map, String name,String password) {



if (StringUtils.isNotBlank(name)&& !name.equals("admin") && StringUtils.isNotBlank(password)

&& !password.equals("123456")) {

map.put("errorMessage", "用户名或密码错误");

return "login";

}



return "redirect:index";

}

/**

* 跳转到index页面

*

* @return

*/

@RequestMapping(value = "/index")

public String index(ModelMap map) {

List<User> list = userService.queryList(null);

map.put("users", list);

return "index";

}

/**

* 详情页面

* @param id

* @param map

* @return

*/

@RequestMapping(value = "/detail/{id}")

public String detail(@PathVariable(value="id") Integer id,ModelMap map){

User user = userService.get(id);

map.put("user", user);

return "detail";

}

/**

* 删除

* @param id

* @return

*/

@RequestMapping(value = "/delete/{id}")

public String delete(@PathVariable(value="id") Integer id){

userService.delete(id);

return "redirect:/index";

}

/**

* 跳转到添加页面

* @param map

* @return

*/

@RequestMapping(value = "/save",method = RequestMethod.GET)

public String toSave(ModelMap map) {

return "add";

}

/**

* 保存添加信息

* @param user

* @return

*/

@RequestMapping(value = "/save",method = RequestMethod.POST)

public String save(User user,ModelMap map){

if(StringUtils.isBlank(user.getName())){

map.put("error", "用户名不能为空");

return "add";

}

if(user.getAge()==null){

map.put("error", "非法年龄");

return "add";

}

if(StringUtils.isBlank(user.getPhone())){

map.put("error", "手机号不能为空");

return "add";

}

user.setPassword("123456");

userService.save(user);

return "redirect:/index";

}

 


}
技术图片

11.view文件夹中的html文件

login.html

<!DOCTYPE html>

<html>

<head>

<meta charset="UTF-8">

<title>Insert title here</title>

</head>

<body>

<h2>spring boot</h2>

<#if errorMessage??>

${errorMessage}

</#if>

<form action="login" method=‘post‘>

用户名:<input type="text" name="name"><p>

密码:<input type="password" name="password"><p>

<input type="submit" value="提交">

</form>

</body>

</html>

 

技术图片

index.html

<!DOCTYPE html>

<html>

<head>

<meta charset="UTF-8">

<title>Insert title here</title>

<style type="text/css">

table {

border-collapse: collapse;

margin: 0 auto;

}



table, td, th {

border: 1px solid black;

padding: 15px;

}

</style>

</head>

<body>

<input type="button" value="添加" onclick="add();">

<table>

<thead>

<tr>

<th>用户名</th>

<th>年龄</th>

<th>电话</th>

<th>操作</th>

</tr>



</thead>

<tbody>

<#if users??> <#list users as user>

<tr>

<td>${user.name}</td>

<td>${user.age}</td>

<td>${user.phone}</td>

<td><a href="javascript:void(0)" onclick="edit(‘${user.id}‘)" >编辑</a>

<a href="javascript:void(0)" onclick="del(‘${user.id}‘)">删除</a>

<a href="javascript:void(0)" onclick="detail(‘${user.id}‘)">详情</a>

</td>

</tr>

</#list> </#if>



</tbody>

</table>

<script type="text/javascript">

function edit(id){

alert(id);

}

function del(id){

var flag=confirm("你确定要删除此选项吗");

if(flag==true){

window.location.href="delete/"+id;

}

}

function detail(id){

window.location.href="detail/"+id;

}

function add(){

window.location.href="save";

}



</script>

</body>

</html>

 

技术图片

add.html

<!DOCTYPE html>

<html lang="en">

<head>

<meta charset="UTF-8">

<title>Document</title>

</head>

<body>

<h2>添加</h2>

<#if error??>

${error}

</#if>

<form action="save" method=‘post‘>

用户名:<input type="text" name="name"><p>

年龄:<input type="text" name="age"><p>

手机号:<input type="text" name="phone"><p>

<input type="submit" value="提交">

</form>

</body>

</html>

 

技术图片

detail.html

<!DOCTYPE html>

<html lang="en">

<head>

<meta charset="UTF-8">

<title>Document</title>

</head>

<body>

<h2>详情页面</h2>

用户名:<input type="text" readonly value="${user.name!‘‘}">

年龄:<input type="text" readonly value="${user.age!‘‘}">

电话:<input type="text" readonly value="${user.phone!‘‘}">

</body>

</html>

 

技术图片

页面显示效果如:http://blog.csdn.net/niugang0920/article/details/79445700

                                                                       微信公众号: 

                                               技术图片技术图片?

                                                                             JAVA程序猿成长之路

                          分享资源,记录程序猿成长点滴。专注于Java,Spring,SpringBoot,SpringCloud,分布式,微服务。 

javaweb知识汇总目录

JavaWeb知识汇总目录JavaWeb之Java基础知识增强JavaWeb之JDBCJavaWeb之数据库连接池JavaWeb之HTML&CSSJavaWeb之JavaScriptJavaWeb之BootstrapJavaWeb之XMLJavaWeb之web服务器软件JavaWeb之ServletJavaWeb之http协议JavaWeb之会话技术JavaWeb之JSP&MVC&EL&JSTLJav... 查看详情

javaweb之ajax&json(代码片段)

知识回顾:JavaWeb之Java基础知识增强JavaWeb之JDBCJavaWeb之数据库连接池JavaWeb之HTML&CSSJavaWeb之JavaScriptJavaWeb之BootstrapJavaWeb之XMLJavaWeb之web服务器软件JavaWeb之ServletJavaWeb之http协议JavaWeb之会话技术JavaWeb之JSP&MVC&a 查看详情

天地之始,万物之母

道可道,非常道。名可名,非常名。无,名天地之始,有,名天地之母。故常无,欲以观其妙,常有,予以观其徼。此两者,同出而异名,同谓之玄。玄之又玄,众妙之门。  查看详情

博客目录

博客目录python基础python基础之文件读写python基础之编码问题python基础之dict、set及字符python基础之循环结构以及列表python基础python高级python高级之面向对象高级python高级之面向对象初级python高级之函数算法算法之使用递归求解迷... 查看详情

javaweb知识汇总目录

JavaWeb知识汇总目录JavaWeb之Java基础知识增强JavaWeb之JDBCJavaWeb之数据库连接池JavaWeb之HTML&CSSJavaWeb之JavaScriptJavaWeb之BootstrapJavaWeb之XMLJavaWeb之web服务器软件JavaWeb之ServletJavaWeb之http协议JavaWeb之会话技术JavaWeb之JSP&MVC& 查看详情

图解系列之垃圾收集之分代回收算法

查看详情

layaair之小游戏的坑之解决之道

版本:LayaAir2.0.0bate4一:MiniAdpter.init目前直接在代码里设会报错,那只有在底层laya.wxmini.js里面设置了Ⅰ,主域:MiniAdpter.init(true,false);Ⅱ,开放域(子域):MiniAdpter.init(true,true);①,如果不设置为出现什么情况:二:不要大惊小怪①,子域只支持使... 查看详情

总索引

...建,关于环境搭建还请参考其他资料。1、走向云计算之Hadoop基本介绍及生态系统2、走向云计算之HDFS详解3、走向云计算之HadoopYARN的基本原理和运行流程4、走向云计算之MapReduce原理和运行流程详解5、走向云计算之MapReduce应用... 查看详情

stl六大组件之算法(代码片段)

文章目录56、STL六大组件之遍历算法57、STL六大组件之查找算法158、STL六大组件之查找算法259、STL六大组件之统计算法60、STL六大组件之合并算法61、随机数(rand)和随机数种子(srand)的理解62、STL六大组件之随机... 查看详情

己亥年(2019年)忆往昔表

?????年关将至,望垂暮落日之余晖,欲捶胸顿足之仰天长叹,若卿欲问何故,吾曰:而立之年,唯有鸿鹄之志,郁郁不得志。三十之末,未立业亦未成家,此为众人普遍之现象,焦虑之心亦为而立年之心态,固书己亥年之忆往昔... 查看详情

oracle之3单行函数之条件表达式

单行函数之条件表达式Case表达式:例如:也可以在条件判断的when中写表达式Decode函数:例如:  查看详情

poi之excel下载之详细设置

1、设置标题格式/** *HEAD样式 * *@paramworkbook *@paramsheet */ publicvoidsetHeadCellStyles(HSSFWorkbookworkbook,HSSFSheetsheet){ headStyle=workbook.createCellStyle(); headStyle.setAlignment(HSSFCellStyle.ALI 查看详情

文本主题模型之ldalda求解之变分推断em算法

       文本主题模型之LDA(一)LDA基础    文本主题模型之LDA(二)LDA求解之Gibbs采样算法    文本主题模型之LDA(三)LDA求解之变分推断EM算法    本文是LDA主题模型的第三篇,读这一篇之前建议... 查看详情

redux源码分析之compose

 Redux源码分析之基本概念 Redux源码分析之createStore Redux源码分析之bindActionCreators Redux源码分析之combineReducers Redux源码分析之compose   解读之前先了准备一下基本知识rest参数  形式为...变量名,用于... 查看详情

数据结构之队列(代码片段)

...样实现队列3.项目搭建4.定义队列5.队列的所有操作5.1队列之初始化5.2队列之判空5.3队列之入队5.4队列之出队5.5队列之获取队首5.6队列之获取队尾5.7队列之返回队列元素数量5.8队列之销毁空间总代码前言陆陆续续的,我们已经学完... 查看详情

数据结构之顺序表(代码片段)

文章目录前言顺序表项目详细分配.定义顺序表顺序表之初始化方法实现顺序表之打印方法顺序表之尾插方法实现顺序表之检查容量方法实现顺序表之头插方法实现顺序表之尾删方法实现顺序表之头删方法实现顺序表之查找元素... 查看详情

golang学习之路

Golang基础Golang基础之包概念Golang基础之数据类型Golang基础之流程控制Golang基础之数组Golang基础之切片Golang基础之mapGolang基础之函数Golang基础之指针Golang基础之结构体Golang基础之接口GolangWeb开发Golang其它算法 查看详情

mongodb系列之学习笔记教程汇总

1、什么是MongoDB?MongoDB系列之SQL和NoSQL的区别MongoDB系列之什么是非关系型数据库MongoDB系列之MongoDB基本概念MongoDB系列之适用场景和不适用场景2、MongoDB环境搭建MongoDB系列之Window环境部署配置MongoDB系列之Linux环境部署配置3、Mon... 查看详情