- SQLite是目前比较流行的一个开源、免费的小型的EmbeddableRDBMS(关系型数据库),用C实现,内存占用较小,支持绝大数的SQL92标准,个别不支持的情况,在这里说明
- 对各种语言的支持也比较不错,wrapper很多。
- GoogleGears、Mozilla和AdobeAIR都在使用sqlite,应该说明其还是很不错的
- SQLite的关键字列表,这里
- 支持的sql语法,在这里
- --------------------------------------------------------------------------------
- 在.NET里面使用SQLite,我这里使用的wrapper是System.Data.SQLite,它只需要一个dll,接口符合ADO.Net2.0的定义,性能也不错,NHibernate用的也是它,目前支持ADO.NET3.5了,支持集成在VS2005和VS2008里面,而且支持wince,是个亮点
- 因为符合ADO.NET的规范,所以使用方式,基本和SqlClient,OleDb等原生的一致
- usingSystem.Data;
- usingSystem.Data.SQLite;
- //...
- using(SQLiteConnectioncn=newSQLiteConnection(
- "DataSource=Test.db3;Pooling=true;FailIfMissing=false")
- )
- {
- //在打开数据库时,会判断数据库是否存在,如果不存在,则在当前目录下创建一个
- cn.Open();
- using(SQLiteCommandcmd=newSQLiteCommand())
- {
- cmd.Connection=cn;
- //建立表,如果表已经存在,则报错
- cmd.CommandText="CREATETABLE[test](idint,namenvarchar(20))";
- cmd.ExecuteNonQuery();
- //插入测试数据
- for(inti=2;i<5;i++)
- {
- cmd.CommandText=string.Format("INSERTINTO[test]VALUES({0},'杜思波技术讨论区域')",i);
- cmd.ExecuteNonQuery();
- }
- for(inti=5;i<10;i++)
- {
- cmd.CommandText=string.Format("INSERTINTO[test]VALUES({0},'EnglishTest')",i);
- cmd.ExecuteNonQuery();
- }
- //读取数据
- cmd.CommandText="SELECT*FROM[test]";
- using(SQLiteDataReaderdr=cmd.ExecuteReader(CommandBehavior.CloseConnection))
- {
- while(dr.Read())
- {
- Console.WriteLine("第{0}条:{1}",dr.GetValue(0),dr.GetString(1));
- }
- }
- }
- }
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。