Чтение онлайн

ЖАНРЫ

Программирование на языке Ruby
Шрифт:

В классе

PGconn
определены также следующие полезные методы:

• 

db
возвращает имя базы, с которой установлено соединение;

• 

host
возвращает имя сервера, с которым установлено соединение;

• 

user
возвращает имя аутентифицированного пользователя;

• 

error
возвращает сообщение об ошибке;

• 

finish
,
close
закрывают соединение;

• 

loimport(file)
импортирует файл в большой двоичный объект (BLOB), в случае успеха возвращает объект
PGlarge
,
иначе возбуждает исключение
PGError
;

• 

loexport(oid, file)
выгружает BLOB с идентификатор
oid
в указанный файл;

• 

locreate([mode])
возвращает объект
PGlarge
в случае успеха, иначе возбуждает исключение
PGError
;

• 

loopen(oid, [mode])
открывает BLOB с идентификатором
oid
. Возвращает объект
PGlarge
в случае успеха. Аргумент
mode
задает режим работы с открытым объектом:
"INV_READ"
или
"INV_WRITE"
(если этот аргумент опущен, по умолчанию предполагается
"INV_READ"
);

• 

lounlink(oid)
удаляет BLOB с идентификатором
oid
.

Отметим, что пять последних методов (

loimport
,
loexport
,
locreate
,
loopen
и
lounlink
) работают с объектами класса
PGlarge
. У этого класса есть собственные методы для доступа к объекту и его изменения. (BLOB'ы создаются в результате выполнения методов
loimport
,
locreate
,
loopen
экземпляра.)

Ниже перечислены методы, определенные в классе

PGlarge
:

• 

open([mode])
открывает BLOB. Аргумент
mode
задает режим работы с объектом, как и в случае с методом
PGconn#loopen
);

• 

close
закрывает BLOB (BLOB'ы также закрываются автоматически, когда их обнаруживает сборщик мусора);

• 

read([length])
пытается прочитать
length
байтов из BLOB'a. Если параметр
length
не задан, читаются все данные;

• 

write(str)
записывает строку в BLOB и возвращает число записанных байтов;

• 

tell
возвращает текущую позицию указателя;

• 

seek(offset, whence)
перемещает указатель в позицию
offset
. Параметр
whence
может принимать значения
SEEK_SET
,
SEEK_CUR
и
SEEK_END
(равные соответственно 0,1,2);

• 

unlink
удаляет BLOB;

• 

oid
возвращает идентификатор BLOB'a;

• 

size
возвращает размер BLOB'a;

• 

export(file)
сохраняет BLOB в файле с указанным именем.

Более интересны методы экземпляра, определенные в классе

PGresult
(перечислены ниже). Объект такого класса возвращается в результате успешного выполнения запроса. (Для экономии памяти вызывайте метод
PGresult#clear
по завершении работы с таким объектом.)

• 

result
возвращает массив кортежей, описывающих результат запроса;

• 

each
итератор;

• 

[]
— метод доступа;

• 

fields
возвращает массив описаний полей результата запроса;

• 

num_tuples
возвращает число кортежей в результате запроса;

• 

fieldnum(name)
возвращает индекс поля с указанным именем;

• 

type(index)
возвращает целое число, соответствующее типу поля;

• 

size(index)
возвращает размер поля в байтах. 1 означает, что поле имеет переменную длину;

• 

getvalue(tup_num, field_num)
возвращает значение поля с указанным порядковым номером;
tup_num
— номер строки;

• 

getlength(tup_num, field_num)
возвращает длину поля в байтах;

• 

cmdstatus
возвращает строку состояния для последнего запроса;

• 

clear
очищает объект
PGresult
.

10.4.4. Интерфейс с LDAP

Для Ruby есть по меньшей мере три разных библиотеки, позволяющих работать с протоколом LDAP. Ruby/LDAP, написанная Такааки Татеиси (Takaaki Tateishi), — это довольно «тонкая» обертка. Если вы хорошо знакомы с LDAP, то ее может оказаться достаточно; в противном случае вы, наверное, сочтете ее слишком сложной. Пример:

conn = LDAP::Conn.new("rsads02.foo.com")

conn.bind("CN=username,CN=Users,DC=foo,DC=com", "password") do |bound|

 bound.search("DC=foo,DC=com", LDAP::LDAP_SCOPE_SUBTREE,

"(&(name=*) (objectCategory=person))", ['name','ipPhone'])

 do |user|

puts "#{user['name']} #{user['ipPhone']}"

 end

end

Библиотека

ActiveLDAP
организована по образцу
ActiveRecord
. Вот пример ее использования, взятый с домашней страницы:

require 'activeldap'

require 'examples/objects/user'

require 'password'

# Установить соединение Ruby/ActiveLDAP и т. д.

ActiveLDAP::Base.connect(:password_block

 => Proc.new { Password.get('Password: ') },

:allow_anonymous => false)

# Загрузить запись с данными о пользователе

# (ее класс определен в примерах).

wad = User.new('wad')

# Напечатать общее имя.

р wad.cn

# Изменить общее имя.

wad.cn = "Will"

# Сохранить в LDAP.

wad.write

Есть также сравнительно недавняя библиотека, написанная Фрэнсисом Чианфрокка (Francis Cianfrocca), многие предпочитают именно ее:

require 'net/ldap'

ldap = Net::LDAP.new :host => server_ip_address,

Поделиться с друзьями: