C# SQlite操作方法小结
本文实例分析了C# SQlite操作方法。分享给大家供大家参考,具体如下:
最近项目需求用C#保存一些数据,如此先总结一下。需要下载Sqlite 库 SourceForge 链接网址http://sourceforge.net/projects/sqlite-dotnet2/或到官方网http://www.sqlite.org/download.html下载都可以,下载之后安装。在C#项目中添加引用 引入安装目录bin中的System.Data.SQLite.dll。添加命名空间using System.Data.SQLite;便可以在你的项目中
对扩平台的微型数据库SQlite 进行使用了,
主要注意一点是:
数据库若未创建则使用:
SQLiteConnection.CreateFile(databaseName);
数据库已经创建,并要进行访问:
下面是项目中封装的操作数据库代码,使用时可稍微修改便可在项目中使用。
using System; using System.Collections.Generic; using System.Text; using System.Data.SQLite; namespace Toolbar { public class CSPDatabase { protected string m_dbName; protected string m_tablename; protected string m_password; public CSPDatabase(string dbName) { m_dbName = dbName; m_tablename = "MhtInfo"; m_password = ""; } //Create DataBase public virtual void Init() { } public virtual void CreateDataBase() { } public virtual void OpenDataBase() { } public virtual void SetPassWord(string password) { } //Connect DataBase public virtual void ConnectDataBase() { } //Create Table public virtual void CreateTable(string tableName) { } //Insert Data public virtual void Insert(string mhtlocation) { } } }
using System; using System.Collections.Generic; using System.Text; using System.Data.SQLite; using System.Windows.Forms; namespace Toolbar { class SqliteDatabase : CSPDatabase { private SQLiteConnection m_conn= null; private SQLiteCommand m_cmd=null; public SqliteDatabase(string dbName):base(dbName) { } public override void Init() { if(m_conn == null) m_conn = new SQLiteConnection(); m_cmd = new SQLiteCommand(); m_cmd.Connection = m_conn; } public override void CreateDataBase() { //Create Database try { SQLiteConnection.CreateFile(m_dbName); Init(); ConnectDataBase(); } catch (System.Exception e) { MessageBox.Show("Create DataBase Failed!"); } } public override void OpenDataBase() { m_conn = new SQLiteConnection("Data Source="+m_dbName+";Version=3;New=False;Compress=True;"); Init(); ConnectDataBase(); } public override void SetPassWord(string password) { m_password = password; } public override void ConnectDataBase() { //Connect to DataBase try { SQLiteConnectionStringBuilder connstr = new SQLiteConnectionStringBuilder(); connstr.DataSource = m_dbName; if(m_password != "") connstr.Password = m_password; m_conn.ConnectionString = connstr.ToString(); } catch (System.Exception e) { MessageBox.Show("Fail to Connect to the database"); } } //Create Table public override void CreateTable(string tableName) { try { m_tablename = tableName; m_conn.Open(); string sql = "CREATE TABLE " + tableName + "(mhtlocation varchar(20))"; m_cmd.CommandText = sql; m_cmd.ExecuteNonQuery(); m_conn.Close(); } catch (System.Exception e) { MessageBox.Show("Create Table Failed!"); } } public override void Insert(string mhtlocation) { try { //Insert Data m_conn.Open(); string sql = "insert into [" + m_tablename + "] values('" + mhtlocation + "')"; m_cmd.CommandText = sql; m_cmd.ExecuteNonQuery(); m_conn.Close(); } catch (System.Exception e) { MessageBox.Show(e.ToString()); } } } }
更多关于C#相关内容感兴趣的读者可查看本站专题:《C#程序设计之线程使用技巧总结》、《C#操作Excel技巧总结》、《C#中XML文件操作技巧汇总》、《C#常见控件用法教程》、《WinForm控件用法总结》、《C#数据结构与算法教程》、《C#数组操作技巧总结》及《C#面向对象程序设计入门教程》
希望本文所述对大家C#程序设计有所帮助。
上一篇:C#计算器编写代码
栏 目:C#教程
本文标题:C# SQlite操作方法小结
本文地址:https://www.xiuzhanwang.com/a1/C_jiaocheng/6361.html
您可能感兴趣的文章
- 01-10C#通过反射获取当前工程中所有窗体并打开的方法
- 01-10WinForm限制窗体不能移到屏幕外的方法
- 01-10WinForm绘制圆角的方法
- 01-10C#停止线程的方法
- 01-10WinForm实现仿视频播放器左下角滚动新闻效果的方法
- 01-10C#通过重写Panel改变边框颜色与宽度的方法
- 01-10C#实现清空回收站的方法
- 01-10C#实现读取注册表监控当前操作系统已安装软件变化的方法
- 01-10C#实现多线程下载文件的方法
- 01-10C#实现Winform中打开网页页面的方法
阅读排行
本栏相关
- 01-10C#通过反射获取当前工程中所有窗体并
- 01-10关于ASP网页无法打开的解决方案
- 01-10WinForm限制窗体不能移到屏幕外的方法
- 01-10WinForm绘制圆角的方法
- 01-10C#实现txt定位指定行完整实例
- 01-10WinForm实现仿视频播放器左下角滚动新
- 01-10C#停止线程的方法
- 01-10C#实现清空回收站的方法
- 01-10C#通过重写Panel改变边框颜色与宽度的
- 01-10C#实现读取注册表监控当前操作系统已
随机阅读
- 01-11ajax实现页面的局部加载
- 01-10使用C语言求解扑克牌的顺子及n个骰子
- 01-11Mac OSX 打开原生自带读写NTFS功能(图文
- 04-02jquery与jsp,用jquery
- 01-10C#中split用法实例总结
- 01-10SublimeText编译C开发环境设置
- 08-05DEDE织梦data目录下的sessions文件夹有什
- 08-05织梦dedecms什么时候用栏目交叉功能?
- 01-10delphi制作wav文件的方法
- 08-05dedecms(织梦)副栏目数量限制代码修改