[golang gin框架] 25.Gin 商城项目-配置清除缓存以及前台列表页面数据渲染公共数据

  1. 配置清除缓存

当进入前台首页时,会缓存对应的商品相关数据,这时,如果后台修改了商品的相关数据,缓存中的对应数据并没有随之发生改变,这时就需要需改对应的缓存数据,这里有两种方法:

方法一

在管理后台操作直接清除缓存中的所有数据,当再次访问前台首页时,就会先从数据库中获取数据,然后缓存到redis中,代码如下:

(1).界面

点击 清除缓存 按钮,直接清除缓存驱动中的所有数据

(2).增加 清除缓存 按钮

在templates/admin/main/index.html页面,增加 清除缓存 按钮
<ul class="nav navbar-nav navbar-right">
    <li><a>欢迎您,{{.username}}</a>
    </li>
    <li><a href="/admin/flushAll">清除缓存</a>
    <li><a href="/admin/loginOut">安全退出</a>
    </li>
</ul>

(3).增加路由

在routers/admin/adminRouter.go中增加 清除缓存 路由
adminRouters.GET("/flushAll", admin.MainController{}.FlushAll)

(4).增加清除缓存方法

在controllers/admin/MainController.go中增加清除缓存的方法
//清除缓存
func (con MainController) FlushAll(c *gin.Context)  {
    models.RedisCache.FlushAll()
    con.Success(c, "清除缓存成功", "/admin")
}
在models /redisCache.go中增加清除缓存方法
//清除缓存
func (r RedisCache) FlushAll() {
    if redisEnable {
        RedisDb.FlushAll(ctxRedis)
    }
}

方法二

在管理后台修改商品相关数据时,就去修改对应的缓存数据,代码:略

2.分类页面数据展示

当从首页点击 商品分类,进入商品分类的 商品展示页面时,会存在和首页共同的 公共数据顶部导航、中间导航、左侧分类),那么就可以把公共的代码分离出来,放到 基础控制器(BaseController.go)中,实现 代码的复用;
在商品分类的商品展示页面 展示分类的对应商品,以及 筛选对应分类的商品,和对商品进行 分页操作

1).界面

首页界面
商品分类对应的商品页面: 该页面和首页都有共同的 公共数据顶部导航、中间导航、左侧分类
商品列表

2).代码展示

(1).html

拆分publibc/page_header.html,把中部导航代码单独成一个文件middle_nav.html
index.html中增加 中部导航 代码
创建product/list.html商品页面文件

page_header.html

拆分publibc/page_header.html,把中部导航代码单独成一个文件middle_nav.html
<!-- 相当于给模板定义一个名字, define end 必须成对出现 -->
{{ define "frontend/public/page_header.html" }}
    <!DOCTYPE html>
    <html>
    <head>
        <meta charset="UTF-8">
        <meta name="author" content="order by dede58.com"/>
        <title>小米商城</title>
        <link rel="stylesheet" type="text/css" href="/static/frontend/css/style.css">
        <link rel="stylesheet" href="/static/frontend/css/swiper.min.css">

        <script src="/static/frontend/js/jquery-1.10.1.js"></script>
        <script src="/static/frontend/js/swiper.min.js"></script>
        <script src="/static/frontend/js/base.js"> </script>

    </head>
    <body>
    <!-- start header 顶部导航 -->
    <header>
        <div class="top center">
            <div class="left fl">
                <ul>
                    <!--获取长度,并计算,看看是否显示最后的 | 画线-->
                    {{ $temp := .topNavList | len }}
                    {{ $navLen := Sub  $temp 1 }}
                    {{range $key, $value := .topNavList}}
                    <li><a href="{{$value.Link}}"{{if eq $value.IsOpennew 1 }} target="_blank" {{end}} >{{$value.Title}}</a></li>
                    {{if lt $key $navLen}}
                    <li>|</li>
                    {{end}}
                    {{end}}
                    <div class="clear"></div>
                </ul>
            </div>
            <div class="right fr">
                <div class="gouwuche fr"><a href="">购物车</a></div>
                <div class="fr">
                    <ul>
                        <li><a href="./login.html" target="_blank">登录</a></li>
                        <li>|</li>
                        <li><a href="./register.html" target="_blank" >注册</a></li>
                        <li>|</li>
                        <li><a href="">消息通知</a></li>
                    </ul>
                </div>
                <div class="clear"></div>
            </div>
            <div class="clear"></div>
        </div>
    </header>
    <!--end header -->
{{end}}

list.html

创建product/list.html商品页面文件
{{ define "frontend/public/middle_nav.html" }}
    <!-- 中间导航start banner_x -->
    <div class="banner_x center">
        <a href="/" target="_blank">
            <div class="logo fl"></div>
        </a>

        <div class="nav fl">
            <ul class="clearfix" id="nav_list">
                <li class="link-category">
                    <a href="#">全部商品分类</a>
                    <div class="banner_y center">
                        <div class="nav">
                            <ul>
                                {{range $key,$value := .goodsCateList}}
                                    <li>
                                        <!--判断点击分类是否跳转到一个新的链接,如果不是,则跳转到对应的分类商品页面-->
                                        {{if eq $value.Link ""}}
                                            <a href="category{{$value.Id}}" target="_blank">{{$value.Title}}</a>
                                        {{else}}
                                            <a href="{{$value.Link}}" target="_blank">{{$value.Title}}</a>
                                        {{end}}

                                        <div class="pop">
                                            <ol class="cate_list clear">

                                                {{range $k,$v := $value.GoodsCateItems}}
                                                    <li>
                                                        <div class="xuangou_left">
                                                            {{if eq $v.Link ""}}
                                                                <a href="category{{$v.Id}}" target="_blank"
                                                                   class="clearfix">
                                                                    <div class="img fl"><img
                                                                                src="{{$v.CateImg | FormatImg}}"
                                                                                alt="{{$v.Title}}"></div>
                                                                    <span class="fl">{{$v.Title}}</span>
                                                                </a>
                                                            {{else}}
                                                                <a href="{{$v.Link}}" target="_blank" class="clearfix">
                                                                    <div class="img fl"><img
                                                                                src="{{$v.CateImg | FormatImg}}"
                                                                                alt="{{$v.Title}}"></div>
                                                                    <span class="fl">{{$v.Title}}</span>
                                                                </a>
                                                            {{end}}
                                                        </div>
                                                    </li>

                                                {{end}}
                                            </ol>
                                        </div>
                                    </li>
                                {{end}}
                            </ul>
                        </div>
                    </div>
                </li>
                {{range $key,$value := .middleNavList}}
                    <li>
                        <a href="#" target="_blank">{{$value.Title}}</a>
                        <ol class="children-list clearfix">
                            {{range $k,$v := $value.GoodsItems}}
                                <li>
                                    <a href="#">
                                        <img src="{{$v.GoodsImg | FormatImg}}" alt="{{$v.Title}}"/>
                                        <p>{{$v.Price}}元</p>
                                    </a>
                                </li>
                            {{end}}
                        </ol>

                    </li>
                {{end}}

            </ul>
        </div>
        <div class="search fr">
            <form action="" method="post">
                <div class="text fl">
                    <input type="text" class="shuru" placeholder="6&nbsp;MIX现货">
                </div>
                <div class="submit fl">
                    <input type="submit" class="sousuo" value="搜索"/>
                </div>
                <div class="clear"></div>
            </form>
            <div class="clear"></div>
        </div>
    </div>
    <!-- end banner_x -->
{{end}}

index.html

商品首页增加 中部导航 代码, 因为page_header.html中的中部导航代码没有了,已经封装成middle_nav.html代码了,而首页的商品分类和商品页面的商品分类还有点区别,故不会导入public/middle_nav.html中的代码,所以会直接增加 中部导航 代码
{{ define "frontend/index/index.html" }}
    {{template "frontend/public/page_header.html" .}}
    <!-- start banner_x 中部导航 -->
    <div class="banner_x center">
        <a href="./index.html" target="_blank"><div class="logo fl"></div></a>
        <a href=""><div class="ad_top fl"></div></a>
        <div class="nav fl">
            <ul class="clearfix" id="nav_list">
                {{range $key, $value := .middleNavList }}
                    <li>
                        <a href="{{$value.Link}}" target="_blank">{{$value.Title}}</a>

                        <ol class="children-list clearfix">
                            {{range $k, $v := $value.GoodsItems }}
                                <li>
                                    <a href="#">
                                        <img src="{{$v.GoodsImg | FormatImg }}" />
                                        <p>{{$v.Price}}</p>
                                    </a>
                                </li>
                            {{end}}
                        </ol>
                    </li>
                {{end}}
            </ul>
        </div>
        <div class="search fr">
            <form action="" method="post">
                <div class="text fl">
                    <input type="text" class="shuru"  placeholder="小米6&nbsp;小米MIX现货">
                </div>
                <div class="submit fl">
                    <input type="submit" class="sousuo" value="搜索"/>
                </div>
                <div class="clear"></div>
            </form>
            <div class="clear"></div>
        </div>
    </div>
    <!-- end banner_x -->

    <!-- 商品分类 start banner_y -->
        <div class="banner_y center">
            <div class="nav">
                <ul>
                    {{range $key, $value := .goodsCateList }}
                    <li>
                        {{if eq $value.Link ""}}
                            <a href="category{{$value.Id}}" target="_blank">{{$value.Title}}</a>
                        {{else}}
                            <a href="{{$value.Link}}" target="_blank">{{$value.Title}}</a>
                        {{end}}
                        <div class="pop">
                            <ol class="cate_list clear">
                                {{range $k, $v := $value.GoodsCateItems}}
                                    <li>
                                        <div class="xuangou_left">
                                            {{if eq $v.Link ""}}
                                                <a href="category{{$v.Id}}" target="_blank"
                                                   class="clearfix">
                                                    <div class="img fl"><img
                                                                src="{{$v.CateImg | FormatImg}}"
                                                                alt="{{$v.Title}}"></div>
                                                    <span class="fl">{{$v.Title}}</span>
                                                </a>
                                            {{else}}
                                                <a href="{{$v.Link}}" target="_blank" class="clearfix">
                                                    <div class="img fl"><img
                                                                src="{{$v.CateImg | FormatImg}}"
                                                                alt="{{$v.Title}}"></div>
                                                    <span class="fl">{{$v.Title}}</span>
                                                </a>
                                            {{end}}
                                        </div>
                                    </li>
                                {{end}}
                            </ol>
                        </div>
                    </li>
                    {{end}}
                </ul>
            </div>
            <!--轮播图-->
              <div class="swiper-container">
                <div class="swiper-wrapper">
                    {{range $key, $value := .focusList}}
                      <div class="swiper-slide">
                          <a href="{{$value.Link}}" target="_blank">
                            <img src="{{$value.FocusImg | FormatImg}}" alt="{{$value.Title}}" />
                          </a>
                      </div>
                    {{end}}
                </div>
                <!-- Add Arrows -->
                <div class="swiper-button-next"></div>
                <div class="swiper-button-prev"></div>
              </div>
        
        </div>    
        <!-- 商品分类end -->

        <div class="sub_banner center">
            <div class="sidebar fl">
                <div class="fl"><a href=""><img src="/static/frontend/image/hjh_01.gif"></a></div>
                <div class="fl"><a href=""><img src="/static/frontend/image/hjh_02.gif"></a></div>
                <div class="fl"><a href=""><img src="/static/frontend/image/hjh_03.gif"></a></div>
                <div class="fl"><a href=""><img src="/static/frontend/image/hjh_04.gif"></a></div>
                <div class="fl"><a href=""><img src="/static/frontend/image/hjh_05.gif"></a></div>
                <div class="fl"><a href=""><img src="/static/frontend/image/hjh_06.gif"></a></div>
                <div class="clear"></div>
            </div>
            <div class="datu fl"><a href=""><img src="/static/frontend/image/hongmi4x.png" alt=""></a></div>
            <div class="datu fl"><a href=""><img src="/static/frontend/image/xiaomi5.jpg" alt=""></a></div>
            <div class="datu fr"><a href=""><img src="/static/frontend/image/pinghengche.jpg" alt=""></a></div>
            <div class="clear"></div>


        </div>
    <!-- end banner -->
    <!-- 手机 -->
    <div class="category_item w">
        <div class="title center">手机</div>
        <div class="main center">
            <div class="category_item_left">
                <img src="static/itying/image/shouji.jpg" alt="手机">
            </div>
            <div class="category_item_right">
                {{range $key,$value := .phoneList}}
                    <div class="hot fl">
                        <div class="xinpin"><span style="background:#fff"></span></div>
                        <div class="tu"><a href="#"><img src="{{$value.GoodsImg | FormatImg}}"></a></div>
                        <div class="miaoshu"><a href="#">{{$value.Title}}</a></div>
                        <div class="jiage">{{$value.Price}}元</div>
                        <div class="pingjia">372人评价</div>
                        <div class="piao">
                            <a href="">
                                <span>{{SubStr $value.SubTitle 0 4}}</span>
                            </a>
                        </div>
                    </div>
                {{end}}
            </div>
        </div>
    </div>
    {{template "frontend/public/page_footer.html" .}}
    </body>
</html>
{{end}}

(2).增加商品分类页面路由

defaultRouters.GET("/category:id", frontend.ProductController{}.Category)

(3).基础控制器

在基础控制器BaseController.go中创建公共方法: 加载公共模板方法Render()
package frontend

//基础控制器

import (
    "github.com/gin-gonic/gin"
    "gorm.io/gorm"
    "goshop/models"
    "net/http"
    "strings"
)

type BaseController struct{}

/*
加载公共模板方法
tpl string 模板
data map 请求的数据
 */
func (con BaseController) Render(c *gin.Context, tpl string, data map[string]interface{}) {
    //实例化redisCache结构体
    redisCache := models.RedisCache{}

    //获取顶部导航列表
    topNavList := []models.Nav{}
    //判断redis中是否存在数据
    if hasTopNavList := redisCache.Get("topNavList", &topNavList); !hasTopNavList {  //不存在数据,则从数据中获取数据,并把数据保存到redis
        models.DB.Where("status = 1 AND position = 1").Find(&topNavList)
        redisCache.Set("topNavList", topNavList, 3600)
    }
    //获取分类数据
    goodsCateList := []models.GoodsCate{}
    if hasGoodsCateList := redisCache.Get("goodsCateList", &goodsCateList); !hasGoodsCateList {
        //获取分类列表以及下级分类,并进行排序
        models.DB.Where("pid = ? AND status = ?", 0, 1).Order("sort DESC").Preload("GoodsCateItems", func(db *gorm.DB) *gorm.DB {
            return db.Where("goods_cate.status = 1").Order("goods_cate.sort DESC")
        } ).Find(&goodsCateList)
        redisCache.Set("goodsCateList", goodsCateList, 3600)
    }

    //获取中间导航
    middleNavList := []models.Nav{}
    if hasMiddleNavList := redisCache.Get("middleNavList", &middleNavList); !hasMiddleNavList {
        models.DB.Where("status = ? AND position = ? ", 1, 2).Find(&middleNavList)
        //循环,获取中间导航对应的商品数据
        for i:= 0; i < len(middleNavList);i++{
            //获取管理商品
            //替换字符串中的中文逗号strings.ReplaceAll()
            relation := strings.ReplaceAll(middleNavList[i].Relation, ",", ",")
            //把字符串转换成切片
            relationIds := strings.Split(relation, ",")
            //获取对应的商品信息
            goodsList := []models.Goods{}
            models.DB.Where("status = ?", 1).Where("id in ?", relationIds).Select("id, title, goods_img, price").Find(&goodsList)
            middleNavList[i].GoodsItems = goodsList
        }
        redisCache.Set("middleNavList", middleNavList, 3600)
    }

    renderData := gin.H{
        "topNavList":    topNavList,
        "goodsCateList": goodsCateList,
        "middleNavList": middleNavList,
    }

    for key, v := range data {
        renderData[key] = v
    }

    c.HTML(http.StatusOK, tpl, renderData)
}

(4).商品控制器

创建ProductController.go控制器,该控制器与商品相关
package frontend

//商品相关

import (
    "github.com/gin-gonic/gin"
    "goshop/models"
    "math"
)

type ProductController struct {
    //extend 基础控制器
    BaseController
}

// 根据商品分类获取分类下面的所有商品数据
func (con ProductController) Category(c *gin.Context) {
    //获取分类id
    cateId, _  := models.Int(c.Param("id"))
    //当前页
    page, _ := models.Int(c.Query("page"))
    if page == 0 {
        page = 1
    }
    //每一页显示的数量
    pageSize := 2

    //获取当前分类
    curCate := models.GoodsCate{}
    models.DB.Where("id = ? ", cateId).Find(&curCate)

    //判断当前分类是否顶级分类,如果是,则获取对应的二级分类,如果不是,则获取对应的兄弟分类
    subCate := []models.GoodsCate{}
    var tempSlice []int
    if curCate.Pid == 0 {  // 当前分类是顶级分类,获取对应的二级分类
        models.DB.Where("pid = ?", cateId).Find(&subCate)
        //把二级分类id放到切片中
        for i := 0; i < len(subCate); i++ {
            tempSlice = append(tempSlice, subCate[i].Id)
        }
    } else { // 当前分类是二级分类,获取对应的兄弟分类
        models.DB.Where("pid = ?", curCate.Pid).Find(&subCate)
    }
    //把请求的分类id放入切片
    tempSlice = append(tempSlice, cateId)
    //通过上面的分类id,获取商品相关数据
    goodsList := []models.Goods{}
    where := "cate_id in ?"
    models.DB.Where(where, tempSlice).Where("status = ?", 1).Offset((page - 1) * pageSize).Limit(pageSize).Find(&goodsList)

    //获取总数量
    var count int64
    models.DB.Where(where, tempSlice).Table("goods").Count(&count)

    //定义请求的模板
    tpl := "frontend/product/list.html"
    con.Render(c, tpl, gin.H{
        "goodsList": goodsList,  // 商品列表
        "subCate": subCate, // 选择分类下面的子分类
        "currentCate": curCate,  // 当前分类
        "page": page, //当前页码数
        "totalPages":  math.Ceil(float64(count) / float64(pageSize)), // 总页面数
    })
}

[上一节][golang gin框架] 24.Gin 商城项目-redis讲解以及操作

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/13701.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

记frp内网穿透配置

这两天由于想给客户看一下我们的系统&#xff0c;于是想到用内网穿透&#xff0c;但是怎么办呢&#xff0c;没有用过呀&#xff0c;于是各处找资料&#xff0c;但是搞完以后已经不记得参考了那些文档了&#xff0c;对不起各位大神&#xff0c;就只能写出过程和要被自己蠢死的错…

初识C++(二)

在初识c&#xff08;一&#xff09;当中我们已经向大家介绍了四个c和C语言不同的使用方法。接下来我们再来向大家介绍另外的一些新的c语言的使用方法。 &#x1f335;引用 简单一点来说引用就是给已存在的变量起一个别名。这个别名通常的作用和C语言当中的指针类似。我们可以通…

牛客网刷题总结

1.利用%符号获取特定位数的数字。 2.强制类型转换 &#xff08;将float转换为int &#xff09; 3.计算有关浮点型数据时&#xff0c;要注意你计算过程中所有的数据都是浮点型 4.0/3.0 ! 4/3 4.通过位操作符实现输出2的倍数&#xff08;对于位操作符不熟悉的小伙伴可以看看我…

基于Java+SpringBoot+vue实现图书借阅和销售商城一体化系统

基于JavaSpringBootvue实现图书借阅和销售商城一体化系统 博主介绍&#xff1a;5年java开发经验&#xff0c;专注Java开发、定制、远程、指导等,csdn特邀作者、专注于Java技术领域 作者主页 超级帅帅吴 Java项目精品实战案例《500套》 欢迎点赞 收藏 ⭐留言 文末获取源码联系方…

电脑系统错误怎么办?您可以看看这5个方法!

案例&#xff1a;电脑出现系统错误该如何解决&#xff1f; 【这几天长时间使用我的电脑&#xff0c;导致它的系统出现了错误。有没有小伙伴知道如何解决电脑系统出错的问题&#xff1f;求一个能快速解决的方法。】 电脑系统出现错误是使用电脑时难免会遇到的问题之一&#xf…

【C++初阶】C++入门(二):引用内联函数auto关键字范围for循环(C++11)指针空值nullptr

​ ​&#x1f4dd;个人主页&#xff1a;Sherry的成长之路 &#x1f3e0;学习社区&#xff1a;Sherry的成长之路&#xff08;个人社区&#xff09; &#x1f4d6;专栏链接&#xff1a;C初阶 &#x1f3af;长路漫漫浩浩&#xff0c;万事皆有期待 上一篇博客&#xff1a;【C初阶】…

MySQL数据库学习笔记之存储引擎

存储引擎 MySQL体系结构 连接层 最上层是一些客户端和连接服务&#xff0c;主要完成一些类似于连接处理、授权认证、以及相关的安全方案。服务器也会为安全接入的每个客户端验证它所具有的操作权限。 服务层 第二层架构主要完成大多数的核心服务功能&#xff0c;如SQL接口&am…

【Linux网络】部署YUM仓库及NFS服务

部署YUM仓库及NSF服务 一、YUM仓库1.1、YUM仓库概述1.2准备安装来源1.3在软件仓库加载非官方RPM包组1.4yum与apt 二、配置yam源与制作索引表2.1配置FTP源2.2配置国内在线yum源2.3在线源与本地源同时使用2.4建立软件包索引关系表的三种方法 三、nfs共享存储服务3.1安装软件&…

OpenAI-ChatGPT最新官方接口《微调ChatGPT模型》全网最详细中英文实用指南和教程,助你零基础快速轻松掌握全新技术(四)(附源码)

微调ChatGPT模型 前言Introduction 导言What models can be fine-tuned? 哪些模型可以微调&#xff1f;Installation 安装Prepare training data 准备训练数据CLI data preparation tool CLI数据准备工具Create a fine-tuned model 创建微调模型Use a fine-tuned model 使用微…

Windows下版本控制器(SVN) - 1、开发中的实际问题+2、版本控制简介

文章目录 基础知识-Windows下版本控制器(SVN)1、开发中的实际问题2、版本控制简介2.1 版本控制[Revision control]2.2 Subversion2.3 Subversion 的优良特性2.4 SVN 的工作原理&#xff1a;2.5 SVN 基本操作 本人其他相关文章链接 基础知识-Windows下版本控制器(SVN) 1、开发中…

docker容器:docker镜像的三种创建方法及dockerfile案例

目录 一、基于现有镜像创建 1、创建启动镜像 2、生成新镜像 二、基于本地模板创建 1、OPENVZ 下载模板 2、导入容器生成镜像 三、基于dockerfile创建 1、dockerfile结构及分层 2、联合文件系统 3、docker镜像加载原理 4、dockerfile操作常用的指令 (1)FROM指令 (…

倾斜摄影三维模型格式转换OSGB 到3Dtitles 实现的常用技术方法

倾斜摄影三维模型格式转换OSGB 到3Dtitles 实现的常用技术方法 倾斜摄影三维模型是一种用于建立真实世界三维场景的技术&#xff0c;常用于城市规划、土地管理、文化遗产保护等领域。在倾斜摄影模型中&#xff0c;OSGB格式和3Dtiles格式都是常见的数据格式。其中&#xff0c;OS…

ChatGPT 速通手册——连续提问和重新生成的作用

连续提问和重新生成的作用 和 ChatGPT 聊天&#xff0c;也是有套路的。我们把给 ChatGPT 输入的问题文本&#xff0c;叫 Prompt&#xff0c;提示词。实际上&#xff0c;传统搜索引擎也有比较相类似的功能。 在 Prompt Learning 提示学习之后&#xff0c;又总结出一种更好的聊…

如何高效提高倾斜摄影三维模型顶层合并的技术方法分析

如何高效提高倾斜摄影三维模型顶层合并的技术方法分析 1、倾斜摄影三维模型顶层合并 1.1倾斜摄影三维模型是一种基于倾斜摄影技术&#xff0c;通过多个角度拍摄同一区域的影像&#xff0c;利用计算机图像处理和三维重建技术生成的三维地理信息数据。由于一个大区域可能需要多块…

13-nginx

一 初始Nginx 1 Nginx概述 Nginx是一款轻量级的Web服务器、反向代理服务器&#xff0c;由于它的内存占用少&#xff0c;启动极快&#xff0c;高并发能力强&#xff0c;在互联网项目中广泛应用。Nginx 专为性能优化而开发&#xff0c;使用异步非阻塞事件驱动模型。 常见服务器 …

57 openEuler搭建Mariadb数据库服务器-管理数据库用户

文章目录 57 openEuler搭建Mariadb数据库服务器-管理数据库用户57.1 创建用户57.2 查看用户57.3 修改用户57.3.1 修改用户名57.3.2 修改用户示例57.3.3 修改用户密码57.3.4 修改用户密码示例 57.4 删除用户57.5 用户授权57.6 删除用户权限 57 openEuler搭建Mariadb数据库服务器…

(Ubuntu22.04 Jammy)安装ROS2 Humble

文章目录 (Ubuntu22.04 Jammy)安装ROS2 (Humble)版本一、设置本地区域二、设置源三、安装ROS2软件包四、环境设置五、测试用例Talker-listener 六、卸载ros2 (Ubuntu22.04 Jammy)安装ROS2 (Humble)版本 提示&#xff1a;以下内容是已经安装了ubuntu22.04 下进行安装ros2 一、设…

Java语法理论和面经杂疑篇《十二. JDK8 - 17新特性》

第18章_JDK8-17新特性&#xff08;下&#xff09; 6. 新语法结构 新的语法结构&#xff0c;为我们勾勒出了 Java 语法进化的一个趋势&#xff0c;将开发者从复杂、繁琐的低层次抽象中逐渐解放出来&#xff0c;以更高层次、更优雅的抽象&#xff0c;既降低代码量&#xff0c;又…

设计模式-结构型模式之享元模式

5. 享元模式 5.1. 模式动机 面向对象技术可以很好地解决一些灵活性或可扩展性问题&#xff0c;但在很多情况下需要在系统中增加类和对象的个数。当对象数量太多时&#xff0c;将导致运行代价过高&#xff0c;带来性能下降等问题。 享元模式正是为解决这一类问题而诞生的。享元模…

函数栈帧的创建和销毁【汇编语言理解】

&#x1f339;作者:云小逸 &#x1f4dd;个人主页:云小逸的主页 &#x1f4dd;Github:云小逸的Github &#x1f91f;motto:要敢于一个人默默的面对自己&#xff0c;强大自己才是核心。不要等到什么都没有了&#xff0c;才下定决心去做。种一颗树&#xff0c;最好的时间是十年前…
最新文章