Анализирайте Apple plist с TSQL

Работя с база данни на SQL Server 2008, която съхранява Apple plists в колона. Търся бърз и мръсен начин да извлека част от тази информация.

Знам, че SQL Server може да прави XML анализиране. Тъй като plist не е истински XML, има ли нещо там, което може да ми помогне да заявя/манипулирам данните?

Като алтернатива, ако някой има препоръка за олекотена Java библиотека за анализиране на plist-овете, мога да тръгна и по този път.

<dict>
  <key>BundleSize</key>
  <integer>16138240</integer>
  <key>DynamicSize</key>
  <integer>7569408</integer>
  <key>Identifier</key>
  <string>com.ea.scrabble.ipad.inc2</string>
  <key>Name</key>
  <string>Scrabble</string>
  <key>Version</key>
  <string>1.15.73</string>
</dict>

person tbone14    schedule 15.06.2012    source източник
comment
Какъв DMBS използвате? В Oracle и SQL Server има някои собствени инструменти за анализиране на XML.   -  person N West    schedule 15.06.2012
comment
Може да ви даде известна представа - stackoverflow.com/a/9207497/763026   -  person Angshuman Agarwal    schedule 15.06.2012
comment
Какво ще кажете за plists не е ли истински XML? Стига да е добре оформен, можете да го поставите в XML колона и след това да използвате информацията, която вече сте посочили в основната част на вашия въпрос.   -  person bluevector    schedule 15.06.2012


Отговори (1)


Можете да използвате някои основни анализи на TSQL низове, ако просто трябва да изтеглите двойки ключ/стойност. Трябва да можете да превърнете кода по-долу във функция, която ще върне таблица с ключове/стойности/типове. Просто поставете този код и го стартирайте и ще видите какво имам предвид. Той ще върне таблица с колони [ID], [Key], [Value] и [ValueType]. Бързо е, ако преминете в един plist.

DECLARE @pList VARCHAR(255)
SET @pList = 
'<dict> 

<key>BundleSize</key> 
<integer>16138240</integer> 

<key>DynamicSize</key> 
<integer>7569408</integer> 

<key>Identifier</key> 
<string>com.ea.scrabble.ipad.inc2</string> 

<key>Name</key> 
<string>Scrabble</string> 

<key>Version</key> 
<string>1.15.73</string> 

</dict> 
'

DECLARE @IsKey BIT
DECLARE @ID INT
DECLARE @KeyValue TABLE (
    ID INT PRIMARY KEY IDENTITY(1,1) NOT NULL,
    [Key] VARCHAR(255) NOT NULL,
    [Value] VARCHAR(255) NULL,
    [ValueType] VARCHAR(255) NULL
    )

SET @IsKey = 1

WHILE LEN(@pList) > 10
BEGIN


    IF @IsKey = 1
    BEGIN

        -- Remove junk at the beginning of the string:
        SELECT @pList = SUBSTRING(@pList, CHARINDEX('<key>', @pList) + 5, LEN(@pList))

        -- Parse out the first value between the <key></key> tags:
        INSERT INTO @KeyValue ([Key])
            SELECT LEFT(@pList, CHARINDEX('</', @pList)-1)
        SELECT @ID = SCOPE_IDENTITY()

        -- Remove new junk at the beginning of the string:
        SELECT @pList = LTRIM(SUBSTRING(@pList, CHARINDEX(CHAR(13), @pList)+2, LEN(@pList)))

        SET @IsKey = 0

    END
    ELSE -- Is a value
    BEGIN

        -- Parse out the ValueType and Value:
        UPDATE @KeyValue
            SET ValueType = (SELECT SUBSTRING(@pList, 2, CHARINDEX('>', @pList)-2)),
            Value = (SELECT SUBSTRING(@pList, CHARINDEX('>', @pList)+1, CHARINDEX('</', @pList) - CHARINDEX('>', @pList)-1))
        WHERE ID = @ID

        -- Remove new junk at the beginning of the string:
        SELECT @pList = LTRIM(SUBSTRING(@pList, CHARINDEX(CHAR(13), @pList)+2, LEN(@pList)))

        SET @IsKey = 1

    END

END

SELECT *
FROM @KeyValue
person Russell Fox    schedule 15.06.2012