博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
C# web项目中sql数据库转sqlite数据库
阅读量:3963 次
发布时间:2019-05-24

本文共 4674 字,大约阅读时间需要 15 分钟。

最近做了一个小网站,用到了一个使用sql server 2005的.net cms系统,但是现在我所买虚拟主机的服务商,不给虚拟主机提供sql server服务了,那就转数据库吧,转啥好呢,思来想去,access?刚入行时候用了很久,简单够用,不过实在提不起兴趣了,sqlite?嗯...还没用过,只是简单看过介绍,听说性能还不错,那就试试吧,等等,不知道虚拟主机支持不支持?!百度!然而一大堆没啥用处的提问和回答,也许可能大概是我搜索的关键词不对,懒得管了,年龄大了,没有那个劲儿了,实践出真理,先上手试试验证一下吧,说干就干

先查查怎么在本地创建和管理数据库,然后选择使用了SQLiteStudio这个软件,然后新建个test数据库->随便插条数据->然后在vs创建个test web项目->数据库文件扔进去->新建个页面,查下数据显示到页面->本地运行,ok!,发布,->上传虚拟主机,怀着稍稍激动的心情,打开网址,ok!完全可以!

这么简单吗?nonono,运行之前还是有点小小的障碍的:

首先项目需要用到System.Data.SQLite.dll,到sqlite官网下一个吧,

然后添加引用,引用之后,还需要连接字符串,搜索(ss)! 嗯,和access很像,附个例子:

这样就可以运行了!具体的参数还有不少,ss一下,根据需求自己设置。

然后开始改cms吧,首先是转数据库,一看表,我尼玛,好多表,自己一个一个建吗?想想都想打消折腾的念头了,有没有什么工具可以借助呢?ss一下,还真有!

SQL server To SQLite DB Convert 这是一位叫liron.levi老外写的,项目地址:https://www.codeproject.com/Articles/26932/Convert-SQL-Server-DB-to-SQLite-DB

简直神器,界面如下

 作者还给出了源代码,在源代码中可以看到数据类型对应的转换

///         /// Used when creating the CREATE TABLE DDL. Creates a single row        /// for the specified column.        ///         /// The column schema        /// 
A single column line to be inserted into the general CREATE TABLE DDL statement
private static string BuildColumnStatement(ColumnSchema col, TableSchema ts, ref bool pkey) { StringBuilder sb = new StringBuilder(); sb.Append("\t[" + col.ColumnName + "]\t"); // Special treatment for IDENTITY columns if (col.IsIdentity) { if (ts.PrimaryKey.Count == 1 && (col.ColumnType == "tinyint" || col.ColumnType == "int" || col.ColumnType == "smallint" || col.ColumnType == "bigint" || col.ColumnType == "integer")) { sb.Append("integer PRIMARY KEY AUTOINCREMENT"); pkey = true; } else sb.Append("integer"); } else { if (col.ColumnType == "int") sb.Append("integer"); else { sb.Append(col.ColumnType); } if (col.Length > 0) sb.Append("(" + col.Length + ")"); } if (!col.IsNullable) sb.Append(" NOT NULL"); if (col.IsCaseSensitivite.HasValue && !col.IsCaseSensitivite.Value) sb.Append(" COLLATE NOCASE"); string defval = StripParens(col.DefaultValue); defval = DiscardNational(defval); _log.Debug("DEFAULT VALUE BEFORE [" + col.DefaultValue + "] AFTER [" + defval + "]"); if (defval != string.Empty && defval.ToUpper().Contains("GETDATE")) { _log.Debug("converted SQL Server GETDATE() to CURRENT_TIMESTAMP for column [" + col.ColumnName + "]"); sb.Append(" DEFAULT (CURRENT_TIMESTAMP)"); } else if (defval != string.Empty && IsValidDefaultValue(defval)) sb.Append(" DEFAULT " + defval); return sb.ToString(); }
View Code

然后就用这个工具把cms的sql server数据库转换成sqlite数据库文件,直接扔进cms项目中。

这样就行了吗?当然还有工作要做,原来项目中操作sql server的类库也要换成sqlite的,sql语句也要做相应的转换,下面就挑一些重点的说一说:

先说数据类型吧:

由于在工具的源代码中,主键不管什么类型的int转成sqlite都用的integer,有需求的可以自己改代码,不过最好要熟悉sqlite的数据类型。下面列出我在项目中所遇到的主要类型转换

sql server c# sqlite c#
int new SqlParameter("@id", SqlDbType.Int,4)  integer new SQLiteParameter("@id", DbType.Int64,8)
nvarchar new SqlParameter("@id", SqlDbType.NVarChar,50) nvarchar new SQLiteParameter("@id", DbType.String,50)
decimal new SqlParameter("@id", SqlDbType.Decimal) numeric new SQLiteParameter("@id", DbType.Decimal)
tinyint new SqlParameter("@id", SqlDbType.TinyInt,1) smallint new SQLiteParameter("@id", DbType.Int16,1)
ntext new SqlParameter("@id", SqlDbType.NText) text new SQLiteParameter("@id", DbType.String)
datetime new SqlParameter("@id", SqlDbType.DateTime) datetime new SQLiteParameter("@id", DbType.DateTime)
Image new SqlParameter("@fs", SqlDbType.Image) Binary new SQLiteParameter("@fs", DbType.Binary)
 

代码数据类型转换之后,就剩调试修改sql语句了,下面列出我在项目中遇到的比较主要的转换

1、top语句,在sqlite中要使用limit,和mysql差不多,例如

  sql:select top 10 * from table_1  sqlite:select * from table_1 limit 10

2、在插入一条数据后,要获取最新的id

  sql:select @@IDENTITY;  sqlite:select LAST_INSERT_ROWID();

3、计算时间差

  sql:where datediff(d,field_time,getdate())>=0  sqlite:where JULIANDAY(datetime('now','localtime'))-JULIANDAY(field_time)>=0

4、分页

  sql:2005以上一般使用ROW_NUMBER()      select * from ( select row_number() over(order by id) as rows,* ) as t where rows between PageIndex*PageSize and PageIndex*PageSize+PageSize  sqlite:用 limit  offset    select * from table_1 limit PageSize offset (PageIndex- 1) * PageSize

5、最让人抓狂的是修改表部分的差异

  这一部分单独再写一篇吧

时间不早了,来自老年人的叹息.....

第二天了,附上修改表的文章链接:

 

转载地址:http://nakki.baihongyu.com/

你可能感兴趣的文章
NET - .NET Core 之 Abp Audit-Logging
查看>>
NET - .NET Core 之 Abp AuditLog 将不同的Controller实体的审计日志存储到不同的Table
查看>>
NET - .NET Core 之 Azure Key Vault 密钥保管库的使用
查看>>
NET - .NET Core 之 Abp 整合 Quartz
查看>>
Docker - Docker Desktop(WSL2)修改镜像存储位置
查看>>
NET - NET Core使用Log4net的SqlServer AdoNetAppender 报程序集错误
查看>>
NET - NET Core中使用Log4net输出日志到数据库中去
查看>>
NET - NET Core 迁移nuget包缓存到指定位置
查看>>
Spring - SpringBoot 集成 swagger2
查看>>
SQL - 深入理解MySQL索引之B+Tree
查看>>
SQL - 数据库索引原理,及MySQL索引类型
查看>>
Spring - Dubbo的实现原理
查看>>
Spring - Dubbo 扩展点详解
查看>>
Spring - Hystrix原理与实战
查看>>
Spring - Sentinel 原理 全解析
查看>>
Spring - 比较Sentinel和Hystrix
查看>>
Spring - Nacos 服务注册与发现原理分析
查看>>
Spring - Nacos 配置中心原理分析
查看>>
Spring - Nacos 配置实时更新原理分析
查看>>
Android开发MVP模式(解决了View和Model的耦合)
查看>>