elasticsearch怎么使用
发表于:2025-12-02 作者:千家信息网编辑
千家信息网最后更新 2025年12月02日,这篇文章主要讲解了"elasticsearch怎么使用",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"elasticsearch怎么使用"吧!es.go
千家信息网最后更新 2025年12月02日elasticsearch怎么使用
这篇文章主要讲解了"elasticsearch怎么使用",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"elasticsearch怎么使用"吧!
es.go
package mainimport ( "context" "github.com/olivere/elastic" "time")var ( esUrl = "http://s10:19200" ctx = context.Background() client *elastic.Client)func init() { var err error client, err = elastic.NewClient( elastic.SetSniff(false), elastic.SetURL(esUrl), elastic.SetHealthcheckInterval(10*time.Second), elastic.SetMaxRetries(5), ) if err != nil { panic(err.Error()) }}mysql.go
package mainimport ( _ "github.com/go-sql-driver/mysql" "github.com/go-xorm/xorm")var ( db *xorm.EngineGroup)func init() { conns := []string{"test:test@tcp(127.0.0.1:3306)/test"} var err error db, err = xorm.NewEngineGroup("mysql", conns) if err != nil { panic(err.Error()) } db.ShowSQL(true) db.SetMaxIdleConns(5) db.SetMaxOpenConns(10)}model.go
package mainimport ( "encoding/json" "time")type StudentAnswer struct { Id int64 `json:"id"` Qid int64 `json:"qid"` QuesType int `json:"ques_type"` ClassType int `json:"class_type"` LessonId int64 `json:"lesson_id"` ScheduleId int64 `json:"schedule_id"` IsFirstSubmit int `json:"is_first_submit"` IsRight int `json:"is_right"` StuAnswer string `json:"stu_answer"` Scores string `json:"scores"` StudentId int64 `json:"student_id"` CreatedAt time.Time `json:"created_at"` UpdatedAt time.Time `json:"updated_at"`}func (*StudentAnswer) TableName() string { return "student_answer"}func (sa *StudentAnswer) String() string { buf, _ := json.Marshal(sa) return string(buf)}main.go
package mainimport ( "fmt" "github.com/olivere/elastic" "googo.io/goo/log" "sync")var ( MaxId = int64(0) pageSize = 1000 index = "stu-answer" wg sync.WaitGroup ch = make(chan int64, 1000) data = make(chan []StudentAnswer))func init() { // client.DeleteIndex(index).Do(ctx) // client.CreateIndex(index).Do(ctx)}func main() { wg.Add(1) go func() { defer wg.Done() for { rows := getRows() fmt.Println(len(rows)) if rows == nil || len(rows) == 0 { break } MaxId = rows[len(rows)-1].Id data <- rows } }() wg.Add(1) go func() { defer wg.Done() for { select { case rows := <-data: el := client.Bulk().Index(index) for _, row := range rows { el.Add(elastic.NewBulkIndexRequest().Id(fmt.Sprintf("%d", row.Id)).Doc(row)) } if _, err := el.Do(ctx); err != nil { gooLog.Error(err.Error()) } } } }() wg.Wait()}func getRows() []StudentAnswer { rows := []StudentAnswer{} err := db.Where("id > ?", MaxId).Limit(pageSize).Find(&rows) if err != nil { gooLog.Error(err.Error()) return nil } return rows}test/main.go
package mainimport ( "encoding/json" "fmt" "github.com/olivere/elastic")// SELECT COUNT(*) AS cnt FROM (SELECT id FROM `student_answer`// WHERE lesson_id IN (633,63,635,636,665,668) AND is_first_submit = 1 AND class_type = 2// GROUP BY `student_id`) AS avar ( index = "jy_edu_student_answer")func main() { q := elastic.NewBoolQuery().Must( elastic.NewTermsQuery("lesson_id", 633, 634, 635, 636, 665, 668), elastic.NewMatchQuery("is_first_submit", "1"), elastic.NewMatchQuery("class_type", "2"), ) agg := elastic.NewTermsAggregation().Field("student_id") cnt, err := client.Count().Index(index).Do(ctx) fmt.Println(cnt, err) cnt, err = client.Count().Index(index).Query(q).Do(ctx) fmt.Println(cnt, err) rst, _ := client.Search().Index(index).Aggregation("agg_student_id", agg).Query(q).Size(0).Do(ctx) buf, _ := json.Marshal(rst) fmt.Println(string(buf))}感谢各位的阅读,以上就是"elasticsearch怎么使用"的内容了,经过本文的学习后,相信大家对elasticsearch怎么使用这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是,小编将为大家推送更多相关知识点的文章,欢迎关注!
学习
内容
就是
思路
情况
文章
更多
知识
知识点
篇文章
跟着
问题
实践
推送
研究
验证
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
移动应用软件开发试卷
无锡服务器维修华硕
网络安全提出者
大学软件开发课程都有哪些
信息处理技术员考数据库吗
数据库技术的基础论文
手机数据库封面
华为服务器配置参数
腾讯为什么要分那么多服务器
sql导出数据库表数据库
软件开发公司用项目管理软件
数据库progres
浙江实用的外贸软件开发公司
dgv人群数据库怎么查询
无线网络安全硬件
客户端共享服务器应用软件的方法
珠海应用软件开发设计
hive元数据库查看分隔符
软件开发与数据挖掘能力
i春秋网络安全分享
机构树的数据库表设计图
青岛移动软件开发流程
教育网络安全研修
云游戏 gpu 服务器市场
网络技术群定义
湖南工控服务器散热器云主机
数据库备份到另一个表上怎么写
国网公司变电站网络安全评估
周一睿网络安全
云服务器无法连接本地测试