0

私は小さなテーブルを持っています:

CREATE TABLE [organization_division] (
[id] int IDENTITY (1, 1) NOT NULL PRIMARY KEY,
[uuid] binary(16) NOT NULL
)

SQL クエリを使用してレコードを挿入できます。

INSERT INTO [organization_division] ([uuid]) VALUES (0x244c71c6c9444f38b67ab1dcfbb5fc32)

このテーブルの Django モデルは次のとおりです。

from apps.lib.fields import GUIDField

class Division(models.Model):
    uuid = GUIDField() 

GUIDField は、カスタム フィールドを作成する私の試みです。

class GUIDField(models.Field):    
    description = "GUID binary field"
    __metaclass__ = models.SubfieldBase

    def __init__(self, *args, **kwargs):
        kwargs['max_length'] = 16
        super(GUIDField, self).__init__(*args, **kwargs)

    def db_type(self, connection):
        return 'binary(16)'

ORM インスタンスからデータベースに 16 バイトのバイナリ データを渡す必要があります。ほとんどの場合、引用符で囲まれていない文字列の後に SQL Server 側で0xを取得する必要があります...しかし、どのように?

私は unixodbc、pyodbc、django-odbc を使用しています。

4

1 に答える 1

0
from django.db import models
import pyodbc

class GUIDField(models.Field):    
    description = "GUID binary field"
    __metaclass__ = models.SubfieldBase

    def __init__(self, *args, **kwargs):
        kwargs['max_length'] = 16
        super(GUIDField, self).__init__(*args, **kwargs)

    def db_type(self, connection):
        return 'binary(16)'

    def get_db_prep_value(self, value):
        if value is None:
            return None
        return pyodbc.BINARY(value)
于 2012-08-23T00:05:53.023 に答える