当前位置: 首页>>代码示例>>C#>>正文


C# SQLiteConnection.Prepare方法代码示例

本文整理汇总了C#中SQLiteConnection.Prepare方法的典型用法代码示例。如果您正苦于以下问题:C# SQLiteConnection.Prepare方法的具体用法?C# SQLiteConnection.Prepare怎么用?C# SQLiteConnection.Prepare使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在SQLiteConnection的用法示例。


在下文中一共展示了SQLiteConnection.Prepare方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: TestPrepareValidStatement

 public void TestPrepareValidStatement()
 {
     using (var connection = new SQLiteConnection(this.databaseRelativePath))
     {
         using (var statement = connection.Prepare("CREATE TABLE IF NOT EXISTS t(x INTEGER, y TEXT);"))
         {
         }
     }
 }
开发者ID:matrostik,项目名称:SQLitePCL.Windows.SQLCipher,代码行数:9,代码来源:GeneralUnitTest.cs

示例2: TestPrepareInvalidStatement

 public void TestPrepareInvalidStatement()
 {
     Assert.ThrowsException<SQLiteException>(() =>
     {
         using (var connection = new SQLiteConnection(this.databaseRelativePath))
         {
             using (var statement = connection.Prepare("AN INVALID STATEMENT;"))
             {
             }
         }
     });
 }
开发者ID:matrostik,项目名称:SQLitePCL.Windows.SQLCipher,代码行数:12,代码来源:GeneralUnitTest.cs

示例3: TestDataType

        public void TestDataType()
        {
            using (var connection = new SQLiteConnection(this.databaseRelativePath))
            {
                using (var statement = connection.Prepare("DROP TABLE IF EXISTS TestDataType;"))
                {
                    statement.Step();
                }

                using (var statement = connection.Prepare("CREATE TABLE TestDataType(id INTEGER, i INTEGER, t TEXT, r REAL, b BLOB, n);"))
                {
                    statement.Step();
                }

                using (var statement = connection.Prepare("INSERT INTO TestDataType(id, i, t, r, b) VALUES(@id,@i,@t,@r,@b);"))
                {
                    statement.Bind(1, 0);
                    statement.Bind("@i", this.GetRandomInteger());
                    statement.Bind(3, this.GetRandomString());
                    statement.Bind("@r", this.GetRandomReal());
                    statement.Bind(5, this.GetRandomBlob());

                    statement.Step();

                    statement.Reset();
                    statement.ClearBindings();
                }

                using (var statement = connection.Prepare("SELECT id, i, t, r, b, n FROM TestDataType ORDER BY id ASC;"))
                {
                    statement.Step();

                    var integerType = statement.DataType(1);
                    var textType = statement.DataType(2);
                    var floatType = statement.DataType(3);
                    var blobType = statement.DataType(4);
                    var nullType = statement.DataType(5);

                    Assert.AreEqual(SQLiteType.INTEGER, integerType);
                    Assert.AreEqual(SQLiteType.TEXT, textType);
                    Assert.AreEqual(SQLiteType.FLOAT, floatType);
                    Assert.AreEqual(SQLiteType.BLOB, blobType);
                    Assert.AreEqual(SQLiteType.NULL, nullType);
                }

                using (var statement = connection.Prepare("DROP TABLE TestDataType;"))
                {
                    statement.Step();
                }
            }
        }
开发者ID:matrostik,项目名称:SQLitePCL.Windows.SQLCipher,代码行数:51,代码来源:GeneralUnitTest.cs

示例4: TestLastInsertRowId

        public void TestLastInsertRowId()
        {
            using (var connection = new SQLiteConnection(this.databaseRelativePath))
            {
                using (var statement = connection.Prepare("DROP TABLE IF EXISTS TestLastInsertedRowId;"))
                {
                    statement.Step();
                }

                using (var statement = connection.Prepare("CREATE TABLE TestLastInsertedRowId (id INTEGER PRIMARY KEY AUTOINCREMENT, desc TEXT);"))
                {
                    statement.Step();
                }

                using (var statement = connection.Prepare("INSERT INTO TestLastInsertedRowId (desc) VALUES (@desc);"))
                {
                    statement.Bind("@desc", "Desc 1");

                    statement.Step();

                    statement.Reset();
                    statement.ClearBindings();
                }

                var lastId = connection.LastInsertRowId();

                Assert.AreEqual(1, lastId);

                using (var statement = connection.Prepare("DROP TABLE TestLastInsertedRowId;"))
                {
                    statement.Step();
                }
            }
        }
开发者ID:matrostik,项目名称:SQLitePCL.Windows.SQLCipher,代码行数:34,代码来源:GeneralUnitTest.cs

示例5: TestColumnDataCount

        public void TestColumnDataCount()
        {
            using (var connection = new SQLiteConnection(this.databaseRelativePath))
            {
                using (var statement = connection.Prepare("DROP TABLE IF EXISTS TestColumnDataCount;"))
                {
                    statement.Step();
                }

                using (var statement = connection.Prepare("CREATE TABLE TestColumnDataCount(id INTEGER, desc TEXT);"))
                {
                    statement.Step();
                }

                using (var statement = connection.Prepare("INSERT INTO TestColumnDataCount(id, desc) VALUES(@id,@desc);"))
                {
                    statement.Bind(1, 1);
                    statement.Bind("@desc", "Desc 1");

                    statement.Step();

                    statement.Reset();
                    statement.ClearBindings();
                }

                using (var statement = connection.Prepare("SELECT id, desc AS desc FROM TestColumnDataCount ORDER BY id ASC;"))
                {
                    var columnCount = statement.ColumnCount;
                    var dataCount = statement.DataCount;

                    Assert.AreEqual(2, columnCount);
                    Assert.AreEqual(0, dataCount);

                    statement.Step();

                    columnCount = statement.ColumnCount;
                    dataCount = statement.DataCount;

                    Assert.AreEqual(2, columnCount);
                    Assert.AreEqual(2, dataCount);

                    statement.Step();

                    columnCount = statement.ColumnCount;
                    dataCount = statement.DataCount;

                    Assert.AreEqual(2, columnCount);
                    Assert.AreEqual(0, dataCount);
                }

                using (var statement = connection.Prepare("DROP TABLE TestColumnDataCount;"))
                {
                    statement.Step();
                }
            }
        }
开发者ID:matrostik,项目名称:SQLitePCL.Windows.SQLCipher,代码行数:56,代码来源:GeneralUnitTest.cs

示例6: TestColumnSameName

        public void TestColumnSameName()
        {
            using (var connection = new SQLiteConnection(this.databaseRelativePath))
            {
                using (var statement = connection.Prepare("DROP TABLE IF EXISTS TestColumnSameName;"))
                {
                    statement.Step();
                }

                using (var statement = connection.Prepare("CREATE TABLE TestColumnSameName(id INTEGER, desc TEXT);"))
                {
                    statement.Step();
                }

                using (var statement = connection.Prepare("SELECT id, desc AS descrip, desc, desc, SUM(id), desc \"some name\", desc \"sOmE NaMe\" FROM TestColumnSameName ORDER BY id ASC;"))
                {
                    var col0 = statement.ColumnName(0);
                    var col1 = statement.ColumnName(1);
                    var index2 = statement.ColumnIndex("desc");
                    var col3 = statement.ColumnName(3);
                    var col4 = statement.ColumnName(4);
                    var index5 = statement.ColumnIndex("some name");
                    var index6 = statement.ColumnIndex("sOmE NaMe");

                    Assert.AreEqual(col0, "id");
                    Assert.AreEqual(col1, "descrip");
                    Assert.AreEqual(index2, 2);
                    Assert.AreEqual(col3, "desc");
                    Assert.AreEqual(col4, "SUM(id)");
                    Assert.AreEqual(index5, 5);
                    Assert.AreEqual(index6, 6);
                }

                using (var statement = connection.Prepare("DROP TABLE TestColumnSameName;"))
                {
                    statement.Step();
                }
            }
        }
开发者ID:matrostik,项目名称:SQLitePCL.Windows.SQLCipher,代码行数:39,代码来源:GeneralUnitTest.cs

示例7: TestBindPrimitiveTypes

        public void TestBindPrimitiveTypes()
        {
            var numRecords = this.rnd.Next(1, 11);

            var insertedRecords = new List<Tuple<int, byte, sbyte, short, ushort, int, uint, Tuple<long, ulong, char, string, decimal, float, double>>>(numRecords);
            var queriedRecords = new List<Tuple<int, byte, sbyte, short, ushort, int, uint, Tuple<long, ulong, char, string, decimal, float, double>>>(numRecords);

            for (var i = 0; i < numRecords; i++)
            {
                insertedRecords.Add(new Tuple<int, byte, sbyte, short, ushort, int, uint, Tuple<long, ulong, char, string, decimal, float, double>>(
                    i,
                    (byte)this.GetRandomInteger(),
                    (sbyte)this.GetRandomInteger(),
                    (short)this.GetRandomInteger(),
                    (ushort)this.GetRandomInteger(),
                    (int)this.GetRandomInteger(),
                    (uint)this.GetRandomInteger(),
                    new Tuple<long, ulong, char, string, decimal, float, double>(
                        this.GetRandomInteger(),
                        (ulong)Math.Abs(this.GetRandomInteger()),
                        this.GetRandomString()[0],
                        this.GetRandomString(),
                        (decimal)this.GetRandomReal(),
                        (float)this.GetRandomReal(),
                        this.GetRandomReal())));
            }

            using (var connection = new SQLiteConnection(this.databaseRelativePath))
            {
                using (var statement = connection.Prepare("DROP TABLE IF EXISTS TestBindPrimitiveTypes;"))
                {
                    statement.Step();
                }

                using (var statement = connection.Prepare("CREATE TABLE TestBindPrimitiveTypes(id INTEGER, b INTEGER, sb INTEGER, s INTEGER, us INTEGER, i INTEGER, ui INTEGER, l INTEGER, ul INTEGER, c TEXT, st TEXT, m REAL, f REAL, d REAL);"))
                {
                    statement.Step();
                }

                using (var statement = connection.Prepare("INSERT INTO TestBindPrimitiveTypes(id, b, sb, s, us, i, ui, l, ul, c, st, m, f, d) VALUES(@id,@b,@sb,@s,@us,@i,@ui,@l,@ul,@c,@st,@m,@f,@d);"))
                {
                    foreach (var record in insertedRecords)
                    {
                        statement.Bind("@id", record.Item1);
                        statement.Bind("@b", record.Item2);
                        statement.Bind("@sb", record.Item3);
                        statement.Bind("@s", record.Item4);
                        statement.Bind("@us", record.Item5);
                        statement.Bind("@i", record.Item6);
                        statement.Bind("@ui", record.Item7);
                        statement.Bind("@l", record.Rest.Item1);
                        statement.Bind("@ul", record.Rest.Item2);
                        statement.Bind("@c", record.Rest.Item3);
                        statement.Bind("@st", record.Rest.Item4);
                        statement.Bind("@m", record.Rest.Item5);
                        statement.Bind("@f", record.Rest.Item6);
                        statement.Bind("@d", record.Rest.Item7);

                        statement.Step();

                        statement.Reset();
                        statement.ClearBindings();
                    }
                }

                using (var statement = connection.Prepare("SELECT id, b, sb, s, us, i, ui, l, ul, c, st, m, f, d FROM TestBindPrimitiveTypes ORDER BY id ASC;"))
                {
                    while (statement.Step() == SQLiteResult.ROW)
                    {
                        var id = (int)statement.GetInteger("id");
                        var b = (byte)statement.GetInteger("b");
                        var sb = (sbyte)statement.GetInteger("sb");
                        var s = (short)statement.GetInteger("s");
                        var us = (ushort)statement.GetInteger("us");
                        var i = (int)statement.GetInteger("i");
                        var ui = (uint)statement.GetInteger("ui");
                        var l = statement.GetInteger("l");
                        var ul = (ulong)statement.GetInteger("ul");
                        var c = statement.GetText("c")[0];
                        var st = statement.GetText("st");
                        var m = (decimal)statement.GetFloat("m");
                        var f = (float)statement.GetFloat("f");
                        var d = statement.GetFloat("d");

                        queriedRecords.Add(new Tuple<int, byte, sbyte, short, ushort, int, uint, Tuple<long, ulong, char, string, decimal, float, double>>(
                    id,
                    b,
                    sb,
                    s,
                    us,
                    i,
                    ui,
                    new Tuple<long, ulong, char, string, decimal, float, double>(
                        l,
                        ul,
                        c,
                        st,
                        m,
                        f,
                        d)));
//.........这里部分代码省略.........
开发者ID:matrostik,项目名称:SQLitePCL.Windows.SQLCipher,代码行数:101,代码来源:GeneralUnitTest.cs

示例8: TestAggregate

        public void TestAggregate()
        {
            using (var connection = new SQLiteConnection(this.databaseRelativePath))
            {
                connection.CreateAggregate(
                    "CUSTOMAGGSUM",
                    1,
                    new AggregateStep((aggregateContextData, arguments) =>
                    {
                        aggregateContextData["Acum"] = aggregateContextData.ContainsKey("Acum") ? (long)arguments[0] + (long)aggregateContextData["Acum"] : (long)arguments[0];
                    }),
                    new AggregateFinal((aggregateContextData) =>
                    {
                        return aggregateContextData.ContainsKey("Acum") ? (long)aggregateContextData["Acum"] : 0L;
                    }));

                using (var statement = connection.Prepare("DROP TABLE IF EXISTS TestAggregate;"))
                {
                    statement.Step();
                }

                using (var statement = connection.Prepare("CREATE TABLE TestAggregate(id INTEGER);"))
                {
                    statement.Step();
                }

                using (var statement = connection.Prepare("INSERT INTO TestAggregate(id) VALUES(@id);"))
                {
                    for (var value = 0; value < 10; value++)
                    {
                        statement.Bind(1, value);

                        statement.Step();

                        statement.Reset();
                        statement.ClearBindings();
                    }
                }

                using (var statement = connection.Prepare("SELECT CUSTOMAGGSUM(id) AS CustomResult FROM TestAggregate;"))
                {
                    var rowTotal = 0;
                    while (statement.Step() == SQLiteResult.ROW)
                    {
                        rowTotal++;

                        var totalSum = (long)statement[0];

                        Assert.AreEqual(45, totalSum);
                    }

                    Assert.AreEqual(1, rowTotal);
                }

                using (var statement = connection.Prepare("DROP TABLE TestAggregate;"))
                {
                    statement.Step();
                }
            }
        }
开发者ID:matrostik,项目名称:SQLitePCL.Windows.SQLCipher,代码行数:60,代码来源:GeneralUnitTest.cs

示例9: TestReadOnlyDB

        public void TestReadOnlyDB()
        {
            Exception exception = null;
            var numRecords = this.rnd.Next(1, 11);

            var insertedRecords = new List<Tuple<int, long, string, double>>(numRecords);
            var queriedRecords = new List<Tuple<int, long, string, double>>(numRecords);

            for (var i = 0; i < numRecords; i++)
            {
                insertedRecords.Add(new Tuple<int, long, string, double>(i, this.GetRandomInteger(), this.GetRandomString(), this.GetRandomReal()));
            }

            using (var connection = new SQLiteConnection(this.databaseRelativePath, SQLiteOpen.READWRITE))
            {
                using (var statement = connection.Prepare("DROP TABLE IF EXISTS TestReadOnlyDB;"))
                {
                    statement.Step();
                }

                using (var statement = connection.Prepare("CREATE TABLE TestReadOnlyDB(id INTEGER, i INTEGER, t TEXT, r REAL);"))
                {
                    statement.Step();
                }

                foreach (var record in insertedRecords)
                {
                    var command = "INSERT INTO TestReadOnlyDB(id, i, t, r) VALUES(" + record.Item1.ToString(this.invClt) + "," + record.Item2.ToString(this.invClt)
                        + ",'" + record.Item3 + "'," + record.Item4.ToString(this.invClt) + ");";

                    using (var statement = connection.Prepare(command))
                    {
                        statement.Step();
                    }
                }
            }

            using (var connection = new SQLiteConnection(this.databaseRelativePath, SQLiteOpen.READONLY))
            {
                foreach (var record in insertedRecords)
                {
                    var command = "SELECT id, i, t, r FROM TestReadOnlyDB WHERE id = " + record.Item1.ToString(this.invClt) + " AND i = " + record.Item2.ToString(this.invClt)
                        + " AND t = '" + record.Item3 + "' AND r = " + record.Item4.ToString(this.invClt) + ";";

                    using (var statement = connection.Prepare(command))
                    {
                        while (statement.Step() == SQLiteResult.ROW)
                        {
                            var id = (long)statement[0];
                            var i = (long)statement[1];
                            var t = (string)statement[2];
                            var r = (double)statement[3];

                            queriedRecords.Add(new Tuple<int, long, string, double>((int)id, i, t, r));
                        }
                    }
                }

                using (var statement = connection.Prepare("DROP TABLE TestReadOnlyDB;"))
                {
                    var result = statement.Step();

                    if (result == SQLiteResult.READONLY)
                    {
                        exception = new SQLiteException(connection.ErrorMessage());
                    }
                    else
                    {
                        throw new SQLiteException(connection.ErrorMessage());
                    }
                }
            }

            using (var connection = new SQLiteConnection(this.databaseRelativePath, SQLiteOpen.READWRITE))
            {
                using (var statement = connection.Prepare("DROP TABLE TestReadOnlyDB;"))
                {
                    var result = statement.Step();

                    if (result != SQLiteResult.DONE)
                    {
                        throw new SQLiteException(connection.ErrorMessage());
                    }
                }
            }

            Assert.AreEqual(insertedRecords.Count, queriedRecords.Count);

            insertedRecords.Sort((x, y) => { return x.Item1 - y.Item1; });
            queriedRecords.Sort((x, y) => { return x.Item1 - y.Item1; });

            for (var i = 0; i < insertedRecords.Count; i++)
            {
                var insertedRecord = insertedRecords[i];
                var queriedRecord = queriedRecords[i];

                Assert.AreEqual(insertedRecord.Item1, queriedRecord.Item1);
                Assert.AreEqual(insertedRecord.Item2, queriedRecord.Item2);
                Assert.AreEqual(insertedRecord.Item3, queriedRecord.Item3);
                Assert.IsTrue(Math.Abs(insertedRecord.Item4 - queriedRecord.Item4) <= Math.Abs(insertedRecord.Item4 * 0.0000001));
//.........这里部分代码省略.........
开发者ID:matrostik,项目名称:SQLitePCL.Windows.SQLCipher,代码行数:101,代码来源:GeneralUnitTest.cs

示例10: TestInMemory

        public void TestInMemory()
        {
            var numRecords = this.rnd.Next(1, 11);

            var insertedRecords = new List<Tuple<int, long, string, double>>(numRecords);
            var queriedRecords = new List<Tuple<int, long, string, double>>(numRecords);

            for (var i = 0; i < numRecords; i++)
            {
                insertedRecords.Add(new Tuple<int, long, string, double>(i, this.GetRandomInteger(), this.GetRandomString(), this.GetRandomReal()));
            }

            using (var connection = new SQLiteConnection(":memory:"))
            {
                using (var statement = connection.Prepare("DROP TABLE IF EXISTS TestInMemory;"))
                {
                    statement.Step();
                }

                using (var statement = connection.Prepare("CREATE TABLE TestInMemory(id INTEGER, i INTEGER, t TEXT, r REAL);"))
                {
                    statement.Step();
                }

                foreach (var record in insertedRecords)
                {
                    var command = "INSERT INTO TestInMemory(id, i, t, r) VALUES(" + record.Item1.ToString(this.invClt) + "," + record.Item2.ToString(this.invClt)
                        + ",'" + record.Item3 + "'," + record.Item4.ToString(this.invClt) + ");";

                    using (var statement = connection.Prepare(command))
                    {
                        statement.Step();
                    }
                }

                foreach (var record in insertedRecords)
                {
                    var command = "SELECT id, i, t, r FROM TestInMemory WHERE id = " + record.Item1.ToString(this.invClt) + " AND i = " + record.Item2.ToString(this.invClt)
                        + " AND t = '" + record.Item3 + "' AND r = " + record.Item4.ToString(this.invClt) + ";";

                    using (var statement = connection.Prepare(command))
                    {
                        while (statement.Step() == SQLiteResult.ROW)
                        {
                            var id = (long)statement[0];
                            var i = (long)statement[1];
                            var t = (string)statement[2];
                            var r = (double)statement[3];

                            queriedRecords.Add(new Tuple<int, long, string, double>((int)id, i, t, r));
                        }
                    }
                }

                using (var statement = connection.Prepare("DROP TABLE TestInMemory;"))
                {
                    statement.Step();
                }
            }

            Assert.AreEqual(insertedRecords.Count, queriedRecords.Count);

            insertedRecords.Sort((x, y) => { return x.Item1 - y.Item1; });
            queriedRecords.Sort((x, y) => { return x.Item1 - y.Item1; });

            for (var i = 0; i < insertedRecords.Count; i++)
            {
                var insertedRecord = insertedRecords[i];
                var queriedRecord = queriedRecords[i];

                Assert.AreEqual(insertedRecord.Item1, queriedRecord.Item1);
                Assert.AreEqual(insertedRecord.Item2, queriedRecord.Item2);
                Assert.AreEqual(insertedRecord.Item3, queriedRecord.Item3);
                Assert.IsTrue(Math.Abs(insertedRecord.Item4 - queriedRecord.Item4) <= Math.Abs(insertedRecord.Item4 * 0.0000001));
            }
        }
开发者ID:matrostik,项目名称:SQLitePCL.Windows.SQLCipher,代码行数:76,代码来源:GeneralUnitTest.cs

示例11: TestTransactionRollbackSupport

        public void TestTransactionRollbackSupport()
        {
            var numRecords = this.rnd.Next(1, 11);

            var insertedRecords = new List<Tuple<int, long, string, double>>(numRecords);
            var queriedRecords = 0;

            for (var i = 0; i < numRecords; i++)
            {
                insertedRecords.Add(new Tuple<int, long, string, double>(i, this.GetRandomInteger(), this.GetRandomString(), this.GetRandomReal()));
            }

            using (var connection = new SQLiteConnection(this.databaseRelativePath))
            {
                using (var statement = connection.Prepare("DROP TABLE IF EXISTS TestQuery;"))
                {
                    statement.Step();
                }

                using (var statement = connection.Prepare("CREATE TABLE TestQuery(id INTEGER, i INTEGER, t TEXT, r REAL);"))
                {
                    statement.Step();
                }

                var beginTransactionCommand = "BEGIN TRANSACTION";

                using (var statement = connection.Prepare(beginTransactionCommand))
                {
                    statement.Step();
                }

                foreach (var record in insertedRecords)
                {
                    var command = "INSERT INTO TestQuery(id, i, t, r) VALUES(" + record.Item1.ToString(this.invClt) + "," + record.Item2.ToString(this.invClt)
                        + ",'" + record.Item3 + "'," + record.Item4.ToString(this.invClt) + ");";

                    using (var statement = connection.Prepare(command))
                    {
                        statement.Step();
                    }
                }

                var rollbackTransactionCommand = "ROLLBACK TRANSACTION";

                using (var statement = connection.Prepare(rollbackTransactionCommand))
                {
                    statement.Step();
                }

                foreach (var record in insertedRecords)
                {
                    var command = "SELECT id, i, t, r FROM TestQuery WHERE id = " + record.Item1.ToString(this.invClt) + " AND i = " + record.Item2.ToString(this.invClt)
                        + " AND t = '" + record.Item3 + "' AND r = " + record.Item4.ToString(this.invClt) + ";";

                    using (var statement = connection.Prepare(command))
                    {
                        while (statement.Step() == SQLiteResult.ROW)
                        {
                            queriedRecords++;
                        }
                    }
                }

                using (var statement = connection.Prepare("DROP TABLE TestQuery;"))
                {
                    statement.Step();
                }
            }

            Assert.AreEqual(0, queriedRecords);
        }
开发者ID:matrostik,项目名称:SQLitePCL.Windows.SQLCipher,代码行数:71,代码来源:GeneralUnitTest.cs

示例12: TestChangesCount

        public void TestChangesCount()
        {
            var initialChangesCount = 0;
            var insertChangesCount = 0;

            var numRecords = this.rnd.Next(1, 11);

            var insertedRecords = new List<Tuple<int, long, string, double>>(numRecords);

            for (var i = 0; i < numRecords; i++)
            {
                insertedRecords.Add(new Tuple<int, long, string, double>(i, this.GetRandomInteger(), this.GetRandomString(), this.GetRandomReal()));
            }

            using (var connection = new SQLiteConnection(this.databaseRelativePath))
            {
                using (var statement = connection.Prepare("DROP TABLE IF EXISTS TestQuery;"))
                {
                    statement.Step();
                }

                using (var statement = connection.Prepare("CREATE TABLE TestQuery(id INTEGER, i INTEGER, t TEXT, r REAL);"))
                {
                    statement.Step();
                }

                initialChangesCount = connection.ChangesCount();

                foreach (var record in insertedRecords)
                {
                    var command = "INSERT INTO TestQuery(id, i, t, r) VALUES(" + record.Item1.ToString(this.invClt) + "," + record.Item2.ToString(this.invClt)
                        + ",'" + record.Item3 + "'," + record.Item4.ToString(this.invClt) + ");";

                    using (var statement = connection.Prepare(command))
                    {
                        statement.Step();
                    }

                    insertChangesCount += connection.ChangesCount();
                }

                using (var statement = connection.Prepare("DROP TABLE TestQuery;"))
                {
                    statement.Step();
                }
            }

            Assert.AreEqual(0, initialChangesCount);
            Assert.AreEqual(insertedRecords.Count, insertChangesCount);
        }
开发者ID:matrostik,项目名称:SQLitePCL.Windows.SQLCipher,代码行数:50,代码来源:GeneralUnitTest.cs

示例13: TestEmptyBlob

        public void TestEmptyBlob()
        {
            using (var connection = new SQLiteConnection(this.databaseRelativePath))
            {
                using (var statement = connection.Prepare("DROP TABLE IF EXISTS TestEmptyBlob;"))
                {
                    statement.Step();
                }

                using (var statement = connection.Prepare("CREATE TABLE TestEmptyBlob(b BLOB);"))
                {
                    statement.Step();
                }

                using (var statement = connection.Prepare("INSERT INTO TestEmptyBlob(b) VALUES(@b);"))
                {
                    statement.Bind("@b", this.GetRandomBlob(0));

                    statement.Step();

                    statement.Reset();
                    statement.ClearBindings();
                }

                using (var statement = connection.Prepare("SELECT b FROM TestEmptyBlob;"))
                {
                    statement.Step();

                    var emptyBlobValue = statement.GetBlob(0);

                    Assert.IsNotNull(emptyBlobValue);
                    Assert.AreEqual(0, emptyBlobValue.Length);
                }

                using (var statement = connection.Prepare("DROP TABLE TestEmptyBlob;"))
                {
                    statement.Step();
                }
            }
        }
开发者ID:matrostik,项目名称:SQLitePCL.Windows.SQLCipher,代码行数:40,代码来源:GeneralUnitTest.cs

示例14: TestConstantInsertParameterBoundQueryFilter

        public void TestConstantInsertParameterBoundQueryFilter()
        {
            var numRecords = this.rnd.Next(1, 11);

            var insertedRecords = new List<Tuple<int, long, string, double>>(numRecords);
            var queriedRecords = new List<Tuple<int, long, string, double>>(numRecords);

            for (var i = 0; i < numRecords; i++)
            {
                insertedRecords.Add(new Tuple<int, long, string, double>(i, this.GetRandomInteger(), this.GetRandomString(), this.GetRandomReal()));
            }

            using (var connection = new SQLiteConnection(this.databaseRelativePath))
            {
                using (var statement = connection.Prepare("DROP TABLE IF EXISTS TestConstantInsertParameterBoundQueryFilter;"))
                {
                    statement.Step();
                }

                using (var statement = connection.Prepare("CREATE TABLE TestConstantInsertParameterBoundQueryFilter(id INTEGER, i INTEGER, t TEXT, r REAL);"))
                {
                    statement.Step();
                }

                foreach (var record in insertedRecords)
                {
                    var command = "INSERT INTO TestConstantInsertParameterBoundQueryFilter(id, i, t, r) VALUES(" + record.Item1.ToString(this.invClt) + "," + record.Item2.ToString(this.invClt)
                        + ",'" + record.Item3 + "'," + record.Item4.ToString(this.invClt) + ");";

                    using (var statement = connection.Prepare(command))
                    {
                        statement.Step();
                    }
                }

                using (var statement = connection.Prepare("SELECT id, i, t, r FROM TestConstantInsertParameterBoundQueryFilter WHERE id = @id AND i = @i AND t = @t;"))
                {
                    foreach (var record in insertedRecords)
                    {
                        statement.Bind(1, record.Item1);
                        statement.Bind("@i", record.Item2);
                        statement.Bind(3, record.Item3);

                        while (statement.Step() == SQLiteResult.ROW)
                        {
                            var id = (long)statement[0];
                            var i = (long)statement[1];
                            var t = (string)statement[2];
                            var r = (double)statement[3];

                            queriedRecords.Add(new Tuple<int, long, string, double>((int)id, i, t, r));
                        }

                        statement.Reset();
                        statement.ClearBindings();
                    }
                }

                using (var statement = connection.Prepare("DROP TABLE TestConstantInsertParameterBoundQueryFilter;"))
                {
                    statement.Step();
                }
            }

            Assert.AreEqual(insertedRecords.Count, queriedRecords.Count);

            insertedRecords.Sort((x, y) => { return x.Item1 - y.Item1; });
            queriedRecords.Sort((x, y) => { return x.Item1 - y.Item1; });

            for (var i = 0; i < insertedRecords.Count; i++)
            {
                var insertedRecord = insertedRecords[i];
                var queriedRecord = queriedRecords[i];

                Assert.AreEqual(insertedRecord.Item1, queriedRecord.Item1);
                Assert.AreEqual(insertedRecord.Item2, queriedRecord.Item2);
                Assert.AreEqual(insertedRecord.Item3, queriedRecord.Item3);
                Assert.IsTrue(Math.Abs(insertedRecord.Item4 - queriedRecord.Item4) <= Math.Abs(insertedRecord.Item4 * 0.0000001));
            }
        }
开发者ID:matrostik,项目名称:SQLitePCL.Windows.SQLCipher,代码行数:80,代码来源:GeneralUnitTest.cs

示例15: TestBindParameterFilter

        public void TestBindParameterFilter()
        {
            var numRecords = this.rnd.Next(1, 11);

            var insertedRecords = new List<Tuple<int, long, string, double, byte[]>>(numRecords);
            var queriedRecords = new List<Tuple<int, long, string, double, byte[]>>(numRecords);

            for (var i = 0; i < numRecords; i++)
            {
                insertedRecords.Add(new Tuple<int, long, string, double, byte[]>(i, this.GetRandomInteger(), this.GetRandomString(), this.GetRandomReal(), this.GetRandomBlob()));
            }

            using (var connection = new SQLiteConnection(this.databaseRelativePath))
            {
                using (var statement = connection.Prepare("DROP TABLE IF EXISTS TestBindParameterFilter;"))
                {
                    statement.Step();
                }

                using (var statement = connection.Prepare("CREATE TABLE TestBindParameterFilter(id INTEGER, i INTEGER, t TEXT, r REAL, b BLOB);"))
                {
                    statement.Step();
                }

                using (var statement = connection.Prepare("INSERT INTO TestBindParameterFilter(id, i, t, r, b) VALUES(@id,@i,@t,@r,@b);"))
                {
                    foreach (var record in insertedRecords)
                    {
                        statement.Bind(1, record.Item1);
                        statement.Bind("@i", record.Item2);
                        statement.Bind(3, record.Item3);
                        statement.Bind("@r", record.Item4);
                        statement.Bind(5, record.Item5);

                        statement.Step();

                        statement.Reset();
                        statement.ClearBindings();
                    }
                }

                using (var statement = connection.Prepare("SELECT id, i, t, r, b FROM TestBindParameterFilter WHERE id = @id AND i = @i AND t = @t AND r = @r AND b = @b;"))
                {
                    foreach (var record in insertedRecords)
                    {
                        statement.Bind(1, record.Item1);
                        statement.Bind("@i", record.Item2);
                        statement.Bind(3, record.Item3);
                        statement.Bind("@r", record.Item4);
                        statement.Bind(5, record.Item5);

                        while (statement.Step() == SQLiteResult.ROW)
                        {
                            var id = (long)statement[0];
                            var i = (long)statement[1];
                            var t = (string)statement[2];
                            var r = (double)statement[3];
                            var b = (byte[])statement[4];

                            queriedRecords.Add(new Tuple<int, long, string, double, byte[]>((int)id, i, t, r, b));
                        }

                        statement.Reset();
                        statement.ClearBindings();
                    }
                }

                using (var statement = connection.Prepare("DROP TABLE TestBindParameterFilter;"))
                {
                    statement.Step();
                }
            }

            Assert.AreEqual(insertedRecords.Count, queriedRecords.Count);

            insertedRecords.Sort((x, y) => { return x.Item1 - y.Item1; });
            queriedRecords.Sort((x, y) => { return x.Item1 - y.Item1; });

            for (var i = 0; i < insertedRecords.Count; i++)
            {
                var insertedRecord = insertedRecords[i];
                var queriedRecord = queriedRecords[i];

                Assert.AreEqual(insertedRecord.Item1, queriedRecord.Item1);
                Assert.AreEqual(insertedRecord.Item2, queriedRecord.Item2);
                Assert.AreEqual(insertedRecord.Item3, queriedRecord.Item3);
                Assert.IsTrue(Math.Abs(insertedRecord.Item4 - queriedRecord.Item4) <= Math.Abs(insertedRecord.Item4 * 0.0000001));
                Assert.IsTrue(insertedRecord.Item5.SequenceEqual(queriedRecord.Item5));
            }
        }
开发者ID:matrostik,项目名称:SQLitePCL.Windows.SQLCipher,代码行数:90,代码来源:GeneralUnitTest.cs


注:本文中的SQLiteConnection.Prepare方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。