flex sqlite基本用法
flex sqlite基本用法
页面
<?xml version="1.0" encoding="utf-8"?>
<s:WindowedApplication xmlns:fx="http://ns.adobe.com/mxml/2009"
xmlns:s="library://ns.adobe.com/flex/spark"
xmlns:mx="library://ns.adobe.com/flex/mx">
<fx:Script>
<![CDATA[
import sqlTest.SQLTest;
protected function button1_clickHandler(event:MouseEvent):void{
var sql:SQLTest = new SQLTest();
}
]]>
</fx:Script>
<s:Button x="192" y="221" label="按钮" click="button1_clickHandler(event)"/>
</s:WindowedApplication>
sqlite类
package sqlTest{
import flash.data.SQLConnection;
import flash.data.SQLResult;
import flash.data.SQLStatement;
import flash.events.SQLErrorEvent;
import flash.events.SQLEvent;
import flash.filesystem.File;
import flash.net.Responder;
import mx.controls.Alert;
public class SQLTest{
private var con:SQLConnection;
private var stmt:SQLStatement;
private var creatTableSQL:String ="CREATE TABLE IF NOT EXISTS user ( "+
"userId INTEGER PRIMARY KEY AUTOINCREMENT, " +
"userName TEXT, " +
"password TEXT )";
private var insertSQL:String = "INSERT INTO user (userName, password) VALUES ('admin', 'admin')";
//语句参数 :itemName @firstName 或者 ? 使用问号时只能用索引方式设值 索引从0开始
private var insertSQLparams:String = "INSERT INTO user (userName, password) VALUES (:userName, @password)";
private var deleteSQLparams:String = "delete from user where userName=:userName"
private var updateSQLparams:String = "update user set password= ? where userName= ?";
private var selectSQL:String = "select userName,password from user"
public function SQLTest(){
initApp();
}
private function initApp():void{
var file:File = File.applicationStorageDirectory.resolvePath("MySQLite.sqlite")
con = new SQLConnection();
//异步
// asyncOpen(con,file);
//同步
open(con,file);
}
private function open(con:SQLConnection,file:File):void{
try{
//若参数为空则建立在内存上 若文件不存在则自动创建
con.open(file);
con.begin();
Alert.show("Create/open database finished");
stmt = new SQLStatement();
stmt.sqlConnection = con;
//1.create table
stmt.text = creatTableSQL;
//2.insert data
stmt.text = insertSQL;
//带占位符insert
// stmt.text = insertSQLparams;
// stmt.parameters[":userName"] = "aaa";
// stmt.parameters["@password"] = "admin";
//3.delete
// stmt.text = deleteSQLparams;
// stmt.parameters[0] = "admin";
//4.update
// stmt.text = updateSQLparams;
// stmt.parameters[0] = "aaa";
// stmt.parameters[1] = "aaa";
//5.select
// stmt.text = selectSQL;
// var responder:Responder = new Responder("resultHandler", "errorHandler");
// stmt.execute(1,responder);//此处可以指定返回行数 ,若不使用responder则添加2个监听器如下
// stmt.addEventListener(SQLEvent.RESULT,resultHandler);
// stmt.addEventListener(SQLErrorEvent.ERROR,errorHandler);
stmt.execute();
var result:SQLResult = stmt.getResult();
//row
if(result!=null){
//上一次INSERT 操作的行标识符 如果执行的语句不是 INSERT 语句,则该值为 0
var row:Number = result.lastInsertRowID;
row = result.rowsAffected;
Alert.show("Row"+row.toString());
}
//data
if(result.data!=null){
var numResults:int =result.data.length;
for (var i:int = 0; i < numResults; i++) {
var re:Object = result.data[i];
var output:String = "userName: " + re.userName;
output += "; password: " + re.password;
Alert.show(output);
}
}
Alert.show("finished");
con.commit();
}catch(error:SQLErrorEvent){
con.rollback();
errorHandler(error);
}
}
private function asyncOpen(con:SQLConnection,file:File):void{
// openAsync SQLConnection 对象操作导致错误时调度
con.addEventListener(SQLErrorEvent.ERROR,errorHandler);
// openAsync 方法调用操作成功完成时调度
con.addEventListener(SQLEvent.OPEN,openHandler);
//若参数为空则建立在内存上 若文件不存在则自动创建
con.openAsync(file);
}
private function openHandler(evt:SQLEvent):void{
Alert.show("Create/open database finished");
stmt = new SQLStatement();
stmt.sqlConnection = con;
stmt.text = creatTableSQL;
stmt.addEventListener(SQLEvent.RESULT, createResult);
stmt.addEventListener(SQLErrorEvent.ERROR, createError);
stmt.execute();
}
private function errorHandler(evt:SQLErrorEvent):void{
Alert.show("SQLErrorEvent");
Alert.show(evt.error.message);
Alert.show(evt.error.details);
}
private function createResult(event:SQLEvent):void {
Alert.show("create table finished");
}
private function createError(event:SQLErrorEvent):void {
Alert.show("Error message:", event.error.message);
Alert.show("Details:", event.error.details);
}
}
}
flex sqlite基本用法的更多相关文章
- Flex 布局相关用法
前言: 布局的传统解决方案,基于盒状模型,依赖 display属性 + position属性 + float属性.它对于那些特殊布局非常不方便,比如,垂直居中 就不容易实现. 2009年,W3C提出了 ...
- Flex的基础用法【转】
//获得屏幕的分辨率 var x:Number=Capabilities.screenResolutionX; var y:Number=Capabilities.screenResolutionY; ...
- flex sqlite 操作blog 二进制数据
1, 通常的操作方式: 首先我们建立表:CREATE TABLE "pages" ("id" varchar, "data& ...
- Android 操作SQLite基本用法
一.SQLite的介绍 1.SQLite简介 SQLite是一款轻型的数据库,是遵守ACID的关联式数据库管理系统,它的设计目标是嵌入 式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非常的 ...
- sqlite query用法
本文转自http://blog.csdn.net/double2hao/article/details/50281273,在此感谢作者 query(table, columns, selection, ...
- 数据持久化之sqlite基本用法
一.ACID 即原子性(Atomicity).一致性(Consistency).隔离性(Isolation).持久性(Durability). 原子性:整个事务中的所有操作,要么全部完成,要么全部不完 ...
- sqlite基本用法
DDL-数据定义语言 CREATE 创建一个新的表,一个表的视图,或者数据库中的其他对象. ALTER 修改数据库中的某个已有的数据库对象,比如一个表. DROP 删除整个表,或者表的视图,或者数据库 ...
- flex布局常见用法小结
1,display:flex 这个在父容器中声明: 2,flex-direction:row / column 默认为横向,也在父容器中设置,定义flex布局的主轴方向:一条轴为主轴,那么另一条轴自然 ...
- Android SQLite基本用法
SQLite简介 Google为Andriod的较大的数据处理提供了SQLite,他在数据存储.管理.维护等各方面都相当出色,功能也非常的强大.SQLite具备下列特点: 1.轻量级 使用 SQLit ...
随机推荐
- 用css3动画 @keyframes里设置transform:rotate(); 控制动画暂停和运动用属性:animation-play-state:paused暂停,在微信和safari里设置paused无效,在QQ里是正常的
这几天遇到了两个很奇葩的问题,终于找到原因,趁还记得解决方法,赶紧记下来: 用css3动画 @keyframes里设置transform:rotate(); 控制动画暂停和运动可以用属性:animat ...
- Mysql 忘记root密码后修改root密码
1.修改my.cnf: 在mysqld进程配置文件中添加skip-grant-tables,添加完成后记住保存. 2.重新启动MYSQL数据库: service mysqld restart 2.修改 ...
- 《Android进阶》之第二篇 launcher
public boolean addViewToCellLayout(View child, int index, int childId, LayoutParams params, boolean ...
- 01 json环境搭建
1 导包 <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.o ...
- ProxySQL的相关维护说明
背景: 前面的2篇文章MySQL ProxySQL读写分离使用初探和MySQL ProxySQL读写分离实践大致介绍了ProxySQL的使用说明,从文章的测试的例子中看到ProxySQL使用SQLIT ...
- 红包项目总结---MVC版
起因: 针对传统版的明显缺陷做优化.主要是提升可维护性. 效果 线上: 未发布 线下:http://10.27.5.1/svn/FED/code/hongbao/year-end hb-fac ...
- bug 修复:上传库存时前端回发file_name参数丢失;
# tmp_file = os.path.join(os.path.abspath('youcart/tmp'), json.loads(request.data).get('file_name')) ...
- 深入探索C++对象模型(四)
Function语意学(The Semantics of Function) static member functions不可能做到的两点:(1)直接存取nonstatic数据,(2)被声明为con ...
- java基础(三章)
java基础(三章) 一.基本if结构 1.流程图 l 输入输出 l 判断和分支 l 流程线 1.1 简单的if条件判断 if(表达式){ //表 ...
- css清除浮动的八大方法
清除浮动是每一个 web前台设计师必须掌握的机能.css清除浮动大全,共8种方法. 浮动会使当前标签产生向上浮的效果,同时会影响到前后标签.父级标签的位置及 width height 属性.而且同样的 ...