go语言操作数据库(database/sql)

KelvinQ · · 2446 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

操作sql类,目前只有一个查询,其他可以根据这个再去扩展

package QORM

import (
	"database/sql"
	"fmt"
	"reflect"

	_ "github.com/go-sql-driver/mysql"
)

//请求结构体
type QDBProto struct {
	DB *sql.DB
}

var qDBProto *QDBProto

//构造函数
func CreateDBProto(driver string, sqlLink string) *QDBProto {
	qDBProto = new(QDBProto)
	db, err := sql.Open(driver, sqlLink)
	if err == nil {
		qDBProto.DB = db
		return qDBProto
	} else {
		return nil
	}
}

//查询
func (p *QDBProto) Select(destClass interface{}, sqlstr string, arg ...interface{}) ([]interface{}, int) {
	var rowCount int = 0
	var rows *sql.Rows
	var err error
	if arg != nil {
		rows, err = p.DB.Query(sqlstr)
	} else {
		rows, err = p.DB.Query(sqlstr, arg)
	}
	if err != nil {
		fmt.Println(err.Error())
		return nil, rowCount
	}
	defer rows.Close()
	result := make([]interface{}, 0)
	for rows.Next() {
		scanArr := make([]interface{}, 0)
		scanEntity := make(map[string]interface{})
		destValue := reflect.ValueOf(destClass)
		destType := reflect.TypeOf(destClass)
		fieldCount := destValue.NumField()
		for fieldIndex := 0; fieldIndex < fieldCount; fieldIndex++ {
			field := destValue.Field(fieldIndex)
			fieldType := field.Type()
			newFieldValue := reflect.New(fieldType)
			fieldValue := newFieldValue.Interface()
			scanArr = append(scanArr, fieldValue)
			fmt.Println(destType.Field(fieldIndex).Name)
			scanEntity[destType.Field(fieldIndex).Name] = fieldValue
		}
		if err := rows.Scan(scanArr...); err != nil {
			fmt.Println(err.Error())
			return nil, rowCount
		} else {

			result = append(result, scanEntity)
			rowCount++
		}
	}
	return result, rowCount
}

使用:

rows, rowCount := conn2.Select(automethodNew{}, "select * from automethod")

 


有疑问加站长微信联系(非本文作者)

本文来自:开源中国博客

感谢作者:KelvinQ

查看原文:go语言操作数据库(database/sql)

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

2446 次点击  ∙  1 赞  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传