在没有使用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学习笔记知识点

    AJAX用法安全限制JSONPCORS面向对象编程创建对象构造函数原型继承class继承 AJAX 用法 AJAX不是JavaScript的规范,它只是一个哥们“发明”的缩写:Asynchronous ...

  2. Mac安装最新tensorflow遇到的坑,记录下方便后人

    之前其他mac电脑安装tensorflow时候一切顺利,一行命令sudo pip install tensorflow就高搞定了,但是今天在新mac上安装tensorflow时候出现了一个bug,搞了 ...

  3. 用eclipse打包可执行的jar(含第三方jar包)

    在eclipse中的解决方式如下: 在工程目录下(与src同层)建立lib目录,将第三方Jar包放到这个目录里(copy,paste即可)[如果直接引用本地的jar,一旦换电脑就呵呵了...] 右击工 ...

  4. BZOJ4556 Tjoi2016&Heoi2016 字符串【后缀自动机+倍增+线段树合并】

    Description 佳媛姐姐过生日的时候,她的小伙伴从某东上买了一个生日礼物.生日礼物放在一个神奇的箱子中.箱子外边写了 一个长为n的字符串s,和m个问题.佳媛姐姐必须正确回答这m个问题,才能打开 ...

  5. 如何将常规的web 应用程序转化为云上多租户 SaaS 解决方案

    如何将web 应用程序转化为多租户 SaaS 解决方案 https://www.ibm.com/developerworks/cn/cloud/library/cl-multitenantsaas/i ...

  6. CnetOS7使用yum方式安装nginx

    之前一直使用源码包安装,但是对于需要一直进行重新安装的测试环境来说安装起来还是过于麻烦了.今天搜索发现能够进行yum方式的安装,特此记录. 新建yum文件,yum源是nginx的官网. # vim / ...

  7. 《DSP using MATLAB》示例Example 8.25

  8. ES6变量解构赋值

    ES6 允许按照一定模式,从数组和对象中提取值,对变量进行赋值,这被称为解构ES6之前我们申明多个变量需要按照下面的方法: let l a=1; let b=2; let c=3; let d=4; ...

  9. fortran语法笔记

    1,数据类型,fortran支持整形,real型,logical型,char型,复数型.整形分为为长整形和短整形定义长整形的方法 同时声明多个变量的话可以用逗号隔开. 加两个冒号的话可以直接在声明的时 ...

  10. drone 学习三 条件步骤

    1. 基本格式 pipeline: slack: image: plugins/slack channel: dev + when: + branch: master 2. 几种条件类型 a. bra ...