вызов имени столбца в таблице при подключении через БД Oracle - PullRequest
0 голосов
/ 07 июня 2011

Я пытаюсь получить значение из таблицы (сотрудник), соединяющейся через база данных оракула. Поскольку в одном столбце есть сотни значений, мне нужно будет перебрать таблицу и получить точное значение.

У меня есть код, который работает, если я использую индекс №. такие как строка [1], но я хотел использовать column_name "имя" вместо строки [1]. Ниже код, который у меня есть, который работает. Код:

def load_borrower

connection = OCI8.new('usrname', 'pwd', //host:portno/sid') 

connection.exec(("SELECT BI_PREFIX, BI_FNAME, BI_MNAME, BI_LNAME, B.BI_SUFFIX, BI_ID_TYPE, BI_ID_NUMBER, BI_DOB,    B1.*, R.*, M.*, C.*, L.* FROM EMPLOYEE, SC_BORROWERPREF_NEW S1, BORROWER_NEW B, BORROWERPREF_NEW B1, RES_ADD R, MAIL_ADD M, CLOS_ADD C, LLORD_ADD L WHERE S2=SCENARIO_ID = S1.SCENARIO_ID AND S1.PREF_ID = B1.PREF_ID AND B1.BORROWER_ID = B.BORROWER_ID AND B1.PREF_ID = R.RES_PREF_ID AND B1.PREF_ID = M.MAIL_PREF_ID AND B1.PREF_ID = C.CLOS_PREF_ID AND B1.PREF_ID = L.LLORD_PREF_ID  AND S.RELEASE_ID= "1" AND S.SCENARIO_NO = '2' ORDER BY S1.SC_BORROWERPREF_ID") do |row|

$BI_PREFIX=row[0].to_s

$BI_FNAME=row[1].to_s

$BI_MNAME=row[2].to_s

$BI_LNAME=row[3].to_s

$BI_SUFFIX=row[4].to_s

$BI_BI_ID_TYPE=row[5].to_s

$BI_BI_ID_NUMBER=row[6].to_s

$BI_DOB=row[7].to_s

$BI_EMAIL=row[9].to_s

$BI_CELL_PH=row[11].to_s

$BI_WORK_PH=row[12].to_s

$BI_PREF_CONT=row[13].to_s

$BI_MAR_STATUS=row[16].to_s

$BI_EMP_STATUS=row[23].to_s

$BI_EDUC_YEARS=row[17].to_s

$BI_NUM_DEPEND=row[21].to_s

end

end

Теперь я запускаю указанные выше функции

load_borrower

Так что код выше прямо сейчас работает нормально. Но, как вы можете видеть из вышеизложенного, я определяю переменные из таблицы db как row [5], row [24] как то, что очень беспокойно и требует много времени, хотя и работает. Поэтому мне было просто интересно, есть ли у нас какой-либо метод или команда для использования column_name, чтобы оно получало значение из строки и столбца, такого как row ['Emp_id'], вместо того, чтобы найти индекс каждого столбца.

Я не уверен, является ли это недостатком Ruby, так как он обрабатывает таблицу из БД в виде массива, и, возможно, именно поэтому мы не можем указать с помощью column_name.

Ответы [ 3 ]

2 голосов
/ 08 июня 2011

Во-первых, кажется, вы немного смущены границами и разделением между различными частями технологии, которые вы используете. В указанном вами коде нет Watir, НЕТ. все это чистый Ruby и немного материала от OCI8 Gem. GEM - это стандартный способ, которым люди из Ruby используют для распространения библиотек кода и программ, написанных на языке Ruby. См. ЗДЕСЬ для получения дополнительной информации, чтобы лучше понять, что такое драгоценные камни и как они используются.

Watir - еще один гем Ruby, предназначенный для управления веб-браузерами, и вы можете использовать его в другом месте своего кода, но он не относится к этому вопросу или к OCI8, за исключением того, что оба они являются библиотеками кода Ruby, распространяемыми как Gems , Так что давайте оставим это в стороне, чтобы не путать вещи.

Поведение, которое вы видите, - это то, как работает гем OCI8, а НЕ какое-либо отношение к Ruby. Если вы хотите что-то более элегантное, посмотрите на другие гемы, созданные для доступа к БД с помощью Ruby, например ActiveRecord, который уже предлагался в другом ответе. Gem OCI8 возвращает массив, только если у вас есть результаты, поступающие в блок, как в текущем коде. В противном случае результаты находятся в объекте, называемом Курсором, и вы можете использовать метод fetch_hash курсора, чтобы получить извлеченные данные в виде хэша. Ключами хеша являются имена столбцов. (см. http://ruby -oci8.rubyforge.org / ru / api_OCI8Cursor.html )

Позвольте мне настоятельно рекомендовать потратить немного времени на изучение языка Ruby, прежде чем углубляться в свой текущий проект. Учитывая характер кодирования, который вы, похоже, делаете, я бы посоветовал вам прочитать книгу Брайана Марика "Повседневные сценарии с Ruby", которая поможет вам лучше понять технологию, которую вы используете, и вы поймете лучше, когда мы подбрасываем такие термины, как «хэш», как я только что сделал.

Если вы позволите немного общих советов относительно того, как вы собираетесь взаимодействовать с вашей базой данных. ИМХО, вы должны воспользоваться преимуществами базы данных, создав запрос, который возвращает просто нужные вам данные, вместо того, чтобы собирать огромные объемы данных и пытаться проанализировать их вручную. Лучше использовать ресурс, использовать меньше памяти, тратить меньше времени на передачу информации из БД, и, независимо от того, насколько хорошим может быть ваш код синтаксического анализа, он не будет так хорош, как написали люди из Oracle. Пусть БД делает тяжелую работу, вот для чего она.

Если здесь вы имеете дело с данными, необходимыми для тестирования или проверки результатов, а не для создания одного огромного монолитного массива, я бы порекомендовал вам использовать гораздо более модульный подход. Используйте одну глобальную переменную, такую ​​как EMP_ID текущего пользователя, с которым вы тестируете, с или против, и пусть тестовый код получит результаты запроса только для значений, необходимых для каждой проверки, или небольшую логическую группу проверок, например, части адреса. Гораздо проще создавать вещи таким образом, чтобы они работали по мере необходимости, вместо того, чтобы пытаться записать весь бит извлечения данных в один гигантский кусок, который будет кошмаром для обслуживания.

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

0 голосов
/ 12 декабря 2014

Это должно работать

connection = OCI8.new('usrname', 'pwd', //host:portno/sid') 

cursor = connection.exec(("SELECT BI_PREFIX ...")
cols = cursor.get_col_names

while r = cursor.fetch
  $BI_PREFIX=r[cols.index('BI_PREFIX')].to_s
  ...
end
0 голосов
/ 07 июня 2011

Если у вас есть массив, содержащий имена столбцов, вы можете сжать его с помощью массива строк и создать хэш:

Hash[column_names.zip( row )]

Я бы порекомендовал использовать для этого activerecord.

...