разброс питона - PullRequest
2 голосов
/ 27 мая 2011

Я использую matplotlib для разброса графика некоторых данных из таблицы Oracle.Одним из полей является DATE, и при преобразовании его в to_char в приведенном ниже запросе я получаю сообщение об ошибке.Я хочу разбросать сюжет по часам 00-23, а не по дате.Таким образом, ось Y должна показывать 00-23.См. Ниже пример кода вместе с ошибкой.

Спасибо за любую помощь.

Scatter Plot By Day


import cx_Oracle, os
import numpy
import matplotlib.pyplot as plt

Это работает

sql = """select number_of_small_reads, number_of_small_writes, number_of_large_reads, number_of_large_writes, end_time from schema.table order by end_time"""

Это не работает

sql = """select number_of_small_reads, number_of_small_writes, number_of_large_reads, number_of_large_writes, to_char(end_time, 'HH24') e from schema.table order by e"""

Я получаю следующую ошибку: "невозможно выполнить уменьшение с гибким типом"

conn = cx_Oracle.Connection("user/password@server:1521/database")
cursor = conn.cursor()
cursor.execute(sql)
rowset = cursor.fetchall()
cursor.close()
cx1 = []
cx2 = []
cx3 = []
cx4 = []
cy = []
cx1, cx2, cx3, cx4, cy = zip(*rowset)

ax = plt.figure().add_subplot(111)
ax.scatter(cx1, cy, s=9, c='b', marker='o', label='number_of_small_reads')
ax.scatter(cx2, cy, s=9, c='r', marker='o', label='number_of_small_writes')
ax.scatter(cx3, cy, s=9, c='g', marker='o', label='number_of_large_reads')
ax.scatter(cx4, cy, s=9, c='y', marker='o', label='number_of_large_writes')
plt.legend(shadow=True)
plt.title('Python Generated Chart')
plt.xlabel('IOPS')
plt.ylabel('By Date')
plt.xlim(0)
plt.show()
conn.close()

1 Ответ

1 голос
/ 27 мая 2011

Вы можете просто выбрать час вместо даты.

SELECT .. DATEPART(mm, end_date) AS end_hour

http://www.bennadel.com/blog/172-Ask-Ben-Selecting-Parts-of-a-Date-Time-Stamp-In-SQL.htm

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