本文整理匯總了Golang中github.com/QLeelulu/goku.MysqlDB.Query方法的典型用法代碼示例。如果您正苦於以下問題:Golang MysqlDB.Query方法的具體用法?Golang MysqlDB.Query怎麽用?Golang MysqlDB.Query使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類github.com/QLeelulu/goku.MysqlDB
的用法示例。
在下文中一共展示了MysqlDB.Query方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: User_CheckRelationship
// 檢查 mUserId 與 sUserId 的關係,
// return:
// @isFollower: sUserId是否關注mUserId
// @isFollowed: mUserId是否關注sUserId
// @isFriend: 是否互相關注
func User_CheckRelationship(mUserId, sUserId int64) (isFollower, isFollowed, isFriend bool) {
var db *goku.MysqlDB = GetDB()
defer db.Close()
rows, err := db.Query("select * from `user_follow` where `user_id`=? and `follow_id`=? limit 1",
mUserId, sUserId)
if err != nil {
goku.Logger().Errorln(err.Error())
return
}
defer rows.Close()
if rows.Next() {
isFollowed = true
}
rows1, err1 := db.Query("select * from `user_follow` where `user_id`=? and `follow_id`=? limit 1",
sUserId, mUserId)
if err1 != nil {
goku.Logger().Errorln(err1.Error())
return
}
defer rows1.Close()
if rows1.Next() {
isFollower = true
}
if isFollowed && isFollower {
isFriend = true
}
return
}
示例2: thirdPartyUser_SearchOneBy
func thirdPartyUser_SearchOneBy(criteria string, values ...interface{}) (u *ThirdPartyUser) {
var db *goku.MysqlDB = GetDB()
defer db.Close()
sql := "SELECT `user_id`, `third_party`, `third_party_user_id`, `third_party_email`, `access_token`, `refresh_token`, `token_expire_time`, `create_time`, `last_active_time`, `avatar_url`, `link` FROM `third_party_user` WHERE " + criteria + " limit 1"
thirdPartyUserRow, err := db.Query(sql, values...)
if err != nil {
return
}
if thirdPartyUserRow == nil {
return
}
if thirdPartyUserRow.Next() {
u = &ThirdPartyUser{}
err = thirdPartyUserRow.Scan(
&u.UserId, &u.ThirdParty, &u.ThirdPartyUserId, &u.ThirdPartyEmail,
&u.AccessToken, &u.RefreshToken, &u.TokenExpireTime, &u.CreateTime, &u.LastActiveTime, &u.AvatarUrl, &u.Link)
}
if err != nil {
u = nil
}
return
}
示例3: delete_tui_link_for_handle
/**
* 刪除tui_link_for_handle已經處理的數據
*/
func delete_tui_link_for_handle(handleTime time.Time, db *goku.MysqlDB) error {
sql := "DELETE FROM tui_link_for_handle WHERE `insert_time`<=? "
_, err := db.Query(sql, handleTime)
return err
}
示例4: Del_link_for_topic_all
func Del_link_for_topic_all(db *goku.MysqlDB) error {
err := del_link_for_topic_later_top("tui_link_for_topic_top", "reddit_score DESC,link_id DESC", db)
if err == nil {
err = del_link_for_topic_later_top("tui_link_for_topic_later", "link_id DESC", db)
}
if err == nil {
_, err = db.Query(`DELETE FROM tui_link_for_topic_hot WHERE (time_type=2 AND create_time<?) OR (time_type=3 AND create_time<?) OR
(time_type=4 AND create_time<?) OR (time_type=5 AND create_time<?) OR
(time_type=6 AND create_time<?)`, utils.ThisHour(), utils.ThisDate(), utils.ThisWeek(), utils.ThisMonth(), utils.ThisYear())
if err == nil {
err = del_link_for_topic_hot_vote("tui_link_for_topic_hot", "dispute_score DESC,link_id DESC", db)
}
}
if err == nil {
_, err = db.Query(`DELETE FROM tui_link_for_topic_vote WHERE (time_type=2 AND create_time<?) OR (time_type=3 AND create_time<?) OR
(time_type=4 AND create_time<?) OR (time_type=5 AND create_time<?) OR
(time_type=6 AND create_time<?)`, utils.ThisHour(), utils.ThisDate(), utils.ThisWeek(), utils.ThisMonth(), utils.ThisYear())
if err == nil {
err = del_link_for_topic_hot_vote("tui_link_for_topic_vote", "vote DESC,link_id DESC", db)
}
}
return err
}
示例5: link_for_topic_hop_time
/**
* 鏈接推送給話題(熱議) 2:這個小時;3:今天;4:這周;5:這個月;6:今年
*/
func link_for_topic_hop_time(timeType int, handleTime time.Time, db *goku.MysqlDB) error {
var t time.Time
switch {
case timeType == 2:
t = utils.ThisHour()
case timeType == 3:
t = utils.ThisDate()
case timeType == 4:
t = utils.ThisWeek()
case timeType == 5:
t = utils.ThisMonth()
case timeType == 6:
t = utils.ThisYear()
}
sql := `INSERT ignore INTO tui_link_for_topic_hot(topic_id,link_id,create_time,dispute_score,time_type)
(
SELECT TL.topic_id,H.link_id,H.create_time,L.dispute_score,? AS time_type FROM tui_link_for_handle H
INNER JOIN topic_link TL ON H.insert_time<=? AND H.create_time>=? AND H.link_id=TL.link_id
INNER JOIN link L ON L.id=H.link_id
);`
_, err := db.Query(sql, timeType, handleTime, t)
return err
}
示例6: UpdateIsRegister
//更新邀請碼
func UpdateIsRegister(invite *RegisterInvite) {
if !golink.Invite_Enabled {
return
}
var db *goku.MysqlDB = GetDB()
defer db.Close()
db.Query("UPDATE `register_invite` SET `is_register`=1 WHERE `Guid`=?", invite.Guid)
}
示例7: User_RecommendFromTopic
//根據用戶關注的話題給它推薦相關的用戶
func User_RecommendFromTopic(userId int64) ([]User, error) {
iRecommendCount := 10
var db *goku.MysqlDB = GetDB()
db.Debug = true
defer db.Close()
sql := "SELECT `topic_id` FROM `topic_follow` WHERE `user_id`=? ORDER BY `create_time` DESC limit ?"
topicRows, topicErr := db.Query(sql, userId, iRecommendCount)
if topicErr != nil {
return nil, topicErr
}
topicIds := make([]int64, 0)
var topicId int64
for topicRows.Next() {
topicErr = topicRows.Scan(&topicId)
if topicErr == nil {
topicIds = append(topicIds, topicId)
}
}
hashUsers := map[int64]int64{}
users := make([]User, 0)
tLen := len(topicIds)
var uCount int
uCount = iRecommendCount / tLen
strUserIds := fmt.Sprintf("%d", userId)
hashUsers[userId] = userId
if tLen > 0 {
sql = "SELECT u.`id`,u.`name`,u.`email`,u.`description`,u.`user_pic`,u.`friend_count`,u.`topic_count`,u.`ftopic_count`,u.`status`," +
"u.`follower_count`,u.`link_count`,u.`create_time` FROM `tui_link_for_topic_top` tl INNER JOIN `link` l ON " +
"tl.`topic_id`=? AND tl.`link_id`=l.`id` AND l.`user_id` NOT IN(?) " +
"AND NOT EXISTS(SELECT 1 FROM `user_follow` uf WHERE uf.`user_id`=? AND uf.`follow_id`=l.`user_id`) " +
"INNER JOIN `user` u ON u.`id`=l.`user_id` " +
"ORDER BY tl.`reddit_score` DESC limit ?"
for _, tId := range topicIds {
userRows, userErr := db.Query(sql, tId, strUserIds, userId, uCount)
if userErr == nil {
for userRows.Next() {
user := User{}
userErr = userRows.Scan(&user.Id, &user.Name, &user.Email, &user.Description, &user.UserPic, &user.FriendCount, &user.TopicCount, &user.FtopicCount, &user.Status, &user.FollowerCount, &user.LinkCount, &user.CreateTime)
if userErr == nil && hashUsers[userId] <= 0 {
users = append(users, user)
strUserIds += fmt.Sprintf(",%d", user.Id)
hashUsers[user.Id] = user.Id
}
}
}
}
}
//fmt.Print(users)
return users, nil
}
示例8: Link_for_topic_later
/**
* 鏈接推送給話題(最新)
*/
func Link_for_topic_later(handleTime time.Time, db *goku.MysqlDB) error {
sql := `INSERT ignore INTO tui_link_for_topic_later(topic_id,link_id,create_time)
(
SELECT TL.topic_id,H.link_id,H.create_time FROM tui_link_for_handle H
INNER JOIN topic_link TL ON H.data_type=1 AND H.insert_time<=? AND H.link_id=TL.link_id
);`
_, err := db.Query(sql, handleTime)
return err
}
示例9: Link_for_home_top
/**
* 鏈接推送給網站首頁(熱門)
*/
func Link_for_home_top(handleTime time.Time, db *goku.MysqlDB) error {
sql := `INSERT ignore INTO tui_link_for_home(link_id,create_time,data_type,score)
(
SELECT H.link_id,H.create_time,2,L.reddit_score FROM tui_link_for_handle H
INNER JOIN link L ON H.insert_time<=? AND L.id=H.link_id
); `
_, err := db.Query(sql, handleTime)
return err
}
示例10: Comment_DelById
func Comment_DelById(id int64) error {
var db *goku.MysqlDB = GetDB()
defer db.Close()
_, err := db.Query("UPDATE `comment` SET status=2 WHERE id=?", id)
if err != nil {
goku.Logger().Errorln(err.Error())
return err
}
return nil
}
示例11: UpdateInviteEmailStatus
//更新發送的邀請email狀態
func UpdateInviteEmailStatus(emails []*EmailInvite) {
var db *goku.MysqlDB = GetDB()
defer db.Close()
for _, email := range emails {
if email.SendSuccess == true {
db.Query("UPDATE register_invite SET is_send=1 WHERE guid=?", email.Guid)
} else {
db.Query("UPDATE register_invite SET fail_count=fail_count+1 WHERE guid=?", email.Guid)
}
}
}
示例12: del_link_for_home
/** 刪除`tui_link_for_home`
* 熱門, whereDataType:data_type=2 orderName:score DESC,link_id DESC
* 熱議, whereDataType:data_type IN(3,10,11,12,13,14) orderName:score desc,link_id DESC
* 投票, whereDataType:data_type IN(4,5,6,7,8,9) orderName:score DESC,link_id DESC
*/
func del_link_for_home(whereDataType string, orderName string, db *goku.MysqlDB) error {
sql := fmt.Sprintf(`SELECT data_type, tcount - %d AS del_count FROM
(SELECT link_id,data_type,COUNT(1) AS tcount FROM tui_link_for_home WHERE %s GROUP BY data_type) T
WHERE T.tcount>%d;`, LinkMaxCount, whereDataType, LinkMaxCount)
delSqlCreate := `INSERT ignore INTO tui_link_temporary_delete(id)
(
SELECT link_id FROM tui_link_for_home WHERE data_type=%d ORDER BY ` + orderName + ` LIMIT %d,%d
); `
delSqlDelete := `DELETE T FROM tui_link_temporary_delete D INNER JOIN tui_link_for_home T ON T.data_type=%d
AND T.link_id=D.id; `
var delCount int64
var dataType int
rows, err := db.Query(sql)
if err == nil {
for rows.Next() {
rows.Scan(&dataType, &delCount)
db.Query("DELETE FROM tui_link_temporary_delete;")
db.Query(fmt.Sprintf(delSqlCreate, dataType, LinkMaxCount, delCount))
db.Query(fmt.Sprintf(delSqlDelete, dataType))
}
}
return err
}
示例13: Topic_CheckFollowByDb
// 檢查用戶是否已經關注話題,
// @isFollowed: 是否已經關注話題
func Topic_CheckFollowByDb(db *goku.MysqlDB, userId, topicId int64) (isFollowed bool) {
rows, err := db.Query("select * from `topic_follow` where `user_id`=? and `topic_id`=? limit 1",
userId, topicId)
if err != nil {
goku.Logger().Errorln(err.Error())
return
}
defer rows.Close()
if rows.Next() {
isFollowed = true
}
return
}
示例14: Link_for_home_update
/**
* 鏈接推送給網站首頁(更新現有數據 )
*/
func Link_for_home_update(handleTime time.Time, db *goku.MysqlDB) error {
sql := `UPDATE tui_link_for_handle H
INNER JOIN tui_link_for_home T ON H.insert_time<=? AND H.data_type=2 AND T.link_id=H.link_id
INNER JOIN link L ON L.id=H.link_id
SET T.score=CASE WHEN T.data_type=2 THEN L.reddit_score -- 熱門
WHEN T.data_type=3 THEN L.dispute_score -- 熱議
WHEN T.data_type BETWEEN 10 AND 14 THEN L.dispute_score -- 熱議
ELSE L.vote_up-L.vote_down -- 投票
END;`
_, err := db.Query(sql, handleTime)
return err
}
示例15: User_IsEmailExist
// 檢查email地址是否存在。
// 任何出錯都認為email地址存在,防止注冊
func User_IsEmailExist(email string) bool {
var db *goku.MysqlDB = GetDB()
defer db.Close()
rows, err := db.Query("select id from `user` where `email_lower`=? limit 1", strings.ToLower(email))
if err != nil {
goku.Logger().Errorln(err.Error())
// 出錯直接認為email存在
return true
}
defer rows.Close()
if rows.Next() {
return true
}
return false
}