Как сохранить тип данных в ответе после подключения к Datastax Astra DB?

Я использую базу данных Datastax Astra. Я загружаю файл csv и устанавливаю тип данных всех столбцов как float в соответствии с столбцом. Я подключился к своей базе данных через python http_method.

      res = astra_client.request(
    method=http_methods.GET,
    path=f"/api/rest/v2/keyspaces/{ASTRA_DB_KEYSPACE}/{ASTRA_DB_COLLECTION}/rows")

Это дает мне все строки, но тип данных не сохраняется в ответе. Все числа с плавающей запятой преобразованы в строку. Почему и как я могу это решить?

      {'PetalWidthCm': '0.2', 'Id': 23, 'PetalLengthCm': '1.0', 'SepalWidthCm': '3.6', 'Species': 'Iris-setosa', 'SepalLengthCm': '4.6'}

1 ответ

Как вы создаете свою таблицу и добавляете данные? Например, у меня работает следующее.

      import http.client
import json

ASTRA_TOKEN = ""
ASTRA_DB_ID = ""
ASTRA_DB_REGION = ""
ASTRA_DB_KEYSPACE = "testks"
ASTRA_DB_COLLECTION = "float_test"

conn = http.client.HTTPSConnection(f"{ASTRA_DB_ID}-{ASTRA_DB_REGION}.apps.astra.datastax.com")
headers = {
  'X-Cassandra-Token': ASTRA_TOKEN,
  'Content-Type': 'application/json'
}

# Create the table
createTablePayload = json.dumps({
  "name": f"{ASTRA_DB_COLLECTION}",
  "columnDefinitions": [
    {"name": "id", "typeDefinition": "text"},
    {"name": "floatval", "typeDefinition": "float"},
    {"name": "intval", "typeDefinition": "int"},
    {"name": "doubleval", "typeDefinition": "double"}
  ],
  "primaryKey": {"partitionKey": ["id"]},
  "ifNotExists": True
})

# Add some data
conn.request("POST", f"/api/rest/v2/schemas/keyspaces/{ASTRA_DB_KEYSPACE}/tables", createTablePayload, headers)
res = conn.getresponse()
data = res.read()
print(data.decode("utf-8"))

addRowPayload = json.dumps({
  "id": "af2603d2-8c03-11eb-a03f-0ada685e0000",
  "floatval": 1.1,
  "intval": 2,
  "doubleval": 3.3
})

conn.request("POST", f"/api/rest/v2/keyspaces/{ASTRA_DB_KEYSPACE}/{ASTRA_DB_COLLECTION}", addRowPayload, headers)
res = conn.getresponse()
data = res.read()
print(data.decode("utf-8"))

# Read back the data
conn.request("GET", f"/api/rest/v2/keyspaces/{ASTRA_DB_KEYSPACE}/{ASTRA_DB_COLLECTION}/rows", "", headers)
res = conn.getresponse()
data = res.read()
print(data.decode("utf-8"))

Ответ на это

      $ python3 get_rows.py
{"name":"float_test"}
{"id":"af2603d2-8c03-11eb-a03f-0ada685e0000"}
{"count":1,"data":[{"id":"af2603d2-8c03-11eb-a03f-0ada685e0000","doubleval":3.3,"intval":2,"floatval":1.1}]}
Другие вопросы по тегам