在没有使用SQLite这种轻量级的数据库之前,只使用过Sqlserver2008进行数据的增删改查,公司使用的是大型的ORACLE数据库,还没有真正的会使用它。那时候觉得数据库很庞大,然而遇到SQLite以后,发现有这么个迷你的小数据库,就像女生的包包随身携带的小镜子一样,放在哪里都能使用。

废话少说,SQLite提供了如何连接、关闭等数据库操作,但真正的增、删、改、查等语句同Sqlserver、ORACLE是一样的。

首先,是创建SQLite数据库文件(写了一个方法):

Public static void CreateDataBaseFile()

{

If(!File.Exists(dataBaseName))

{

SqliteConnection.CreateFile(dataBaseName);

}

}

注意:默认SQLite数据库文件创建在当前应用程序根目录下,如果需要更改文件路径,记得把文件路径一块加上。

比如:SQLiteConnection.CreateFile(sceneName
+
"\\"
+
dataSource);

 

打开某个数据库,也要把文件路径加上,如果不需要更改,就无所谓啦….

DataSource="
+
Environment.CurrentDirectory
+
"\\"
+
pack.SceneName
+
"\\"
+
pack.BattleID
+
".db";

 

然后,增删改查语句,以插入语句为例:

1、查询语句

SELECT *FROM TABLE_BATTLE;

 

2、更新语句

UPDATE TABLE_BATTLE SET 字段1='新值1';

 

3、删除语句

DELETE FROM 表

 

4、插入语句

//string connStr = @"datasource=DEPTDATABASE";


//using (SQLiteConnection conn = new SQLiteConnection(connStr))


//{


// conn.Open();


// using (var transaction = conn.BeginTransaction())


// {


// try


// {


// SQLiteCommand cmd = conn.CreateCommand();


// cmd.Parameters.Add(cmd.CreateParameter());


// cmd.CommandText = "INSERT INTO 表名(字段1, 字段2, 字段3) VALUES(@字段1,@字段2,@字段3)";


// cmd.Parameters.AddWithValue("@字段1",值1);


// cmd.Parameters.AddWithValue("@字段2",值2);


// cmd.Parameters.AddWithValue("@字段3",值3);


// cmd.ExecuteNonQuery();


// transaction.Commit();


// conn.Close();


// }


// catch (Exception e)


// {


// Console.WriteLine(e.Message);


// transaction.Rollback();


// }


// }


//}

 

使用这种方法插入二进制字节数据是没有问题的。

当我使用拼接字符串格式的Sql语句就有问题了,因为使用拼接字符串格式,编译器就会认为这句是字符串(string类型),所以即使里面的数据有二进制格式,也被当做字符串处理(数字格式除外),所以就会报错。

下面这句是已经修改后的,所以正常运行。(用一个占位符表示,当使用时再赋值)

var
sql
=
"INSERT INTO TABLE_BATTLE_HISTORY(BATTLE_ID,TIME_STAMP,OBJECT_NAME,SYNC_TYPE,

DETAIL_DATA) VALUES( '"
+
accData.battleId
+
"','"
+
accData.timeStamp
+
"','"
+
accData.objectName
+
"','"
+
accData.syncType
+
"',@DETAIL_DATA)";

 

二进制数据可以正常存到数据库:

 

使用C#书写SQLite数据库增删改查语句(以及插入byte[]时遇到的问题总结)的更多相关文章

  1. (转)SQLite数据库增删改查操作

    原文:http://www.cnblogs.com/linjiqin/archive/2011/05/26/2059182.html SQLite数据库增删改查操作 一.使用嵌入式关系型SQLite数 ...

  2. Android SQLite 数据库 增删改查操作

    Android SQLite 数据库 增删改查操作 转载▼ 一.使用嵌入式关系型SQLite数据库存储数据 在Android平台上,集成了一个嵌入式关系型数据库--SQLite,SQLite3支持NU ...

  3. MySQL数据库(增删改查语句)

    MySQL数据库(增删改查语句)一.登录数据库:---->  mysql -uroot -proot;(对应用户名和密码)二.SQL语句:    数据定义语言DDL  用来定义数据库.表.列,关 ...

  4. IOS sqlite数据库增删改查

    1.简单介绍 简单封装sqlite数据库操作类 BaseDB 用于完毕对sqlite的增删改查.使用前先导入libsqlite3.0.dylib库 2.BaseDB.h // // BaseDB.h ...

  5. SQLite数据库增删改查操作

    一.使用嵌入式关系型SQLite数据库存储数据 在Android平台上,集成了一个嵌入式关系型数据库——SQLite,SQLite3支持NULL.INTEGER.REAL(浮点数字).TEXT(字符串 ...

  6. Android SQLite数据库增删改查操作

    一.使用嵌入式关系型SQLite数据库存储数据 在Android平台上,集成了一个嵌入式关系型数据库——SQLite,SQLite3支持NULL.INTEGER.REAL(浮点数字). TEXT(字符 ...

  7. SQLite数据库增删改查

    一:SQLite数据库简介: SQLite是一种轻量级的关系型数据库,官网:http://www.sqlite.org/. SQLite数据库文件存在于移动设备的一下目录中:data->data ...

  8. 通过API函数来控制SQLite数据库增删改查

    person类属性有Intenger id,String name,Intenger  age,相应的构造方法和set get方法. package com.xh.tx.dao; import and ...

  9. 通过Sql语句控制SQLite数据库增删改查

    person类属性有Intenger id,String name,Intenger  age,相应的构造方法和set get方法. package com.xh.tx.dao; import jav ...

随机推荐

  1. js之吸顶效果

    <!doctype html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  2. mysql安装优化

    安装centos7 安装mysql解决方案1 安装mariadb解决方案2 官网下载安装mysql-server时区批量配置编码远程连接my.cnf简版的参数说明核心配置参数升级版mysql存储引擎M ...

  3. C++头文件预编译与命名空间使用方法

    宏指令的预编译用法,用于多文件的头文件预编译判断 头文件代码: #include <iostream> #ifndef XB_H//预编译判断XB_H代码段是否被执行 #define XB ...

  4. Roslyn 入门:使用 Visual Studio 的语法可视化窗格查看和了解代码的语法树

    使用 Visual Studio 提供的 Syntax Visualizer,我们可以实时看到一个代码文件中的语法树.这对我们基于 Roslyn 编写静态分析和修改工具非常有帮助.本文将介绍如何安装它 ...

  5. Page View Controllers

    Page View Controllers You use a page view controller to present content in a page-by-page manner. A ...

  6. 使用stsadm.exe工具实现SharePoint网站备份还原

    一.过程描述: 首先在源站点机器上用stsadm.exe备份网站集,讲备份文件拷贝到目标服务器(也可直接在备份时配置备份路径为目标机器路径),然后执行还原操作:首先新建网站集,然后用SharePoin ...

  7. 《DSP using MATLAB》示例Example8.2

    代码: N = 3; OmegaC = 0.5; % Direct form [b, a] = u_buttap(N, OmegaC); [C, B, A] = sdir2cas(b, a) 运行结果 ...

  8. jsTree 是一个基于Javascript,支持多浏览器的Tree view jQuery插件。

    https://www.jstree.com/ 之前给大家介绍两种浮动闭合的办法CSS清除浮动 万能float闭合,得 http://www.daqianduan.com/3606.html

  9. flash无法导入mp3文件

    用全能音频转换通转换下,一切采用默认即可,点击下载地址 这个软件真心好用. 把mp3拖入其中,点击批量转换,参数默认,即可.

  10. counting elements--codility

    lesson 4: counting elements 1. FrogRiverOne 2. PermCheck 3. MissingInteger 4. MaxCounters lesson 4: ...