假设我们通过手工的方式分了表user1
和user2
,表结构当然是一样的。
我们要通过select * from users limit 100
来查询。
回顾一下之前的代码:https://blog.csdn.net/github_26672553/article/details/100025119
sql查询主要是调用HandlerQuery
函数。
首先我们要明白mysql中2表联合查询是怎么写的?
SELECT * FROM user1
UNION
SELECT * FROM user2;
但我们这里查询使用的语句是:
select * from users;
所以当我们把sql语句
传递给HandlerQuery()
函数后要对其进行处理。
下面是主要实现代码:
//替换sql语句的函数
func ReplaceTable(sql string) string {
r := regexp.MustCompile("users")
res := r.ReplaceAllString(sql, "(select * from user1 union select * from user2) as t")
return res
}
//重写HandlerQuery方法
func (this MyHandler) HandleQuery(query string) (*mysql.Result, error) {
query = ReplaceTable(query) //对sql处理
result, err := this.conn.Execute(query)
if err != nil {
return nil, fmt.Errorf("Error:", err)
}
return result, nil
}