| « Поставить закладку » « Сделать стартовой » | |||
|
|||
|
Хранение изображений в базе данных
Для записи изображения в базу данных из файла, используется функция ReadBLOB. А для считывания изображения из базы данных в файл используется аналогичная функция WriteBLOB. Функция ReadBlob возвращает количество байт, записанных в базе данных. Source - файл рисунка который, будет записан в базе, T - таблица, или запрос в поле которого будет добавлен файл рисунка, sField - имя Поля, таблицы (Т), для записи данных (в поле с этим именем будет cделана запись). Кратко о работе функции: берётся файл, разбивается на блоки максимального размера (BlockSize = 32768), затем данные блоками считываются из файла и вставляются в OLE поле базы данных. Функция WriteBLOB работает также, но сначала данные блоками размера BlockSize, считываются из базы текущей записи и сохраняются в файле. Перейдём к коду: Option Explicit
Private Const BlockSize = 32768
Function ReadBLOB(Source As String, T As Recordset, sField As String)
Dim NumBlocks As Integer 'счётчик количества блоков
Dim SourceFile As Integer
Dim i As Integer
Dim FileLength As Long
Dim LeftOver As Long
Dim byteData() As Byte
On Error GoTo Err_ReadBLOB 'если ошибка, то надо перейти на обработчик ошибок
SourceFile = FreeFile
Open Source For Binary Access Read As SourceFile 'открытие файла
'получение длинны файла
FileLength = LOF(SourceFile)
If FileLength = 0 Then
ReadBLOB = 0
Exit Function
End If
'вычисление кол-во блоков, которые будут записаны в базу
NumBlocks = FileLength BlockSize
LeftOver = FileLength Mod BlockSize 'вычисляем остаток
If LeftOver > 0 Then 'если есть остаток, то запись из файла в базу
'данных с размером остатка
ReDim byteData(0 To LeftOver - 1) 'изменение массива для считывания данных
Get SourceFile, , byteData 'считывание данных из файла
'T.Edit
T(sField).AppendChunk (byteData) 'запись в базу
'T.Update
End If
'записываем данные блоками, размером BlockSize
ReDim byteData(0 To BlockSize - 1)
For i = 1 To NumBlocks 'считывание и запись в базу
Get SourceFile, , byteData 'считывание данных из файла
T(sField).AppendChunk (byteData) 'запись в базовое поле
Next i
Close SourceFile
ReadBLOB = FileLength 'возвращение функцией размер записанных данных
Exit Function
Err_ReadBLOB:
ReadBLOB = -Err 'возвращение номера ошибки
MsgBox Err.Description, , Err.Number 'если нужно - сообщение об ошибке
Exit Function
End Function
Function WriteBLOB(T As Recordset, sField As String, Destination As String)
Dim NumBlocks As Integer, DestFile As Integer, i As Integer
Dim FileLength As Long, LeftOver As Long
Dim byteData() As Byte
On Error GoTo Err_WriteBLOB
'размер записанных данных
FileLength = T(sField).FieldSize()
If FileLength = 0 Then
WriteBLOB = 0
Exit Function
End If
'вычисление количества блоков для записи
NumBlocks = FileLength BlockSize
LeftOver = FileLength Mod BlockSize
'очистка содержимого файла
DestFile = FreeFile
Open Destination For Output As DestFile
Close DestFile
'открытие файла
Open Destination For Binary As DestFile
'если есть остаток, то запись в файл данных из базы с размером остатка
If LeftOver > 0 Then
byteData() = T(sField).GetChunk(0, LeftOver)
Put DestFile, , byteData
End If
'запись в файл всех данных, которые остались блоками размером
' по BlockSize каждый
For i = 1 To NumBlocks
byteData() = T(sField).GetChunk((i - 1) * BlockSize + LeftOver, BlockSize)
Put DestFile, , byteData
Next i
Close DestFile
WriteBLOB = FileLength
Exit Function
Err_WriteBLOB:
WriteBLOB = -Err
MsgBox Err.Description, vbCritical, Err.Number
Exit Function
End Function
Источник: HiProg Рубрика: Visual Basic
HTML 5: пять вещей вызывающих особый интер....
HTML 5 — это грядущее обновление гипертекстового языка разметки, основного способа создания контента для размещения его во всемирной паутине. Разработка HTML остановилась в 1999 году, на версии HTML 4.01 и с тех пор web-содержимое изменилось так, что текущие спецификации HTML перестали соответствовать сегодняшним требованиям. HTML 5 нацелен на то, чтобы увеличить функциональную совместимость HTML и соответствовать растущим требованиям разнообразного и смешанного web-контента. HTML 5 так же нацелен на устранение недостатков четвертой версии. В этой статье мы взглянем на 5 новых интересных вещей в HTML 5.
Подробнее... |
Рубрика: Html
| Добавлено: 22.12.2008
asp.net: ListView с разных сторон.
Элемент управления ListView был представлен в .Net Framework 3.5 как замена устаревшему GridView. Новый элемент имеет более расширенный функционал, чем его предшественник, но в тоже время лишен некоторых внутренних механизмов, что впрочем целиком следствие из расширенной универсальности ListView. Среди отличий ListView и GridView можно назвать и гибкую настройку разметки, что позволяет выводить данные не только в табличном виде, но и вообще в любом каком пожелает программист. Благодаря шаблонам ItemTemplate, EditItemTemplate, InsertItemTeplate можно настроить внешний вид при любом из состояний ListView: редактировании или выборе элемента.
Подробнее... |
Рубрика: .NET компоненты
| Добавлено: 22.12.2008
Создание кросс-таб отчета в Stimulsoft Rep....
Компания Стимулсофт предоставляет для разработчиков мощный набор инструментов для создания отчетов для Microsoft Visual Studio .Net 2005 и 2008; эти инструменты доступны как для Windows Forms, так и для Web Forms. Это генератор отчетов Stimulsoft Reports.Net. Генератор отчетов Stimulsoft Reports.Net имеет ряд особенностей: простая работа с дизайнером отчетов, полная поддержка экспорта в PDF, Word, Excel и многие другие форматы. Crystal Report и Microsoft Reporting Service – очень хорошие программные продукты для повседневной работы, но, если Вам необходимо создать отчеты с поддержкой кросс-табов, drill down, Ajax, штрих-кодов и возможностью подключения одновременно более одного источника данных, то Stimulsoft Reports.Net поможет Вам сэкономить массу времени. Также, данный генератор отчетов позволяет пользователям создавать свои собственные отчеты любой сложности. И все эти особенности делают Stimulsoft Reports.Net хорошим выбором в сфере программных продуктов для Business Intelligence.
Подробнее... |
Рубрика: .NET компоненты
| Добавлено: 22.12.2008
Остальные статьи: |
Цитата дня (все,добавить):
|
Realcoding.NET
© 2003-2008 |
Контакты |
Реклама на сайте
|