实例介绍
【实例简介】C# .net framwork 3.5 开发,源码,Sqlite数据库简单应用实例 C#中Sqlite数据库的创建、打开、建表、插入数据、提取数据 在Form DataGridView中显示Sqlite数据库内容 附最新System.Data.SQLite.Dll 适合初学者
提示:64位的Win7、win8 解决方案的生成目标平台设置为x86
32位操作系统 解决方案的生成目标平台设置为AnyCPU
否则可能会报 “未能加载文件或程序集“XXX”或它的某一个依赖项。试图加载格式不正确的程序” 错误
【实例截图】
【核心代码】
using System;
using System.Data;
using System.Data.SQLite;
using System.Text;
using System.Windows.Forms;
namespace SqliteView
{
public partial class FormView : Form
{
System.Data.SQLite.SQLiteConnection CONN = new System.Data.SQLite.SQLiteConnection();
System.Data.SQLite.SQLiteConnectionStringBuilder CONNStr = new System.Data.SQLite.SQLiteConnectionStringBuilder();
System.Data.SQLite.SQLiteCommand CMD = new System.Data.SQLite.SQLiteCommand();
System.Data.SQLite.SQLiteDataAdapter DA = new SQLiteDataAdapter();
System.Data.DataSet DS = new DataSet("DS1");
string DataSource = "";
string SQL = "";
public FormView()
{
InitializeComponent();
this.textBox1.Text = "select field2 from demo";
}
private void textBox1_TextChanged(object sender, EventArgs e)
{
}
private void FormView_Load(object sender, EventArgs e)
{
try
{
DataSource = "Demo.db";
;
CONNStr.DataSource = DataSource;
//CONNStr.Password = "admin";//设置密码,SQLite ADO.NET实现了数据库密码保护 (似乎与SqliteManager有冲突)
CONN.ConnectionString = CONNStr.ToString();
CONN.Open();
CMD.Connection = CONN;
SQL = "select * from demo";
showview(SQL, this.dataGridView1);
}
catch (Exception e1)
{
MessageBox.Show(e1.Message, "Error", MessageBoxButtons.OK, MessageBoxIcon.Error);
}
}
private void showview(string sql,DataGridView dgv)
{
try
{
DS.Tables.Clear();
CMD.CommandText = sql;
CMD.ExecuteNonQuery();
DA.SelectCommand = CMD;
DA.Fill(DS);
dgv.DataSource = DS.Tables[0];
}
catch (Exception e1)
{
MessageBox.Show(e1.Message, "Error", MessageBoxButtons.OK, MessageBoxIcon.Error);
}
}
private void testdb()
{
try
{
string datasource = "tmp_demo.db";
//创建数据库
System.Data.SQLite.SQLiteConnection.CreateFile(datasource);
//打开数据库
System.Data.SQLite.SQLiteConnection conn = new System.Data.SQLite.SQLiteConnection();
System.Data.SQLite.SQLiteConnectionStringBuilder connstr = new System.Data.SQLite.SQLiteConnectionStringBuilder();
System.Data.SQLite.SQLiteCommand cmd = new System.Data.SQLite.SQLiteCommand();
connstr.DataSource = datasource;
//connstr.Password = "admin";//设置密码,SQLite ADO.NET实现了数据库密码保护 (似乎与SqliteManager有冲突)
conn.ConnectionString = connstr.ToString();
conn.Open();
cmd.Connection = conn;
//建表
string sql = "CREATE TABLE test(username varchar(20),password varchar(20))";
cmd.CommandText = sql;
cmd.ExecuteNonQuery();
//插入数据
sql = "INSERT INTO test VALUES('dotnetthink','mypassword')";
cmd.CommandText = sql;
cmd.ExecuteNonQuery();
//取出数据
sql = "SELECT * FROM test";
cmd.CommandText = sql;
System.Data.SQLite.SQLiteDataReader reader = cmd.ExecuteReader();
StringBuilder sb = new StringBuilder();
while (reader.Read())
{
sb.Append("username:").Append(reader.GetString(0)).Append("\n");
sb.Append("password:").Append(reader.GetString(1));
}
MessageBox.Show(sb.ToString());
reader.Close();
conn.Close();
}
catch (Exception e1)
{
MessageBox.Show(e1.Message, "Error", MessageBoxButtons.OK, MessageBoxIcon.Error);
}
}
private void buttonRun_Click(object sender, EventArgs e)
{
SQL = this.textBox1.Text.Trim();
showview(SQL, dataGridView1);
this.textBox1.Focus();
}
private void button1_Click(object sender, EventArgs e)
{
CONN.Close();
Close();
}
private void button1_Click_1(object sender, EventArgs e)
{
this.testdb();
}
}//end Class FormView
}//end namespace SqliteView
网友评论
小贴士
感谢您为本站写下的评论,您的评论对其它用户来说具有重要的参考价值,所以请认真填写。
- 类似“顶”、“沙发”之类没有营养的文字,对勤劳贡献的楼主来说是令人沮丧的反馈信息。
- 相信您也不想看到一排文字/表情墙,所以请不要反馈意义不大的重复字符,也请尽量不要纯表情的回复。
- 提问之前请再仔细看一遍楼主的说明,或许是您遗漏了。
- 请勿到处挖坑绊人、招贴广告。既占空间让人厌烦,又没人会搭理,于人于己都无利。
关于好例子网
本站旨在为广大IT学习爱好者提供一个非营利性互相学习交流分享平台。本站所有资源都可以被免费获取学习研究。本站资源来自网友分享,对搜索内容的合法性不具有预见性、识别性、控制性,仅供学习研究,请务必在下载后24小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,平台无法对用户传输的作品、信息、内容的权属或合法性、安全性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论平台是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二与二十三条之规定,若资源存在侵权或相关问题请联系本站客服人员,点此联系我们。关于更多版权及免责申明参见 版权及免责申明


支持(0) 盖楼(回复)
支持(0) 盖楼(回复)