IT评测·应用市场-qidao123.com
标题:
SqLite本地数据库常规用法
[打印本页]
作者:
九天猎人
时间:
2022-8-9 16:46
标题:
SqLite本地数据库常规用法
SqLite数据库介绍
SqLite是一个进程内的库,实现了自给自足的、无服务器的、零配置的、事务性的 SQL 数据库引擎。它是一个零配置的数据库,这意味着与其他数据库一样,您不需要在系统中配置。
就像其他数据库,SqLite 引擎不是一个独立的进程,可以按应用程序需求进行静态或动态连接。SqLite 直接访问其存储文件。
为什么要用SqLite
不需要一个单独的服务器进程或操作的系统(无服务器的)。
SqLite 不需要配置,这意味着不需要安装或管理。
一个完整的 SqLite 数据库是存储在一个单一的跨平台的磁盘文件。
SqLite 是非常小的,是轻量级的,完全配置时小于 400KiB,省略可选功能配置时小于250KiB。
SqLite 是自给自足的,这意味着不需要任何外部的依赖。
SqLite 事务是完全兼容 ACID 的,允许从多个进程或线程安全访问。
SqLite 支持 SQL92(SQL2)标准的大多数查询语言的功能。
SqLite 使用 ANSI-C 编写的,并提供了简单和易于使用的 API。
SqLite 可在 UNIX(Linux, Mac OS-X, Android, iOS)和 Windows(Win32, WinCE, WinRT)中运行。
创建SqLite数据库
使用命令行创建数据库
cd. >test3.db
复制代码
使用代码创建数据库
//方式一
System.IO.File.Create(@"c:\test.db");
//方式二
//需要安装Neget包。.Net FX安装 System.Data.SQLite;.Net Core安装 System.Data.SQLite.Core
System.Data.SQLite.SQLiteConnection.CreateFile(@"c:\test2.db");
复制代码
使用官网工具创建数据库
下载SqLite工具包
博客下载地址
官网下载地址
创建数据库
工具包下载完成后j解压,可以看到SqLite3.exe文件,直接在命令行当前目录中以下命令创建数据库。
sqlite3 "test.db" ".databases" ".quit"
复制代码
连接数据库
test.db文件创建完成以后,默认会创建一个main名称的数据库,然后就可以直接用数据库IDE打开连接数据库即可。
数据库IDE:
navicat
datagrip
DB Browser for SqLite
代码操作数据库
链接字符串
基本
Data Source=filepath;database=main;
版本号
可以通过IDE中执行sql查询版本号 select sqlite_version(*)
Data Source=filepath;database=main;Version=3;
只读链接
Data Source=filepath;database=main;Read Only=True;
实体类操作Sqlite数据库
需要Neget安装sqlite-net-pcl包。
using System;
using System.Collections.Generic;
using System.Threading.Tasks;
using SQLite;
namespace ConsoleApp1
{
class Program
{
static void Main(string[] args)
{
string path = @"F:\DownLoad\sqlite\text4.db";
NoteDatabase noteDatabase = new NoteDatabase(path);
Note note = new Note();
note.Text = "123456";
note.Date = DateTime.Now;
noteDatabase.SaveNoteAsync(note).Wait();
}
}
public class Note
{
//主键,自增
[PrimaryKey, AutoIncrement]
public int ID { get; set; }
//唯一标识,不为空
[Unique, NotNull]
public string Text { get; set; }
[MaxLength(30), NotNull]
public DateTime Date { get; set; }
}
public class NoteDatabase
{
readonly SQLiteAsyncConnection database;
readonly SQLite.SQLiteConnection database2;
public NoteDatabase(string connectionString)
{
database = new SQLiteAsyncConnection(connectionString);
database.CreateTableAsync<Note>().Wait();
}
public Task<List<Note>> GetNotesAsync()
{
//Get all notes.
return database.Table<Note>().ToListAsync();
}
public Task<Note> GetNoteAsync(int id)
{
// Get a specific note.
return database.Table<Note>()
.Where(i => i.ID == id)
.FirstOrDefaultAsync();
}
public Task<int> SaveNoteAsync(Note note)
{
if (note.ID != 0)
{
// Update an existing note.
return database.UpdateAsync(note);
}
else
{
// Save a new note.
return database.InsertAsync(note);
}
}
public Task<int> DeleteNoteAsync(Note note)
{
// Delete a note.
return database.DeleteAsync(note);
}
}
}
复制代码
ADO.NET
需要安装Neget包。.Net FX安装 System.Data.SQLite;.Net Core安装System.Data.SQLite.Core。
using System;
using System.Data;
using System.Data.Common;
using System.Data.SQLite;
namespace ConsoleApp1
{
class Program
{
static void Main(string[] args)
{
SqlHelper helper = new SqlHelper();
string strSql = "Select * From Test";
DataTable dt = helper.GetDataTable(strSql);
string updateSql = "update Test set id=4 where id=3";
int count = helper.ExecuteNonQuery(updateSql);
Console.WriteLine(count);
}
}
public class SqlHelper
{
//创建数据库连接字符串
private static string ConnString = @"Data Source=F:\DownLoad\sqlite\test.db;database=main;";
//创建数据库连接对象
private static SQLiteConnection Conn = null;
//增删改
public int ExecuteNonQuery(string sqlStr)
{
Conn = new SQLiteConnection(ConnString);
Conn.Open();
IDbCommand cmd = new SQLiteCommand(sqlStr, Conn);
int result = cmd.ExecuteNonQuery();
Conn.Close();
return result;
}
/// <summary>
/// 获得datatable
/// </summary>
/// <param name="sql"></param>
/// <returns></returns>
public DataTable GetDataTable(string sqlStr)
{
Conn = new SQLiteConnection(ConnString);
DataTable dt = new DataTable();
DbDataAdapter dap = new SQLiteDataAdapter(sqlStr, Conn);
dap.Fill(dt);
Conn.Close();
return dt;
}
}
}
复制代码
Dapper
需要Neget安装System.Data.SQLite和Dapper包。
using Dapper;
using System.Data.SQLite;
namespace ConsoleApp1
{
class Program
{
static void Main(string[] args)
{
using (var conn = new SQLiteConnection(@"Data Source=F:\DownLoad\sqlite\text4.db;database=main;"))
{
var data = conn.Query<object>("Select * From Test");
int a = conn.Execute("update Test set id=4 where id=3");
}
}
}
}
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
欢迎光临 IT评测·应用市场-qidao123.com (https://dis.qidao123.com/)
Powered by Discuz! X3.4