2020. június 9., kedd 1:03:14 UTC+2 időpontban Saied Seghatoleslami a 
következőt írta:
>
> I am scanning database tables into a structure explicitly (with 
> &struct.field) that works just fine (working path below).  
>
> But my tables have different columns, so I am working to generalize the 
> API.  There are two methods that build and reverse a []interface{} to be 
> supplied to scan.  I have listed them in the problem path.  The last item 
> is the people data in the use case.
>
> It scans every column correctly except the first one that is the ID.  
>
> The problem path always returns zero for the ID field while the working 
> path works fine.  I have been staring at it for a day and experimenting 
> with different ideas but no success
>
> Any thoughts?
>
>
>
> //=============================. Working Path =============================
>
> //Person is the target for scan.
> type Person struct {
> ID             int
> Name           string
> Email          string
> HashedPassword string
> Created        time.Time
> Role           string
> Active         bool
> Online         bool
> }
>
> //inside the "get" method to get the data
>
> person := broker.Person{}
> for rows.Next() {
> err := rows.Scan(&person.ID, &person.Name, &person.Email, //g...)
> &person.HashedPassword, &person.Created, &person.Active)
> if err != nil {
> if errors.Is(err, sql.ErrNoRows) {
> return broker.ErrNoRecord
> }
> return err
> }
> newPeople = append(newPeople, person)
> //=============================. Problem Path =============================
>
> person := broker.Person{}
> g := person.GetItems(e.Get)
> for rows.Next() {
> err := rows.Scan(g...)
> if err != nil {
> if errors.Is(err, sql.ErrNoRows) {
> return broker.ErrNoRecord
> }
> return err
> }
> person.GetBack(e.Get, g)
> newPeople = append(newPeople, person) 
>
>
>
>
> //note that iD, Name, Email... are constants
>
> //GetItems uses the get string to generate an interface to be passed to the
> //sql.Execute statement for the INSERT sql command.
> func (p *Person) GetItems(get []string) []interface{} {
> var g = []interface{}{}
> for _, sp := range get {
> switch sp {
> case iD:
> g = append(g, &p.ID)
> case Name:
> g = append(g, &p.Name)
> case Email:
> g = append(g, &p.Email)
> case HashedPassword:
> g = append(g, &p.HashedPassword)
> case Created:
> g = append(g, &p.Created)
> case Role:
> g = append(g, &p.Role)
> case Active:
> g = append(g, &p.Active)
> case Online:
> g = append(g, &p.Online)
> }
> }
> return g
> }
>
> //GetBack reverses the get item and takes the interface items and gets the
> //underlying data back.
> func (p *Person) GetBack(get []string, g []interface{}) error {
> var ok bool
> for i, sp := range get {
> switch sp {
> case iD:
> p.ID, ok = g[i].(int)
> if !ok {
> return fmt.Errorf("ID (int) type assertion failed")
> }
> case Name:
> p.Name, ok = g[i].(string)
> if !ok {
> return fmt.Errorf("Name (string) type assertion failed")
> }
> case Email:
> p.Email, ok = g[i].(string)
> if !ok {
> return fmt.Errorf("Email (string) type assertion failed")
> }
> case HashedPassword:
> p.HashedPassword, ok = g[i].(string)
> if !ok {
> return fmt.Errorf("Hashed Password (string) type assertion failed")
> }
> case Created:
> p.Created, ok = g[i].(time.Time)
> if !ok {
> return fmt.Errorf("Created (time.Time) type assertion failed")
> }
> case Role:
> p.Role, ok = g[i].(string)
> if !ok {
> return fmt.Errorf("Role (string) type assertion failed")
> }
> case Active:
> p.Active, ok = g[i].(bool)
> if !ok {
> return fmt.Errorf("Active (bool) type assertion failed")
> }
> case Online:
> p.Online, ok = g[i].(bool)
> if !ok {
> return fmt.Errorf("Online (bool) type assertion failed")
> }
> }
> }
> return nil
> }
>
> exchange := Exchange{
> Table: table,
> Put:   []string{},
> Spec:  []string{iD},
> Get: []string{iD, Name, Email, HashedPassword, Created,
> Active, Online},
> People: []Person{
> Person{ID: id},
> },
> Action: "get",
> }
>
>
>
I don't see anything obviously wrong here.
Sprinkle it with log.Printfs around everywhere iD is, and make sure that it 
IS getting set, with the correct value!

-- 
You received this message because you are subscribed to the Google Groups 
"golang-nuts" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to golang-nuts+unsubscr...@googlegroups.com.
To view this discussion on the web visit 
https://groups.google.com/d/msgid/golang-nuts/afbb767b-601c-47f1-9a42-714be988b805o%40googlegroups.com.

Reply via email to