时间:2021-07-01 10:21:17 帮助过:50人阅读
CSDN友回复可能是因为以下原因:
有可能是框架配置不正确,SQLite是.NET 4.0,而你的控制台为.NET 4.0 Client Profile;
.NET 4.0 大于 .NET 4.0 Client Profile 查看项目属性,更改试试.
.NET 4.0 Client Profile比.NET 4.0占用的空间要小,但支持的类型也比.NET 4.0支持的类型小。
SQLITE的动态库是.NET 4.0 Client Profile不支持的。
未验证是否是这样。
(2) 下载了:SQLite-1.0.66.0-setup.exe,安装后在 VS2010 的菜单“增加新数据源”的“新建连接...”中终于找到了 SQLite 的选项。
然后需要将工程的目标框架由 4.0 修改为 3.5,否则编译报错。
最后,在工程中“增加引用”,选择 \SQLite.NET\bin 目录的:System.Data.SQLite.dll和System.Data.SQLite.dll(可选)
(3) 创建数据库
......
------------------------------------------------------------------------------------------------
* 从 http://system.data.sqlite.org/index.html/doc/trunk/www/downloads.wiki 下载了 sqlite-netFx35-setup-bundle-x86-2008-1.0.83.0.exe
* 为 VS2008 版本,安装。安装过程中,在 console 界面提示了一些错误,最后安装完成。
* 在 VS2008 中新建一个 C# 的工程,"Add References..." 浏览到 sqlite-netFx35-setup-bundle-x86-2008-1.0.83.0.exe 的安装目录
* 例如,我的安装目录:D:\Program Files\System.Data.SQLite\2008\bin
* 选择 System.Data.SQLite.dll,在工程的 References 中可以看到多了一个: System.Data.SQLite
* 在工程的 Form1.cs 中增加: using System.Data.SQLite;
* 增加代码如下:
* 编译调试通过,引起问题的原因如 CSDNer 所说的 .Net 版本选择不对,导致前天测试一直通不过。
1 using System.Data.SQLite; 2 3 namespace TestUseSqlite 4 { 5 public partial class Form1 : Form 6 { 7 private string dataSource = "ContactBookDB.sqlite"; 8 9 public Form1() 10 { 11 InitializeComponent(); 12 13 SQLiteConnection.CreateFile(dataSource); 14 15 SQLiteConnection dbConn = new SQLiteConnection("Data Source=" + dataSource); 16 17 dbConn.Open(); 18 19 SQLiteCommand dbCmd = dbConn.CreateCommand(); 20 21 dbCmd.CommandText = "CREATE TABLE TelephoneBook(personID varchar(20),telephone varchar(30),type varchar(20))"; 22 dbCmd.ExecuteNonQuery(); 23 24 dbCmd.CommandText = "INSERT INTO TelephoneBook VALUES(‘MTB‘,‘1234567890‘,‘not mobile‘)"; 25 dbCmd.ExecuteNonQuery(); 26 27 dbCmd.CommandText = "SELECT * FROM TelephoneBook"; 28 SQLiteDataReader dataReader = dbCmd.ExecuteReader(); 29 30 DataTable dataTable = new DataTable(); 31 if (dataReader.HasRows) 32 { 33 dataTable.Load(dataReader); 34 } 35 36 dataGridView1.DataSource = dataTable; 37 38 dataReader.Close(); 39 dbConn.Close(); 40 } 41 } 42 }
C#中使用SQLite
标签: