如果sqlite3 bind blob在插入一条1mb blob数据时中断了,那么数据会提交了片段还是没提交?

SQLite数据库不能插入一条记录,点击“+”没反应,但点击“-”可以删除。安装SQLite后,点击了升级_百度知道
SQLite数据库不能插入一条记录,点击“+”没反应,但点击“-”可以删除。安装SQLite后,点击了升级
jpg" />点击“+”没反应://b.jpg" target="_blank" title="点击查看大图" class="ikqb_img_alink"><img class="ikqb_img" src="http://b.com/zhidao/pic/item/b5bb5a8e4e4ba32d3d539b600bc47<a href="http.hiphotos.baidu:///zhidao/wh%3D600%2C800/sign=f5edfcbb5a8e4e4ba32d3d539b600bc47.hiphotos.baidu.jpg" esrc="/zhidao/wh%3D450%2C600/sign=f82b4db7b085febb5a8e4e4ba32d3d539b600bc47
虽然它支持的类型只有五种、TEXT(字符串文本)和BLOB(二进制对象)数据类型在Android平台上,s) 等数据类型,只不过在运算或保存时会转成对应的五种数据类型、REAL(浮点数字),而不用关心字段声明的数据类型是什么,SQLite3支持NULL、char(n),但实际上sqlite3也接受varchar(n)。 SQLite最大的特点是你可以把各种类型的数据保存到任何字段中,集成了一个嵌入式关系型数据库——SQLite、INTEGER、decimal(p
你回答的不是我问的意思,看看我补充的图片
其他类似问题
为您推荐:
sqlite的相关知识
等待您来回答
下载知道APP
随时随地咨询
出门在外也不愁随笔 - 58&
文章 - 0&评论 - 9&trackbacks - 0
SQLite3是嵌入在iOS中的关系型数据库,对于存储大规模的数据很有效。SQLite3使得不必将每个对象都加到内存中。
基本操作:
sqlite 的方法
sqlite3 & & & & &*db, 数据库句柄,跟文件句柄FILE很类似
sqlite3_stmt & & &*stmt, 这个相当于ODBC的Command对象,用于保存编译好的SQL语句sqlite3_open(), & 打开数据库,没有数据库时创建。sqlite3_exec(), & 执行非查询的sql语句Sqlite3_step(), 在调用sqlite3_prepare后,使用这个函数在记录集中移动。Sqlite3_close(), 关闭数据库文件还有一系列的函数,用于从记录集字段中获取数据,如sqlite3_column_text(), 取text类型的数据。sqlite3_column_blob(),取blob类型的数据sqlite3_column_int(), 取int类型的数据
(1)打开或者创建数据库
int result = sqlite3_open("/path/databaseFile", &database);
如果/path/databaseFile不存在,则创建它,否则打开它。如果result的值是SQLITE_OK,则表明我们的操作成功。
注意上述语句中数据库文件的地址字符串前面没有@字符,它是一个C字符串。将NSString字符串转成C字符串的方法是:
const char *cString = [nsString UTF8String];
(2)关闭数据库
sqlite3_close(database);
(3)创建一个表格
char *errorM
const char *createSQL = "CREATE TABLE IF NOT EXISTS PEOPLE (ID INTEGER PRIMARY KEY AUTOINCREMENT, FIELD_DATA TEXT)";
int result = sqlite3_exec(database, createSQL, NULL, NULL, &errorMsg);
执行之后,如果result的值是SQLITE_OK,则表明执行成功;否则,错误信息存储在errorMsg中。
sqlite3_exec这个方法可以执行那些没有返回结果的操作,例如创建、插入、删除等。
(4)查询操作
NSString *query = @"SELECT ID, FIELD_DATA FROM FIELDS ORDER BY ROW";
sqlite3_stmt *
int result = sqlite3_prepare_v2(database, [query UTF8String], -1, &statement, nil);
如果result的值是SQLITE_OK,则表明准备好statement,接下来执行查询:
while (sqlite3_step(statement) == SQLITE_ROW) {
int rowNum = sqlite3_column_int(statement, 0);
char *rowData = (char *)sqlite3_column_text(statement, 1);
NSString *fieldValue = [[NSString alloc] initWithUTF8String:rowData];
// Do something with the data here
sqlite3_finalize(statement);
使用过其他数据库的话应该很好理解这段语句,这个就是依次将每行的数据存在statement中,然后根据每行的字段取出数据。
(5)使用约束变量
实际操作时经常使用叫做约束变量的东西来构造SQL字符串,从而进行插入、查询或者删除等。
例如,要执行带两个约束变量的插入操作,第一个变量是int类型,第二个是C字符串:
char *sql = "insert into oneTable values (?, ?);";
sqlite3_stmt *
if (sqlite3_prepare_v2(database, sql, -1, &stmt, nil) == SQLITE_OK) {
sqlite3_bind_int(stmt, 1, 235);
sqlite3_bind_text(stmt, 2, "valueString", -1, NULL);
if (sqlite3_step(stmt) != SQLITE_DONE)
NSLog(@"Something is Wrong!");
sqlite3_finalize(stmt);
这里,sqlite3_bind_int(stmt, 1, 235);有三个参数:
第一个是sqlite3_stmt类型的变量,在之前的sqlite3_prepare_v2中使用的。
第二个是所约束变量的标签index。
第三个参数是要加的值。
有一些函数多出两个变量,例如
sqlite3_bind_text(stmt, 2, "valueString", -1, NULL);
这句,第四个参数代表第三个参数中需要传递的长度。对于C字符串来说,-1表示传递全部字符串。
第五个参数是一个回调函数,比如执行后做内存清除工作。
接下来,做个小例子吧!
1、运行Xcode 4.3,新建一个Single View Application,名称为SQLite3 Test:
2、连接SQLite3库:
按照下图中的红色数字的顺序找到加号:
单击这个加号,打开窗口,在搜索栏输入sqlite3:
选择libsqlite3.dylib,单击Add,添加到工程。
3、进行界面设计。打开ViewController.xib,使用Interface Builder设计界面如下:
设置四个文本框的tag分别是1、2、3、4。
4、在ViewController.h中添加属性和方法:
@property (copy, nonatomic) NSString *databaseFileP
- (void)applicationWillResignActive:(NSNotification *)
5、打开ViewController.m,向其中添加代码:
5.1 在开头添加代码:
#import "sqlite3.h"
#define kDatabaseName @"database.sqlite3"
5.2 在@implementation之后添加代码:
@synthesize databaseFileP
5.3 在viewDidLoad方法中添加代码:
- (void)viewDidLoad
[super viewDidLoad];
// Do any additional setup after loading the view, typically from a nib.
//获取数据库文件路径
NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
NSString *documentsDirectory = [paths objectAtIndex:0];
self.databaseFilePath = [documentsDirectory stringByAppendingPathComponent:kDatabaseName];
//打开或创建数据库
if (sqlite3_open([self.databaseFilePath UTF8String] , &database) != SQLITE_OK) {
sqlite3_close(database);
NSAssert(0, @"打开数据库失败!");
//创建数据库表
NSString *createSQL = @"CREATE TABLE IF NOT EXISTS FIELDS (TAG INTEGER PRIMARY KEY, FIELD_DATA TEXT);";
char *errorM
if (sqlite3_exec(database, [createSQL UTF8String], NULL, NULL, &errorMsg) != SQLITE_OK) {
sqlite3_close(database);
NSAssert(0, @"创建数据库表错误: %s", errorMsg);
//执行查询
NSString *query = @"SELECT TAG, FIELD_DATA FROM FIELDS ORDER BY TAG";
sqlite3_stmt *
if (sqlite3_prepare_v2(database, [query UTF8String], -1, &statement, nil) == SQLITE_OK) {
//依次读取数据库表格FIELDS中每行的内容,并显示在对应的TextField
while (sqlite3_step(statement) == SQLITE_ROW) {
//获得数据
int tag = sqlite3_column_int(statement, 0);
char *rowData = (char *)sqlite3_column_text(statement, 1);
//根据tag获得TextField
UITextField *textField = (UITextField *)[self.view viewWithTag:tag];
//设置文本
textField.text = [[NSString alloc] initWithUTF8String:rowData];
sqlite3_finalize(statement);
//关闭数据库
sqlite3_close(database);
//当程序进入后台时执行写入数据库操作
UIApplication *app = [UIApplication sharedApplication];
[[NSNotificationCenter defaultCenter]
addObserver:self
selector:@selector(applicationWillResignActive:)
name:UIApplicationWillResignActiveNotification
object:app];
5.4 在@end之前实现方法:
//程序进入后台时的操作,实现将当前显示的数据写入数据库
- (void)applicationWillResignActive:(NSNotification *)notification {
//打开数据库
if (sqlite3_open([self.databaseFilePath UTF8String], &database)
!= SQLITE_OK) {
sqlite3_close(database);
NSAssert(0, @"打开数据库失败!");
//向表格插入四行数据
for (int i = 1; i &= 4; i++) {
//根据tag获得TextField
UITextField *textField = (UITextField *)[self.view viewWithTag:i];
//使用约束变量插入数据
char *update = "INSERT OR REPLACE INTO FIELDS (TAG, FIELD_DATA) VALUES (?, ?);";
sqlite3_stmt *
if (sqlite3_prepare_v2(database, update, -1, &stmt, nil) == SQLITE_OK) {
sqlite3_bind_int(stmt, 1, i);
sqlite3_bind_text(stmt, 2, [textField.text UTF8String], -1, NULL);
char *errorMsg = NULL;
if (sqlite3_step(stmt) != SQLITE_DONE)
NSAssert(0, @"更新数据库表FIELDS出错: %s", errorMsg);
sqlite3_finalize(stmt);
//关闭数据库
sqlite3_close(database);
6、实现关闭键盘,参考中的第2步。其中,backgroundTap方法如下:
//关闭键盘
- (IBAction)backgroundTap:(id)sender {
for (int i = 1; i &= 4; i++) {
UITextField *textField = (UITextField *)[self.view viewWithTag:i];
[textField resignFirstResponder];
7、运行程序:
刚运行时显示如下面左图:
在各个文本框输入内容,如上面右图。然后按Home键,这样,就执行了写入数据的操作。
第一次运行程序时,在SandBox的Documents目录下出现数据库文件database.sqlite3:
此时退出程序,再次运行,则显示的就是上次退出时的值。
阅读(...) 评论()sqlite存取blob数据 SQLIte如何设置自 - 小小知识站
sqlite存取blob数据 SQLIte如何设置自
最近有网友提出“sqlite存取blob数据 SQLIte如何设置自”等问题,小小知识站提取了各大知名网站有关“sqlite存取blob数据 SQLIte如何设置自”的部分信息,请注意,文中的内容不代表本站的观点,不要相信任何联系方式。下文是关于“sqlite存取blob数据 SQLIte如何设置自”的一些信息:
问题:SQLIte如何设置自动增长的字段
回答:...置的 类似问题:SQLite如何设置自动增长的主键 sqlite 如何让id自动编号 狗问问 为什么我在sqlite数据库中插入数据后罗列列中没有自动增长 SQLite的自增长序列能否删除记录后重新增长? asp 中SQLite数据库userId的自动增长列如何插入数据?如 sqlite expert professional 里怎么设置自动增长? SQlite如何重新排列主键
问题:Android数据的四种存储方式
回答:作为一个完整的应用程序,数据存储操作是必不可少的。因此,Android系统一共提供了四种数据存储方式。分别是:1.SharePreference2.SQLite3.File4.Content Provider由于Android系统中,数据基本都是私有的,都是存放于data/data/程序包名目录下,所以要实现数据共享,正确方式是使用Content
Provider。SharedPreference:除SQLite数据库外,另一种常用的数据存储方式,其本质就是一个xml文件,常用于...
问题:sqlite有没有把字符串转成double型,整型的函数?回答:转换表达式,该表达式的语法规则如下:CAST(expr AS target_type)该表达式会将参数expr转换为target_type类型具体使用可以查一下CAST的范例 类似问题:SQLiteDatabase类中的execSQL(String sql语句可以这样写不? 关于JButton事件处理实现查询功能 急求C语言问题 oc读取mysql数据库数据完整代码?... 问题:sqlite中以GBK存的中文
回答:...么QT lineedit英文和数字字符串显示乱码?没有中文啊 如何将QString转换为char 关于PHP中MySQL开发UTF8数据库的中文输入乱码的问题, 用Qt Creator 编写GUI程序, 源代码用UTF 问一下,在qt连接数据库中,我创建一个表,为什么里面的中 qt 编码问题 qt creator 5.0.2 新建纯C项目(非Qt项目),中文输出为乱
问题:Windows上如何安装Sqlite实现步骤
回答:1.获得命令行程序 SQLite命令行程序(CLP)是开始使用SQLite的最好选择,按照如下步骤获取CLP: 1).打开浏览器进入SQLite主页,.sqlite.。 2).单击页面顶部的下载链接(Download)选项,进入下载页面。 3).滚动鼠标到&Prepiled Binaries for Windows&,选择sqlite-shell-win32-x86-3071401 (第一项),点击下载。 4).使用解压工具,将其解压。zip文件中包含一个sqlite3.exe文件,可以从解压文件所在位...
问题:ODBC和OLEDB的连接字符串
回答:ODBC连接适合数据库类型 连接方式access Driver={microsoft access driver(*.mdb)};dbq=*.uid=pwd=dBase Driver={microsoft dbase driver(*.dbf)};driverid=277;dbq=------------;oracle Driver={microsoft odbc for oracle};server=oraclesever.uid=pwd=MSSQL server Driver={sql server};server=database=uid=pwd=MS text Driver={microsoft text driver(*. *.csv)};dbq=-----;extensions=asc,csv,tab,Persist SecurityInfo=Visual Foxpro Drive...
问题:华为P6电信版开启G卡上网教程
回答:...选择system, 然后在顶上选择+后,在name输入gsm_enable_ct,value里输入1,保存退出。这个是打开默认数据的选择(切换C网或G网,在国际漫游设置-网络选择和设置的CDMA上的)。注意,手机恢复出厂值后这个设置会消失,请重新添加。5、手机重启,然后你就可以自由切换C网和G网了。6、切换方式: 设置-国际漫游设置-网络选择和设置-默认数据里面选择CDMA或GSM。关于G网的APN,系统中已...
问题:怎么修改射手播放器的字幕保存位置
回答:...tabase Browser的软件2、接下来我们打开射手播放器的安装文件夹下,在文件夹下找到settings.db这个数据库文件。3、我们SQLite Database Browser打开这个文件,选择Browse Data。3、接着点击搜索按钮,按照图中的信息寻找以下的值。找到之后双击。4、将原本为0的值更改为1,并点击Apply Changes进行保存。5、最后,我们关闭对话框之后保存文件即可。现在射手自动下载的字幕就会保存至相应...
问题:微软在Win8.1中Skydrive新增脱机文件存取
回答:...但对于经常网络环境不佳的用户来说却并非如此。微软今日宣布Win8.1系统将支持Skydrive脱机文件存取,这项新功能对于网络环境不佳的用户无疑是一大福音。与其竞争对手Dropbox不同,用户不必把存储在云端数据去全部放入本地硬盘中,而是在本地建立一个索引文件,在需要对某些文件进行读取或编辑时,才会去下载源文件。目前已下载安装Windows 8.1预览版的用户便可以亲自体验...
问题:CL延迟是什么
回答:CL反应时间是衡定内存的另一个标志。CL是CAS
Latency的缩写,指的是内存存取数据所需的延迟时间,简单的说,就是内存接到CPU的指令后的反应速度。一般的参数值是2和3两种。数字越小,代表反应所需的时间越短。在早期的PC133内存标准中,这个数值规定为3,而在Intel重新制订的新规范中,强制要求CL的反应时间必须为2,这样在一定程度上,对于内存厂商的芯片及PCB的组装工艺...
问题:怎么连接app到一个sql 数据库?如果不能访问题详情数据库的话,那数据回答:只能访问本地数据库,sqlite、sqlce都成远程的一般通过web server来访问 查看原帖 类似问题:asp连接sql数据库有几种方法啊??? 用VC写的程序连接到SQL数据库,怎么不能运行啊 “安全”选项卡时显示说我无法连接到SQL数据库?? 当VB连接到SQL数据库后,关闭SQL数据库还是可以连接上 怎么样将C++编写的应用程序连接到SQL...... 问题:缓存容量是什么
回答:缓存(Cache
memory)是硬盘控制器上的一块内存芯片,具有极快的存取速度,它是硬盘内部存储和外界接口之间的缓冲器。由于硬盘的内部数据传输速度和外界介面传输速度不同,缓存在其中起到一个缓冲的作用。缓存的大小与速度是直接关系到硬盘的传输速度的重要因素,能够大幅度地提高硬盘整体性能。当硬盘存取零碎数据时需要不断地在硬盘与内存之间交换数据,如果有大...
问题:0X80L这是什么进制的数据,为什么后面有个L
回答:0x确实表示这是个16进制的数据,我记得后面的L表示这个数据是long类型的数据 类似问题:求助啊!!!!!!!怎样将得到的16进制数据快速的在其 SQLite 居然不支持0x这样的16进制数据表示? C#代码:将输入的10进制正整数转换为罗马数据。假设罗马 2、8位二进制数为一个什么,它是计算机中基本的数据 第[3]题、有关二进制的论述,下面(
问题:MongoDB学习笔记二 通过samus驱动实现基本数据操作
回答:...址:点击下载samus驱动下载地址:点击下载本篇将从samus驱动入手讲解数据库访问,国际惯例,存取Hello World!。二、通过samus驱动实现HelloWorld存取在进行下述操作之前,请先确定MongoDB服务已经开启,不知道怎么开启服务,请看上篇。下载驱动,新建控制台项目,并添加对MongoDB.dll的引用,如果你下载的是驱动源码,编译一遍引用生成的DLL即可。基本代码如下:复制代码 代码如下...
分享给小伙伴们:
09-2208-1506-2710-20
09-0609-1707-1408-20
也许你感兴趣安卓需要存一些参数信息、测量数据和计算结果,File和SQlite哪个好?_百度知道
安卓需要存一些参数信息、测量数据和计算结果,File和SQlite哪个好?
新手对这些概念的理解比较差,求解说哪个copy到电脑查看方便?如果要转EXCEL之后copy哪个方便
  public Cursor rawQueryWithFactory (SQLiteDatabase。2,然后将更新列应用到这些行,用于执行SQL查询语句;  (4)rawQuery()方法,所有的操作都是以表为中心的、维护等操作,372,使用SQLite一般只需要带上它的一个动态库,进而确保了表中的所有字段都是可寻址的。具体使用方法可以参阅博文《Android学习笔记34、聚集和通常的管理信息而设计的声明式语言, boolean distinct,用于管理SQLite事务的方法(如beginTransaction(),所有的子句都是可选的,而是指定应用程序中的SQLite数据库的版本,列称为字段:studentId, String sql、openOrCreateDatabase()等);  其中.数据库操作辅助类SQLiteOpenHelper  Android提供了一个重要的类SQLiteOpenHelper:  (1)NULL、VARCHAR和INTEGER?)用这个数组中的值代替,没有独立运行的进程, String[] selectionArgs,查询数据是通过Cursor类来实现的:  public void execSQL (String sql),它提供了很多有关查询的方法:  public Cursor queryWithFactory (SQLiteDatabase,供开发者使用。SQLite在便携性。GROUP BY和HAVING一起工作可以对GROUP BY进行约束。目前最常用的SELECT命令由三个子句组成,SQLite数据库中的所有信息(比如表。  一条创建表的命令示例如下.cnblogs, 3
  studentAge INTEGER)。2。  SQLiteOpenHelper的构造函数原型如下,当该版本号发生变化时。column_definitions由用逗号分隔的字段列表组成,WHERE子句使用断言识别要删除的行。  SQLite为主键提供自增长功能, String[] selectionArgs, String[]  通过以上的语句。4:    SELECT studentId。它的代码与应用程序代码也是在一起的, constraints]),对系统配置信息进行保存。WHERE子句使用断言识别要修改的行,每个关键字(如FROM,这种表只存活于当前会话。参数factory是SQLiteDatabase;当应用程序第一次访问数据库时.2插入记录  使用INSERT命令可以一次插入一条记录,String orderBy), String table,其基本语法形式如下.cnblogs;可以减少网络调用相关的消耗,通过这个参数:  UPDATE tab_student SET studentName=”tom”。  (1)execSQL()方法。图1 SQLiteOpenHelper类的方法  其中,SQLite将为该字段创建默认值,String orderBy;  (5)rawQueryWithFactory()方法, String limit),854;  (2)query()方法, String groupBy, String selection,而不是填补空白, String[] selectionArgs:使用文件存储数据》。  (2)Shared Preferences, String
orderBy,这些值是与column_list中的字段一一对应的, String having:数据共享,第一个版本Alpha发布于2000年。这两个方法都有一个版本能够接收一个字符串数组selectionArgs作为参数;  其中、映射、WHERE.CursorFactory cursorFactory,返回值是Cursor对象、groupBy;  public Cursor query (boolean distinct.2.SQL基本命令  SQL是与关系型数据库通信的唯一方式.数据库类SQLiteDatabase  SQLiteDatabase类用来完成对数据库的操作任务,除电脑上使用的操作系统之外:    DELETE FROM tab_student WHERE studentId=1, String[]columns,用于应用程序之间数据的访问,会根据存入的值自动进行判断,该表包含3个字段。如果想要SQLite使用唯一的自动主键值,value_list是用逗号分隔的值列表,便可以使用如下的语句完成,column_list是用逗号分隔的字段名称,它将为新插入的记录产生新的(不是回收的)rowid,并作为要插入的值,775,SQLite会自动搜索该字段还未使用的值,tab_name指明将数据插入到哪个表中;  通过以上的语句, studentAge FROM tab_student WHERE studentId=1, String limit,Cursor指向的就是每一条记录、一个域(类型)和一个逗号分隔的字段约束,则会调用onOpen()方法,是为构建, String groupBy,便可以将刚才插入的主键为studentId=1的记录更新为studentName=”tom”,域是指存储在该列的信息的类型,用TEMP或TEMPORARY关键字声明的表是临时表,新创建的rowid不一定是按照严格顺序增长的。参数name表示Android的数据库名字.SQLite简介  SQLite是一款开源的;在一个不存在的数据库上调用任何方法时.4删除记录  使用DELETE命令可以删除表中的记录.2,如果版本号发生了变化的话:不用担心防火墙或者地址解析;  (3)queryWithFactory()方法、更新和删除语句等,String editT  如上。  (4)SQLite:通过网络来存储和获取数据.2:使用Shared Preferences方式存储数据》使用SQLite方式存储数据  在Android中一共提供了5种数据存储方式,可以参阅《SQLite权威指南》一书的第三章和第四章。  在讲解SQL基本命令之前,而不必直接使用SQL语句.com/menlsh/archive//3019588,要查询刚才插入的记录, String orderBy,并按照一一对应的位置关系进行取代,它是一款嵌入式数据库。UPDATE命令的一般格式为:空值  (2)INTEGER,还可以使用LIMIT限定结果集的大小和范围,getReadableDatabase()方法以只读状态打开SQLiteOpenHelper对象中指定的SQLite数据库;  public Cursor query (String table.html" target="_blank">http,这里只是对其进行了简单的介绍, String selection,则会调用onUpgrade()或onDowngrade()方法;  比如,包含应用程序所需的共享资源,或者说嵌入其中,必须获得独占锁定.rawQuery()方法时, CancellationSignal cancellationSignal)。具体使用方法可以参阅博文《Android学习笔记35,该版本并非SQLite的真正版本://www,表名必须与其他标识符不同, String[] columns.CursorFactory类对象:浮点型  (4)TEXT;getReadableDatabase()方法和getWriteableDatabase()方法类似。其中。主键确保了每一行记录在某种方式上与表中的其他行记录是不同的(唯一的),并且能够对数据进行使用;写操作;2, String selection, String[]
selectionArgs,参数包括table,一旦连接断开.1 SQLite支持的数据类型  SQLite采用动态数据存储类型://www。这里就不一一介绍了。  比如,我们介绍了SQL中最基本和最常用的CREATE, String[]
selectionArgs:  SELECT [distinct] heading   FROM tables   WHERE predicate   GROUP BY columns   HAVING predicate   ORDER BY columns   LIMIT count,比如创建,每个字段定义包括一个名称、更新。  比如、having, String table。如果没有明确指出创建的表是临时表,String editTable),数组中的每个成员捆绑了一个查询, Object[] bindArgs),但是,也是关系型数据库中信息的标准单位。参数version表示应用程序所用的数据库的版本, “jack”。第二个参数bindArgs接收一个数组,字段赋值的格式为column_name=value。此外,便可以使用如下的语句完成,会得到一个Cursor对象,很多手机上使用的操作系统同样可以运行,每个子句由关键字和跟随的参数构成,有关SQLite中SQL命令的详细使用方法, String selection,可以指定排序方式为ASC(默认的升序)或DESC(降序)。当达到最大值时。  SQLiteDatabase类中常用的用于执行SQL语句的方法有以下一些,用来存储大量的数据;  public Cursor rawQuery (String sql。  SQLiteOpenHelper类的所有方法如图1所示。<a href="http。  此外:二进制对象2、过滤, String orderBy。ORDER BY使记录集在返回之前按一个或多个字段的值进行排序。将数据库客户端与服务器运行在同一个进程中,用于测试数据库是否被锁住的方法(如isDbLockedByCurrentThread():  public Cursor query (String table.游标类Cursor  在Android中,因此.3更新记录  使用UPDATE命令可以更新表中的记录、limit等SQL语句关键字,可以在主键定义INTEGER PRIMARY KEY中加入关键字AUTOINCREMENT:  DELETE FROM table_name WHERE predicate。  SQLiteDatabase类提供了大约50个方法,036,便可以使用如下的语句完成,如图2所示、FROM。  本篇博文介绍第四种方式、紧凑性;  其中, String sql.1创建表  表是由行和列组成的,约束用来控制什么样的值可以存储在表中或特定的字段中;  其中,CancellationSignal cancellationSignal)。5,有必要先了解一下SQLite所支持的数据类型都有哪些。因此,便插入了一条studentName=”jack”,就会被自动销毁, String having;可以简化数据库管理并使程序更容易部署,通过Android自带的SQLite数据库存储数据:  public SQLiteOpenHelper(Context context、columns,SQLiteDatabase对象将把捆绑的SQL语句中的问号(, String groupBy,该命令可以修改一个表中一行或者多行中的一个或多个字段、触发器等)都包含在一个文件内,以及获取数据库基本信息的方法(如getMaximumSiza()。  SQLite和C&#47、UPDATE, String[]columns.query()或SQLiteDatabase,将会在数据库中持久存在。1、WHERE:带符号的整型  (3)REAL,当定义字段类型为INTEGER PRIMARY KEY时,rowid可能被回收并在后面的插入中使用, String[] columns、orderBy, studentAge=”23”的记录, String[] selectionArgs,除了SELECT之外:  INSERT INTO tab_student (studentId,除此之外还有一些用于打开数据库的方法(如openDatabase(), String limit), String[] selectionArgs), CancellationSignal cancellationSignal),807,要删除刚才插入的记录。在发出独占锁定后。在某个进程向数据库执行写操作之前,table_name指明所要删除的记录位于哪个表中,其数据类型分别为,任何想要修改数据库的操作都是不允许的;  public void execSQL (String sql,用于辅助用户对SQLite数据库进行操作;getWriteableDatabase()方法也是打开数据库。2.5查询记录  SELECT命令是查询数据库的唯一命令。  此外, studentAge=”25”了、读取, boolean distinct。  SQLite数据库通过数据库级上的独占性和共享锁来实现独立事务处理;  public Cursor queryWithFactory (SQLiteDatabase, String[] selectionArgs、高效性和可靠性方面有着突出的表现;  其中、排序,该默认值确保整数值是唯一的:  CREATE [TEMP&#47.2, String[] columns,这也是数据库中最常见的表,offset,[]中的内容是可选的,我们创建了一个名为tab_student的表, String name,通过使用关键字PRIMARY KEY、INSERT, String having。从表中删除记录时、更新和修改表,SQLite数据库还提供了多语言的编程接口、嵌入式关系型数据库,offset指定偏移的记录数、插入:  UPDATE tab_name SET update_list WHERE predicate, String[] selectionArgs,向刚才创建的tab_student表中插入一条记录, studentAge) VALUES (1, String
limit。这些方法允许将SQL语句传递给相关方法。同时,上述命令中的table_name表示表名。那么如何使用SQL命令创建一张表呢;不用浪费时间管理复杂的授权和权限:  INSERT INTO tab_name (column_list) VALUES (value_list),都会隐式的调用SQLiteOpenHelper对象的onCreate()方法,当我们使用SQLiteDatabase,该记录的主键为studentId=1。  在上述的SELECT命令通用形式中。它专注于信息处理, studentName,比如表的选择:  public Cursor rawQuery (String sql:通过FileInputStream和FileOutputStream对文件进行操作;  public Cursor query (boolean distinct,具体可以参阅SQLiteDatabase类的API帮助文档;S模式的数据库软件不同, String limit)。2, String orderBy、endTransaction()等), String selection、最复杂的命令。SQLite支持以下5种数据类型,CREATE命令的一般格式为;  public Cursor rawQueryWithFactory (SQLiteDatabase,这个参数是一个SQL语句。execSQL()方法用于运行那些没有返回值的查询语句.2 SQL基本命令  表是探索SQLite中SQL的起点、getVersion()等),与所服务的应用程序在应用程序进程空间内共生共存。2,但是允许数据库正常的读&#47, String groupBy,count指定返回记录的最大数量, String groupBy,参数context表示应用程序运行的环境。SELECT命令也是SQL命令中最大、易用性,行称为记录。3, 23),该字段的最大值是9。因此不存在数据库的客户端和服务器:  (1)Files、DELETE和SELECT命令, int version)。这意味着多个进程可以在同一时间从同一数据库读取数据,我们指定了字段studentId所在的列是主键;  其中.2。  数据库服务器在程序中的好处是不需要网络配置或管理;  至此.CursorFactory factory:SELECT, String table,可以省去不少的操作及麻烦.CursorFactory cursorFactory,INSERT命令的一般格式为, CancellationSignal cancellationSignal), String[] selectionArgs、HAVING等)都是一个单独的子句?2:INTEGER.CursorFactory cursorFactory, 2
  studentName VARCHAR(20)。SQLite使用64-bit单符号整数主键。  (3)Content Providers、isDbLockedByOtherThread()等), studentName。和UPDATE命令一样,DELETE命令的一般格式为,223, String
having, String table。  rawQuery()方法和rawQueryWithFactory()方法也都有一个参数sql, String having,将会触发SQLiteOpenHelper类中的onUpgrade()或onDowngrade()方法。当然了,其他的读写操作将不会再发生,这些字段必须是表中存在的。  query()方法和queryWithFactory()方法是在数据库中运行一些轻量级的单查询语句、视图:字符串文本  (5)BLOB、写入:Android自带的轻量级关系型数据库。SQLite数据库还支持大部分操作系统,则创建的是基本表, SQLiteDatabase:  SELECT heading FROM tables WHERE predicate,close()方法用于关闭SQLiteOpenHelper对象中的SQLite数据库、分组, String selection、插入,支持SQL语言;TEMPORARY] TABLE table_name (column_definitions [,作为托管它的程序的一部分, studentAge=”25” WHERE studentId=1,execSQL()方法都有一个参数sql,update_list是一个或多个字段赋值的列表。  CREATE TABLE命令至少需要一个表名和一个字段名.CursorFactory cursorFactory。  比如。  (5)Network。  SELECT命令的通用形式如下;  其中。AUTOINCREMENT关键字阻止rowid回收,要更新刚才插入到tab_student表中的记录,便可以使用如下的语句完成,就可以享受它的全部功能:常用来存储键值对形式的数据, String
having,方便管理和维护, String
groupBy,但是只有一个可以写入数据:1   CREATE TABLE tab_student (studentId INTEGER PRIMARY KEY AUTOINCREMENT,用于存储查询Android SQLite数据库的结果集、 studentName和/menlsh/archive//3019588,分别为。  使用CREATE命令可以创建表
来自团队:
其他类似问题
为您推荐:
安卓的相关知识
等待您来回答
下载知道APP
随时随地咨询
出门在外也不愁}

我要回帖

更多关于 sqlite blob 大小 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信