Aracılığıyla paylaş


SQL Kullanarak Tabloya İkili Veri Ekleme

İkili veriler, INSERT INTO veya UPDATE SQL sorguları kullanılarak doğrudan tabloya eklenemez. Tabloya ikili veri eklemek için önce sorgudaki parametre işaretçisini (?) ikili değer için yer tutucu olarak kullanmanız gerekir. Sorgunun yürütülmesi, alanlarından birinde ikili verileri içeren bir kayıt içermelidir.

Gösterge, sorguyla gönderilen bir kayıtta sağlanan değere yapılan bir parametre referansıdır. SQL deyiminde bir soru işareti (?) ile gösterilir.

Aşağıdaki örnek kod bir tabloya ikili veri ekler.

#include <windows.h>
#include <Msiquery.h>
#include <tchar.h>
#pragma comment(lib, "msi.lib")


int main()  
{ 

PMSIHANDLE hDatabase = 0;
PMSIHANDLE hView = 0;
PMSIHANDLE hRec = 0;

if (ERROR_SUCCESS == MsiOpenDatabase(_T("c:\\temp\\testdb.msi"), MSIDBOPEN_TRANSACT, &hDatabase))
{
    //
    // Open view on Binary table so that we can add a new row, must use '?' to represent Binary data
    //

    if (ERROR_SUCCESS == MsiDatabaseOpenView(hDatabase, _T("INSERT INTO `Binary` (`Name`, `Data`) VALUES ('NewBlob', ?)"), &hView))
    {

        //
        // Create record with binary data in 1st field (must match up with '?' in query)
        //

        hRec = MsiCreateRecord(1);
        if (ERROR_SUCCESS == MsiRecordSetStream(hRec, 1, _T("c:\\temp\\data.bin")))
        {

            //
            // Execute view with record containing binary data value; commit database to save changes
            //

            if (ERROR_SUCCESS == MsiViewExecute(hView, hRec)
              && ERROR_SUCCESS == MsiViewClose(hView)
              && ERROR_SUCCESS == MsiDatabaseCommit(hDatabase))
            {
                //
                // New binary data successfully committed to the database
                //
            }
        }
    }
}

return 0;  
}

Aşağıdaki örnek komut dosyası bir tabloya ikili veri ekler.

Dim Installer
Dim Database
Dim View
Dim Record

Set Installer = CreateObject("WindowsInstaller.Installer")

Set Record = Installer.CreateRecord(1)
Record.SetStream 1, "c:\temp\data.bin"

Set Database = Installer.OpenDatabase("c:\temp\testdb.msi", msiOpenDatabaseModeTransact)
Set View = Database.OpenView("INSERT INTO `Binary` (`Name`, `Data`) VALUES ('NewBlob', ?)")
View.Execute Record
Database.Commit ' save changes

sorgularla çalışma

SQL Sözdizimi

SQL ve Betik Kullanan Veritabanı Sorgularının Örnekleri