GORM---初级查询

news2024/11/22 14:50:50

文章目录

  • 初始数据表
  • 一般查询
  • Where条件
    • 普通SQL查询
    • 查询 Struct & Map
  • Not 条件
  • Or 条件
  • 内联条件
  • 额外查询选项
  • FirstOrInit
    • Attrs
    • Assign
  • FirstOrCreate
    • Attrs
    • Assign

初始数据表

一般查询

var p1, p2, p3, p4 connect.PersonInfo
var ps []connect.PersonInfo

// 把主键升序,获取表的第一条记录
connect.DB.First(&p1)
fmt.Printf("%#v\n", p1)

// 主键不排序,获取表的第一条记录
connect.DB.Take(&p2)
fmt.Printf("%#v\n", p2)

// 把主键降序,获取表的第一条记录
connect.DB.Last(&p3)
fmt.Printf("%#v\n", p3)

// 查询所有的记录
connect.DB.Find(&ps)
fmt.Printf("%#v\n", ps)

// 查询指定的某条记录(仅当主键为整型时可用)
connect.DB.First(&p4, 3)
fmt.Printf("%#v\n", p4)

Where条件

普通SQL查询

var p1 connect.PersonInfo
var ps1, ps2, ps3, ps4, ps5 []connect.PersonInfo

// 查询username为abc的第一个记录
connect.DB.Where("username = ?", "abc").First(&p1)
//SELECT * FROM `person_info` WHERE username = 'abc' ORDER BY `person_info`.`id` LIMIT 1

// 查询username不等于drg的所有记录
connect.DB.Where("username <> ?", "drg").Find(&ps1)
//SELECT * FROM `person_info` WHERE username <> 'drg'

// 查询username为abc或者xyz的所有记录
connect.DB.Where("username IN ?", []string{"abc", "xyz"}).Find(&ps2)
//SELECT * FROM `person_info` WHERE username IN ('abc','xyz')

// 查询username里面有字串"e"的所有记录
connect.DB.Where("username LIKE ?", "%e%").Find(&ps3)
//SELECT * FROM `person_info` WHERE username LIKE '%e%'

// 查询username里面有字串"e"的所有记录 并且 age大于20的记录
connect.DB.Where("username LIKE ? AND age >= ?", "%e%", "20").Find(&ps4)
//SELECT * FROM `person_info` WHERE username LIKE '%e%' AND age >= '20'

// 查询age再19到23之间的记录
connect.DB.Where("age BETWEEN ? AND ?", 19, 23).Find(&ps5)
//SELECT * FROM `person_info` WHERE age BETWEEN 19 AND 23

查询 Struct & Map

var p1 connect.PersonInfo
var ps1, ps2 []connect.PersonInfo

// Struct
connect.DB.Where(&connect.PersonInfo{UserName: "xyz", Age: 22}).First(&p1)
//SELECT * FROM `person_info` WHERE `person_info`.`username` = 'xyz' 
//AND `person_info`.`age` = 22 ORDER BY `person_info`.`id` LIMIT 1
fmt.Printf("%#v\n", p1)

// Map
connect.DB.Where(map[string]interface{}{"username": "edg", "age": 24}).Find(&ps1)
//SELECT * FROM `person_info` WHERE `age` = 24 AND `username` = 'edg'
fmt.Printf("%#v\n", ps1)

// 主键的切片
connect.DB.Where([]int64{4, 5, 6}).Find(&ps2)
//SELECT * FROM `person_info` WHERE `person_info`.`id` IN (4,5,6)
fmt.Printf("%#v\n", ps2)

运行结果如下:

image-20230604194900972

注意: 当通过结构体进行查询时,GORM将会只通过非零值字段查询,这意味着如果你的字段值为0''false或者其他零值时,将不会被用于构建查询条件,例如:

type User struct {
	Id       uint64
	UserName string
	PassWord string 
	Age      int    
}
var u connect.User
connect.DB.Where(&connect.User{UserName: "bing", Age: 0}).Find(&u)

上面代码的Age字段由于为0,会被忽略,导致Age字段不会参与查询,所以底层执行的SQL语句为SELECT * FROM User WHERE name = “bing”;可以使用指针或实现 Scanner/Valuer 接口来避免这个问题。具体步骤详见:GORM—创建-黎明⁢的博客-CSDN,这篇博客的最后有详细的解决步骤。

Not 条件

var p1, p2, p3, p4, p5 connect.PersonInfo
var ps1 []connect.PersonInfo

connect.DB.Not("username", "dyg").First(&p1)
//SELECT * FROM `person_info` WHERE `username` <> 'dyg' ORDER BY `person_info`.`id` LIMIT 1

connect.DB.Not("username", []string{"abc", "xyz", "dyg"}).Find(&ps1)
//SELECT * FROM `person_info` WHERE `username` NOT IN ('abc','xyz','dyg')

connect.DB.Not([]int64{1, 2, 3}).First(&p2)
//SELECT * FROM `person_info` WHERE `person_info`.`id` NOT IN (1,2,3) ORDER BY `person_info`.`id` LIMIT 1

connect.DB.Not([]int64{}).First(&p3)
//SELECT * FROM `person_info` ORDER BY `person_info`.`id` LIMIT 1

connect.DB.Not("username = ?", "tes").First(&p4)
//SELECT * FROM `person_info` WHERE NOT username = 'tes' ORDER BY `person_info`.`id` LIMIT 1

connect.DB.Not(connect.PersonInfo{UserName: "edg"}).First(&p5)
//SELECT * FROM `person_info` WHERE `person_info`.`username` <> 'edg' ORDER BY `person_info`.`id` LIMIT 1

Or 条件

var p1, p2, p3 connect.PersonInfo

connect.DB.Where("age = ?", "23").Or("username = ?", "xyz").Find(&p1)
//SELECT * FROM `person_info` WHERE age = '23' OR username = 'xyz'
fmt.Printf("%#v\n", p1)

connect.DB.Where("username = 'tes'").Or(connect.PersonInfo{UserName: "abc"}).Find(&p2)
//SELECT * FROM `person_info` WHERE username = 'tes' OR `person_info`.`username` = 'abc'
fmt.Printf("%#v\n", p2)

connect.DB.Where("username = 'dyg'").Or(map[string]interface{}{"password": "12345"}).Find(&p3)
//SELECT * FROM `person_info` WHERE username = 'dyg' OR `password` = '12345'
fmt.Printf("%#v\n", p3)

运行结果如下:

image-20230604194434379

内联条件

作用与Where查询类似,当内联条件与多个立即执行方法一起使用时, 内联条件不会传递给后面的立即执行方法。

var p1, p2 connect.PersonInfo
var ps1, ps2, ps3, ps4 []*connect.PersonInfo

// 根据主键获取记录 (只适用于整形主键)
connect.DB.First(&p1, 5)
//SELECT * FROM `person_info` WHERE `person_info`.`id` = 5 ORDER BY `person_info`.`id` LIMIT 1

// 根据主键获取记录, 如果它是一个非整形主键
connect.DB.First(&p2, "id = ?", "string_primary_key")
//SELECT * FROM `person_info` WHERE id = 'string_primary_key' ORDER BY `person_info`.`id` LIMIT 1

connect.DB.Find(&ps1, "username = ?", "xyz")
//SELECT * FROM `person_info` WHERE username = 'xyz'

connect.DB.Find(&ps2, "username <> ? AND age > ?", "abc", 20)
//SELECT * FROM `person_info` WHERE username <> 'abc' AND age > 20

connect.DB.Find(&ps3, connect.PersonInfo{Age: 20})
//SELECT * FROM `person_info` WHERE `person_info`.`age` = 20

connect.DB.Find(&ps4, map[string]interface{}{"age": 20})
//SELECT * FROM `person_info` WHERE `age` = 20

额外查询选项

在SQL查询时添加额外的 SQL 操作。例如在查询的时候,执行加锁、排序、分页等。下面的例子的作用是查询 id 为 10 的用户数据,并对查询结果加锁,防止其他事务修改这些数据。查询结果将存储到变量 p 中。

tx := connect.DB.Begin() //开启事务
defer func() {
    if r := recover(); r != nil {
        tx.Rollback()
    }
}()

var p connect.PersonInfo
connect.DB.Set("gorm:query_option", "FOR UPDATE").First(&p, 6)
//SELECT * FROM `person_info` WHERE `person_info`.`id` = 6 ORDER BY `person_info`.`id` LIMIT 1

tx.Commit() //提交事务

fmt.Printf("%#v\n", p)

运行结果如下:

image-20230604212637094

需要注意的是,FOR UPDATE 选项只在事务中生效,如果没有使用事务,那么这个选项将被忽略。如果要使用事务,可以使用 Begin 方法开启事务,然后在事务中执行查询操作。相应的,如果要执行排序操作可以使用如下写法:

//升序(ASC)		降序(DESC)
connect.DB.Set("gorm:query_option", "ORDER BY age ASC").Find(&p)

在实际开发中,通常需要动态设置排序的一些属性,可以根据具体情况动态构建选项值。例如,可以使用 fmt.Sprintf 函数将排序字段和排序方式作为参数传递给 Set 方法,动态构建排序条件。代码如下:

sortField := "age"
sortOrder := "ASC"
connect.DB.Set("gorm:query_option", fmt.Sprintf("ORDER BY %s %s", sortField, sortOrder)).Find(&p)

那如果要对查询结果进行分页操作呢?写法如下:

// 查询第 2 页的 10 条数据
connect.DB.Set("gorm:query_option", "LIMIT 10 OFFSET 10").Find(&p)

// 动态设置
pageSize := 10
pageNum := 2
offset := (pageNum - 1) * pageSize
connect.DB.Set("gorm:query_option", fmt.Sprintf("LIMIT %d OFFSET %d", pageSize, offset)).Find(&p)

//对于分页操作,GORM 框架提供了更为方便的方法,可以使用 Limit 和 Offset 方法直接设置分页条件
pageSize := 10
pageNum := 2
connect.DB.Limit(pageSize).Offset((pageNum - 1) * pageSize).Find(&p)

这三种写法根据实际应用场景来选择。

FirstOrInit

根据给定的条件初始化一个新的对象 (仅支持 struct 和 map 查询条件),从数据库中查询符合条件的记录,如果找到了,则返回该记录;如果没有找到,则返回该查询条件。示例代码如下:

var p1, p2, p3, p4 connect.PersonInfo
//没找到的情况
connect.DB.FirstOrInit(&p1, connect.PersonInfo{UserName: "xyg"})
// SELECT * FROM `person_info` WHERE `person_info`.`username` = 'xyg' ORDER BY `person_info`.`id` LIMIT 1
fmt.Printf("%#v\n", p1) //p1为空

//找到了的情况
connect.DB.FirstOrInit(&p2, connect.PersonInfo{UserName: "abc"})
//SELECT * FROM `person_info` WHERE `person_info`.`username` = 'abc' ORDER BY `person_info`.`id` LIMIT 1
fmt.Printf("%#v\n", p2)

connect.DB.Where(connect.PersonInfo{Age: 22}).FirstOrInit(&p3)
//SELECT * FROM `person_info` WHERE `person_info`.`age` = 22 ORDER BY `person_info`.`id` LIMIT 1
fmt.Printf("%#v\n", p3)

connect.DB.FirstOrInit(&p4, map[string]interface{}{"password": "0395"})
//SELECT * FROM `person_info` WHERE `password` = '0395' ORDER BY `person_info`.`id` LIMIT 1
fmt.Printf("%#v\n", p4)

运行结果如下:

image-20230606095320631

Attrs

Attrs方法只是为模型对象设置属性值(可以理解为一个临时变量),但并不会将这些属性值保存到数据库中。

var p1, p2, p3 connect.PersonInfo

// 数据库中并不存在UserName为"bing"的记录
// 未找到(两种写法)
connect.DB.Where(connect.PersonInfo{UserName: "bing"}).Attrs(connect.PersonInfo{Age: 20}).FirstOrInit(&p1)
//SELECT * FROM `person_info` WHERE `person_info`.`username` = 'bing' ORDER BY `person_info`.`id` LIMIT 1
fmt.Printf("%#v\n", p1)

connect.DB.Where(connect.PersonInfo{UserName: "bing"}).Attrs("age",28).FirstOrInit(&p2)
//SELECT * FROM `person_info` WHERE `person_info`.`username` = 'bing' ORDER BY `person_info`.`id` LIMIT 1
fmt.Printf("%#v\n", p2)

// 找到()
connect.DB.Where(connect.PersonInfo{UserName: "xyz"}).Attrs(connect.PersonInfo{Age: 30}).FirstOrInit(&p3)
//SELECT * FROM `person_info` WHERE `person_info`.`username` = 'xyz' ORDER BY `person_info`.`id` LIMIT 1
fmt.Printf("%#v\n", p3)

运行结果如下:

image-20230606102529977

从上面的例子中可以得出以下结论:

  1. 如果使用FirstOrInit方法没有查找到相应记录,再搭配上Attrs方法,那么返回的结果值是一个临时的结构体对象,这个临时的结构体对象的一些属性会被Attrs方法更新。并且这个临时的结构体对象并不会插入到数据库中,程序结束后就会被销毁。
  2. 如果使用FirstOrInit方法找到了相应的记录,则会返回相应的记录,并且Attrs方法设置的属性值不会生效。

Assign

不管记录是否找到,都将参数赋值给相应的记录。

var p1, p2 connect.PersonInfo

// 未找到
connect.DB.Where(connect.PersonInfo{UserName: "bing"}).Assign(connect.PersonInfo{Age: 29}).FirstOrInit(&p1)
//SELECT * FROM `person_info` WHERE `person_info`.`username` = 'bing' ORDER BY `person_info`.`id` LIMIT 1
fmt.Printf("%#v\n", p1)

// 找到
connect.DB.Where(connect.PersonInfo{UserName: "dyg"}).Assign(connect.PersonInfo{Age: 35}).FirstOrInit(&p2)
//SELECT * FROM `person_info` WHERE `person_info`.`username` = 'dyg' ORDER BY `person_info`.`id` LIMIT 1
fmt.Printf("%#v\n", p2)

运行结果如下:

image-20230606105749398

小总结:

在使用FirstOrInit这个方法的大前提下,不管怎么写,都不会把返回的数据插入到数据库,因为FirstOrInit这个方法只是用来做查询操作。在搭配上Attrs和Assign这两个方法,理解起来就是:

  1. 当使用Attrs方法时:
    • 没找到记录:在Attrs方法中设置的属性会更新临时结构体对象的属性。
    • 找到记录:Attrs方法中设置的属性会失效
  2. 当使用Assign方法时;
    • 不管有没有找到相应的记录,都会设置相应的属性。

FirstOrCreate

FirstOrCreate方法用于根据指定的条件查找数据库中的一条数据记录,如果找到,则返回该记录;如果没有找到,则创建一条新的数据记录,并将其保存到数据库中。

p := connect.PersonInfo{
    Id:       8,
    UserName: "ag",
    Password: "9843",
    Age:      25,
}
//如果数据库中没有UserName为"ag"的就插入p这条数据
connect.DB.Where(connect.PersonInfo{UserName: "ag"}).FirstOrCreate(&p)
fmt.Printf("%#v\n", p)

运行完成后,查询结果如下:

image-20230606111351099

可以看到,其底层分为了两条sql语句,由于数据库中没有UserName为"ag"的记录,所以就把p对象的数据插入到数据库中。

Attrs

Attrs方法用于为要创建或更新的数据记录指定属性值,但不会将其保存到数据库中。

//能找到
p1 := connect.PersonInfo{Id: 4, Password: "6666"}
connect.DB.Attrs(connect.PersonInfo{UserName: "bing", Age: 23}).FirstOrCreate(&p1)
//SELECT * FROM `person_info` WHERE `person_info`.`id` = 4 ORDER BY `person_info`.`id` LIMIT 1
fmt.Printf("%#v\n", p1)

//找不到
p2 := connect.PersonInfo{Id: 9, Password: "8888"}
connect.DB.Attrs(connect.PersonInfo{UserName: "bing", Age: 23}).FirstOrCreate(&p2)
//SELECT * FROM `person_info` WHERE `person_info`.`id` = 9 ORDER BY `person_info`.`id` LIMIT 1
//INSERT INTO `person_info` (`username`,`password`,`age`,`id`) VALUES ('bing','8888',23,9)
fmt.Printf("%#v\n", p2)

运行结果如下:

image-20230606113811362

如果FirstOrCreate方法能找到相应的记录,则Attrs方法设置的属性将会无效。如果FirstOrCreate方法不能找到相应的记录,则底层会使用insert的SQL语句创建一条记录,并添加Attrs方法设置的属性到新纪录中。

Assign

不管记录是否找到,都将Attrs方法设置的属性赋值给 struct 并保存至数据库。

var p1, p2 connect.PersonInfo

//未找到
connect.DB.Where(connect.PersonInfo{UserName: "hui"}).Assign(connect.PersonInfo{Age: 26, Id: 10, Password: "83492"}).FirstOrCreate(&p1)
//SELECT * FROM `person_info` WHERE `person_info`.`username` = 'hui' ORDER BY `person_info`.`id` LIMIT 1
//INSERT INTO `person_info` (`username`,`password`,`age`,`id`) VALUES ('hui','83492',26,10)
fmt.Printf("%#v\n", p1)

// 找到
connect.DB.Where(connect.PersonInfo{UserName: "bing"}).Assign(connect.PersonInfo{Age: 30}).FirstOrCreate(&p2)
//SELECT * FROM `person_info` WHERE `person_info`.`username` = 'bing' ORDER BY `person_info`.`id` LIMIT 1
//UPDATE `person_info` SET `age`=30 WHERE `person_info`.`username` = 'bing' AND `id` = 9
fmt.Printf("%#v\n", p2)

运行结果如下:

image-20230606133605008

小总结:

在使用FirstOrCreate这个方法的大前提下,在搭配上Attrs和Assign这两个方法,理解起来就是:

  1. 当使用Attrs方法时:
    • 没找到记录:往数据库里面添加一条数据,Attrs方法的作用就是给这条数据添加一些属性。
    • 找到记录:返回数据库中的数据记录,并且Attrs方法中设置的属性无效。
  2. 当使用Assign方法时;
    • 没找到记录:往数据库里面添加一条数据,Assign方法的作用就是给这条数据添加一些属性(和Attrs一样)。
    • 找到记录:按照Assign方法中设置的属性,更新数据库里面的数据。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

2023年陕西彬州第八届半程马拉松赛153pb完赛

1、赛事背景 2023年6月3日&#xff0c;我参加了2023陕西彬州第八届半程马拉松赛&#xff0c;最终153完赛&#xff0c;PB了5分钟。起跑时间早上7点30分&#xff0c;毕竟6月天气也开始热了。天气预报显示当天还是小到中雨&#xff0c;上次铜川宜君半马也是雨天跑的&#xff0c;阴…

为何选择C语言作为大一编程入门?

C语言&#xff0c;编程之本&#xff0c;源于生命。作为一门最接近底层的高级语言&#xff0c;学习C语言有以下重要原因&#xff1a; 探索底层&#xff1a;C语言为我们提供了理解计算机底层工作原理的机会。通过学习C语言&#xff0c;我们能更容易理解内存管理、指针操作等底层知…

前后端分离项目SpringBoot-Shiro-jwt处理401响应码的方案

问题现象&#xff1a; 现在大多数项目已经实现前后端分离&#xff0c;当采用shiro作为安全框架时&#xff0c;如果请求的token已过期或未认证请求&#xff0c;会得到401的HTTP STATUS。此时在前端还会因为401的错误弹出一个登录认证的弹框。效果如下&#xff1a; 经分析&#…

DataLeap的全链路智能监控报警实践(一):常见问题

随着字节跳动业务的快速发展&#xff0c;大数据开发场景下需要运维管理的任务越来越多&#xff0c;然而普通的监控系统只支持配置相应任务的监控规则&#xff0c;已经不能完全满足当前需求&#xff0c;在日常运维中开发者经常会面临以下几个问题&#xff1a; 任务多&#xff0c…

凝聚全球顶尖力量,助力开源行业发展 | 2023开放原子全球开源峰会开幕式暨高峰论坛亮点抢先看!

亮点攻略 一触即发 6月11-13日&#xff5c;中国北京 作为开源领域一年一度的盛事&#xff0c;由2023全球数字经济大会组委会主办&#xff0c;开放原子开源基金会、北京市经济和信息化局、北京经济技术开发区管理委员会承办的2023开放原子全球开源峰会将于6月11日至13日在北京…

实现Mac使用空格键预览更多文件格式

mac上的快速预览非常好用&#xff0c;但是对于许多格式的不支持造成了体验感的割裂。例如对于使用频繁的.md、.js、.py等格式的文件&#xff0c;无法生成缩略图。可以通过在「Quick Look」中 安装插件的方式来实现预览格式的扩展。 1. 插件的安装 下载的插件一般有两种格式&am…

SpringBoot的高考志愿填报系统(含源码+数据库)

系统获取方式&#xff1a; 1.系统分析 在本系统中&#xff0c;基于SpringBoot的高考志愿填报系统需要满足以下功能需求&#xff1a; 1.用户可以根据自己的院校类型、办学类型、层次类型、地域等因素筛选高校。 2.用户可以查询到所选高校的基本信息&#xff0c;包括学校的概况…

vcsa6.7更换证书

今天一早&#xff0c;有现场反馈&#xff0c;vcenter无法登录&#xff0c;估计到可能是证书到期了 在浏览器中确认下&#xff0c;确实是证书到期的问题 通过查看你sts不过期&#xff0c;直接更新全部证书 To escape to local shell, press CtrlAlt]. VMware vCenter Server Ap…

翻车了,lombok这玩意真坑

目录 背景排查Setter-Getter方法的坑解决原因解决方案原因解决方案 总结 背景 青柠最近在写自己的项目&#xff0c;刚开始就写不下去了&#xff0c;心态崩了&#xff0c;这啥玩意啊&#xff0c;就是找不到问题在哪&#xff1f; 早前&#xff0c;在项目当中引入了Lombok插件&a…

zabbix配置监控日志

目录 一、zabbix日志监控的功能 二、zabbix监控日志的条件 三、日志监控的监控指标 四、日志监控Item的配置案例 一、zabbix日志监控的功能 Zabbix-agent支持对日志文件的监控&#xff0c;可以对日志对的关键字进行监控&#xff0c;然后告警。日志监控支持普通的日志文件&am…

ChatGPT与软件架构(5) - 网络安全

安全是任何系统都无法回避的关键要素&#xff0c;本文介绍了若干利用ChatGPT增强的网络安全攻击&#xff0c;并提出了应对策略。原文: ChatGPT and Cyber Security Benjamin Elliott Unsplash 如果你还不熟悉ChatGPT&#xff0c;那么考虑到这种生成式人工智能服务的快速崛起&am…

Hive SQL 语法大全~

基于语法描述说明 CREATE DATABASE [IF NOT EXISTS] db_name [LOCATION] path; SELECT expr, ... FROM tbl ORDER BY col_name [ASC | DESC] (A | B | C) 如上语法&#xff0c;在语法描述中出现&#xff1a; []&#xff0c;表示可选&#xff0c;如上[LOCATION]表示可写、可不…

神州数码DCRS试题题目合集

2017.11.3 DCRS 在公司总部的DCRS上配置&#xff0c;配置设备enable密码&#xff0c;并且在登录设备时必须正确输入enable密码才能进入交换机的配置模式。 在公司总部的DCRS上配置&#xff0c;在交换设备上开启SSH管理功能&#xff0c;用户名和密码都是DCN&#xff0c;并关闭…

flutter系列之:做一个会飞的菜单

文章目录 简介定义一个菜单项目让menu动起来添加菜单内部的动画总结 简介 flutter中自带了drawer组件&#xff0c;可以实现通用的菜单功能&#xff0c;那么有没有一种可能&#xff0c;我们可以通过自定义动画来实现一个别样的菜单呢&#xff1f; 答案是肯定的&#xff0c;一起…

(栈和队列) 150. 逆波兰表达式求值 ——【Leetcode每日一题】

❓150. 逆波兰表达式求值 难度&#xff1a;中等 给你一个字符串数组 tokens &#xff0c;表示一个根据 逆波兰表示法 表示的算术表达式。 请你计算该表达式。返回一个表示表达式值的整数。 注意&#xff1a; 有效的算符为 ‘’、‘-’、‘*’ 和 ‘/’ 。每个操作数&#…

vue制作自己的组件库(仿ElementUI)

1.首先自己创建个新的vue项目&#xff0c;之后更改下目录形式&#xff0c;将src文件更改为examples&#xff0c;这里是专门放组件展示的md文件&#xff0c;packages文件里是放自己写的组件代码 2.然后是开始配置vue.config.js文件 &#xff0c;其中md-loader是读取md文件的相关…

Linux下安装docker教程

目录 一、安装CentOS系统 二、安装Docker 1.卸载之前安装过的旧版本&#xff1a; 2.安装docker 3.启动docker 4.配置docker镜像仓库 三、Docker的使用 1.docker容器常用指令&#xff1a; 2.运行案例&#xff1a;docker拉取并运行nignx 3.查看容器日志 一、安装CentOS系…

Prompt工程-高级提示

高阶Prompting 到这一步&#xff0c;应该很明显&#xff0c;改进提示有助于在不同任务上获得更好的结果。这就是Prompt工程背后的整个理念。 虽然之前的例子很有趣&#xff0c;但在我们深入了解更高级的概念之前&#xff0c;让我们先正式地介绍一些概念。 文章目录 高阶Promp…

使用Flexible实现移动端页面的终端适配,及快捷设置开发工具px转换rem

1、使用Flexible实现移动端页面的终端适配 官网GitHub地址API介绍&#xff1a; ​​​​​​使用Flexible实现手淘H5页面的终端适配 Issue #17 amfe/article GitHub 阿里 cdn 引入地址&#xff1a; <script src"http://g.tbcdn.cn/mtb/lib-flexible/0.3.4/??…

JavaWeb公司员工管理系统

1.需求分析 系统角色分别为&#xff1a;最高权限管理员、人力主管、部门主管、员工。总体业务流程图如下图所示。 用例图如下所示。 2.系统设计 系统功能总体设计如下图。 数据库设计如下图所示。 3.系统实现效果 登录功能实现效果如下图所示。 考勤管理模块实现效…