package db import ( "applet/app/db/model" "applet/app/utils" "fmt" "xorm.io/xorm" ) func GetStore(eg *xorm.Engine, arg map[string]string) []map[string]string { lng := utils.StrToFloat64(arg["lng"]) lat := utils.StrToFloat64(arg["lat"]) sel := ` *,sqrt( ( (( %f - lng)*PI()*12656*cos((( %f +lat)/2)*PI()/180)/180) * (( %f - lng)*PI()*12656*cos (((%f+lat)/2)*PI()/180)/180) ) + ( ((%f-lat)*PI()*12656/180) * ((%f-lat)*PI()*12656/180) ) ) AS km` sel = fmt.Sprintf(sel, lng, lat, lng, lat, lat, lat) sql := `select %s from community_team_store where %s %s` where := "state=1" if arg["parent_uid"] != "" { where += " and store_type=2 and parent_uid=" + arg["parent_uid"] } else if arg["uid"] != "" { where += " and store_type=1 and uid=" + arg["parent_uid"] } else { where += " and store_type=" + arg["store_type"] } if arg["city"] != "" { where += " and city='" + arg["city"] + "'" } if arg["name"] != "" { where += " and name like '%" + arg["name"] + "'" } start := (utils.StrToInt(arg["p"]) - 1) * utils.StrToInt(arg["size"]) group := " order by %s limit " + utils.IntToStr(start) + "," + arg["size"] groupStr := "fan desc,km asc,id asc" if arg["cid"] == "1" { groupStr = "km asc,id asc" } group = fmt.Sprintf(group, groupStr) sql = fmt.Sprintf(sql, sel, where, group) fmt.Println(sql) nativeString, _ := QueryNativeString(eg, sql) return nativeString } func GetStoreLike(eg *xorm.Engine, arg map[string]string) []map[string]string { lng := utils.StrToFloat64(arg["lng"]) lat := utils.StrToFloat64(arg["lat"]) sel := ` cts.*,sqrt( ( (( %f - cts.lng)*PI()*12656*cos((( %f +cts.lat)/2)*PI()/180)/180) * (( %f - cts.lng)*PI()*12656*cos (((%f+cts.lat)/2)*PI()/180)/180) ) + ( ((%f-cts.lat)*PI()*12656/180) * ((%f-cts.lat)*PI()*12656/180) ) ) AS km` sel = fmt.Sprintf(sel, lng, lat, lng, lat, lat, lat) sql := `select %s from community_team_store_like ctsl left join community_team_store cts on ctsl.store_id=cts.id where %s %s` where := "cts.state=1" if arg["parent_uid"] != "" { where += " and cts.store_type=2 and cts.parent_uid=" + arg["parent_uid"] } else if arg["uid"] != "" { where += " and cts.store_type=1 and cts.uid=" + arg["parent_uid"] } else { where += " and cts.store_type=" + arg["store_type"] } if arg["city"] != "" { where += " and cts.city='" + arg["city"] + "'" } if arg["name"] != "" { where += " and cts.name like '%" + arg["name"] + "'" } start := (utils.StrToInt(arg["p"]) - 1) * utils.StrToInt(arg["size"]) group := " order by km asc,cts.id asc limit " + utils.IntToStr(start) + "," + arg["size"] sql = fmt.Sprintf(sql, sel, where, group) fmt.Println(sql) nativeString, _ := QueryNativeString(eg, sql) return nativeString } func GetStoreId(sess *xorm.Session, id string) *model.CommunityTeamStore { var data model.CommunityTeamStore get, err := sess.Where("id=?", id).Get(&data) if get == false || err != nil { return nil } return &data } func GetStoreIdEg(eg *xorm.Engine, id string) *model.CommunityTeamStore { var data model.CommunityTeamStore get, err := eg.Where("id=?", id).Get(&data) if get == false || err != nil { return nil } return &data }