Простое приложение Linq to SQLIte зависает на SubmitChanges()
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data.SQLite;
using System.Data.Linq.Mapping;
using DbLinq.Data.Linq;
namespace LinqToSQLite
{
class Program
{
static void Main(string[] args)
{
string connectionString = "DbLinqProvider=Sqlite;Data Source=db2.sqlite";
DataContext db = new DataContext(connectionString);
db.ExecuteCommand(Person.CreateCommand);
Table<Person> table = db.GetTable<Person>();
table.InsertOnSubmit(new Person { Name = "Alfred" });
table.InsertOnSubmit(new Person { Name = "Brian" });
table.InsertOnSubmit(new Person { Name = "Charles" });
db.SubmitChanges();
var query = from p in table select p;
foreach (var p in query)
{
Console.WriteLine(p.ID + ". " + p.Name);
}
Console.WriteLine("Done");
Console.ReadLine();
}
}
[Table(Name = "Persons")]
class Person
{
[Column(IsPrimaryKey = true, IsDbGenerated = true)]
public int ID { get; set; }
[Column]
public string Name { get; set; }
public static string CreateCommand = "CREATE TABLE IF NOT EXISTS Persons ( Id INTEGER PRIMARY KEY, Name TEXT )";
}
}
Я просто создал приложение, использующее dblinq для предоставления Linq для SQLite, но оно зависает db.SubmitChanges()
, В чем причина? Я просто хотел создать приложение dblinq без использования DbMetal.exe... Нет ошибок, нет исключений, я не в курсе.
1 ответ
Решение
Проблема была с DataContext и connectonString, чтобы исправить это мне пришлось изменить...
string connectionString = "DbLinqProvider=Sqlite;Data Source=db2.sqlite;";
SQLiteConnection connection = new SQLiteConnection(connectionString);
DataContext db = new DataContext(connection);
... или добавить в DbLinqConnectionType для connectionString...
string connectionString = "DbLinqProvider=Sqlite;Data Source=db2.sqlite;";
connectionString += "DbLinqConnectionType=System.Data.SQLite.SQLiteConnection, System.Data.SQLite, Version=1.0.66.0, Culture=neutral, PublicKeyToken=db937bc2d44ff139";
DataContext db = new DataContext(connectionString);