Построение запросов CQL для добавления новых столбцов и значений из интерфейса map [string] {} - PullRequest
0 голосов
/ 11 июня 2019

Я новичок в Go & CQL и мне нужна помощь со следующим (не могу найти ответ на мой вопрос на платформе): у меня есть интерфейс map [string] {} и для каждой пары k, vна этой карте мне нужно проверить, существует ли столбец (представленный k) в срезе поля ... и если нет - добавить его как новый столбец в таблицу (с определенным типом, основанным на типе значения),а также стоимость.Я изо всех сил пытаюсь найти способ получить тип значения, преобразовать его в тип данных Cassandra и включить его в строку запроса в качестве типа столбца.Мой код до сих пор выглядит так:

//takes as arguments the map and a slice that holds the columns that are already in the table. Is there 
//A fucntion that returns a string to be executed later by //session.Query(...).Exec() to add columns that are missing in the table
func AddColumns(myInterfaceMap map[string]string, fields []string) string {

    var columnsToBeAdded []string

    var sb strings.Builder
    sb.WriteString("ALTER TABLE sample_demo.main ADD (")
    for k := range myInterfaceMap {

        if !contains(fields, k) {
            columnsToBeAdded = append(columnsToBeAdded, k)
            fields = append(Fields, k)
        }
    }
    for idx, column := range columnsToBeAdded {
        if idx == (len(columnsToBeAdded) - 1) {
            sb.WriteString(column)
            //I need to dynamically specify the column type, depending on value   for the 
            //concrete key...need help how to do it
            sb.WriteString(" text)") 

        } else {
            sb.WriteString(column)
            sb.WriteString(" text, ")
        }
    }
    log.Println(sb.String())
    log.Println(fields)
    return sb.String()
}

Если кто-то может помочь, это действительно будет оценено :)

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...