Estou tentando adicionar alguns valores do meu banco de dados a um []string
no Go. Alguns deles são carimbos de data / hora.
Recebo o erro:
não pode usar U.Created_date (digite time.Time) como string de tipo no elemento da matriz
Posso converter time.Time
para string
?
type UsersSession struct {
Userid int
Timestamp time.Time
Created_date time.Time
}
type Users struct {
Name string
Email string
Country string
Created_date time.Time
Id int
Hash string
IP string
}
-
var usersArray = [][]string{}
rows, err := db.Query("SELECT u.id, u.hash, u.name, u.email, u.country, u.IP, u.created_date, us.timestamp, us.created_date FROM usersSession AS us LEFT JOIN users AS u ON u.id = us.userid WHERE us.timestamp + interval 30 minute >= now()")
U := Users{}
US := UsersSession{}
for rows.Next() {
err = rows.Scan(&U.Id, &U.Hash, &U.Name, &U.Email, &U.Country, &U.IP, &U.Created_date, &US.Timestamp, &US.Created_date)
checkErr(err)
userid_string := strconv.Itoa(U.Id)
user := []string{userid_string, U.Hash, U.Name, U.Email, U.Country, U.IP, U.Created_date, US.Timestamp, US.Created_date}
// -------------
// ^ this is where the error occurs
// cannot use U.Created_date (type time.Time) as type string in array element (for US.Created_date and US.Timestamp aswell)
// -------------
usersArray = append(usersArray, user)
log.Print("usersArray: ", usersArray)
}
EDITAR
Eu adicionei o seguinte. Funciona agora, obrigado.
userCreatedDate := U.Created_date.Format("2006-01-02 15:04:05")
userSessionCreatedDate := US.Created_date.Format("2006-01-02 15:04:05")
userSessionTimestamp := US.Timestamp.Format("2006-01-02 15:04:05")
Respostas:
Você pode usar o
Time.String()
método para converter atime.Time
em astring
. Isso usa a string de formato"2006-01-02 15:04:05.999999999 -0700 MST"
.Se precisar de outro formato personalizado, você pode usar
Time.Format()
. Por exemplo, para obter o carimbo de data / hora no formato,yyyy-MM-dd HH:mm:ss
use a string de formato"2006-01-02 15:04:05"
.Exemplo:
Resultado (experimente no Go Playground ):
Nota: o tempo no Go Playground é sempre definido para o valor visto acima. Execute-o localmente para ver a data / hora atual.
Observe também que usando
Time.Format()
, como o layout,string
você sempre tem que passar o mesmo tempo –chamado de hora de referência– formatado da maneira que você deseja que o resultado seja formatado. Isso está documentado emTime.Format()
:fonte
Mon Jan 2 15:04:05 -0700 MST 2006
e colocar essa hora no formato que desejar. Go entenderá o formato se você o passar com este valor. Você não pode usar nenhum outro valor de tempo. Levei algum tempo para descobrir isso e pensei em adicioná-lo como um comentáriofonte
Go Playground http://play.golang.org/p/DN5Py5MxaB
fonte
Encontre a solução simples para reunir o formato de data e hora em Go Lang. Por favor, encontre o exemplo abaixo.
Link do pacote: https://github.com/vigneshuvi/GoDateFormat .
Encontre os titulares de plackholders: https://medium.com/@Martynas/formatting-date-and-time-in-golang-5816112bf098
fonte
fonte