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基本用法的更多相关文章

  1. Flex 布局相关用法

    前言: 布局的传统解决方案,基于盒状模型,依赖 display属性 + position属性 + float属性.它对于那些特殊布局非常不方便,比如,垂直居中 就不容易实现. 2009年,W3C提出了 ...

  2. Flex的基础用法【转】

    //获得屏幕的分辨率 var x:Number=Capabilities.screenResolutionX; var y:Number=Capabilities.screenResolutionY; ...

  3. flex sqlite 操作blog 二进制数据

    1,              通常的操作方式: 首先我们建立表:CREATE TABLE "pages" ("id" varchar, "data& ...

  4. Android 操作SQLite基本用法

    一.SQLite的介绍 1.SQLite简介 SQLite是一款轻型的数据库,是遵守ACID的关联式数据库管理系统,它的设计目标是嵌入  式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非常的 ...

  5. sqlite query用法

    本文转自http://blog.csdn.net/double2hao/article/details/50281273,在此感谢作者 query(table, columns, selection, ...

  6. 数据持久化之sqlite基本用法

    一.ACID 即原子性(Atomicity).一致性(Consistency).隔离性(Isolation).持久性(Durability). 原子性:整个事务中的所有操作,要么全部完成,要么全部不完 ...

  7. sqlite基本用法

    DDL-数据定义语言 CREATE 创建一个新的表,一个表的视图,或者数据库中的其他对象. ALTER 修改数据库中的某个已有的数据库对象,比如一个表. DROP 删除整个表,或者表的视图,或者数据库 ...

  8. flex布局常见用法小结

    1,display:flex 这个在父容器中声明: 2,flex-direction:row / column 默认为横向,也在父容器中设置,定义flex布局的主轴方向:一条轴为主轴,那么另一条轴自然 ...

  9. Android SQLite基本用法

    SQLite简介 Google为Andriod的较大的数据处理提供了SQLite,他在数据存储.管理.维护等各方面都相当出色,功能也非常的强大.SQLite具备下列特点: 1.轻量级 使用 SQLit ...

随机推荐

  1. [C#] BarcodeLib -- 一个精简而不失优雅的条形码生成库

    BarcodeLib -- 一个精简而不失优雅的条形码生成库 引言 在百度进行“C# 条形码”等类似关键字搜索的时候,基本上是使用 ZXing 类库进行条形码的生成.今天我所介绍的是另一款类库 Bar ...

  2. Spring切面通知执行的顺序(Advice Order)

    问题描述 如果在Spring的程序中同时定义了环绕通知(Around)和前置通知(Before)..那么,有以下问题: 1.怎么让两个切面通知都起作用 2.或者让两者切面按自己指定的顺序进行执行? 3 ...

  3. eval全局作用域和局部作用域的坑!

    1.eval 是个函数,他可以被赋值给变量,例如   var evalg = eval;  evalg("alert(1)"); 2.eval被赋值时,也会把当前eval所处的变量 ...

  4. swift pod第三方OC库使用use_frameworks!导致#import提示无法找到头文件

    以MBProgressHUD为例子 swift中Podfile文件一般都会加上use_frameworks! 这样就可以直接通过import MBProgressHUD来访问MBProgressHUD ...

  5. 【设计模式】之开闭原则(OCP)

    开闭原则是面向对象设计的一个重要原则,其定义如下: 开闭原则(Open-Closed Principle, OCP):一个软件实体应当对扩展开放,对修改关闭.即软件实体应尽量在不修改原有代码的情况下进 ...

  6. 利用R语言进行交互数据可视化(转)

    上周在中国R语言大会北京会场上,给大家分享了如何利用R语言交互数据可视化.现场同学对这块内容颇有兴趣,故今天把一些常用的交互可视化的R包搬出来与大家分享. rCharts包 说起R语言的交互包,第一个 ...

  7. 并行类加载与OSGI类加载

    这回来分析一下OSGI的类加载机制. 先说一下OSGI能解决什么问题吧. 记得在上家公司的时候,经常参与上线.上线一般都是增加了一些功能或者修改了一些功能,然后将所有的代码重新部署.过程中要将之前的服 ...

  8. 运行容器的最佳实践 - 每天5分钟玩转 Docker 容器技术(24)

    按用途容器大致可分为两类:服务类容器和工具类的容器. 1. 服务类容器以 daemon 的形式运行,对外提供服务.比如 web server,数据库等.通过 -d 以后台方式启动这类容器是非常合适的. ...

  9. D. 实验室传染病

    D. 实验室传染病 题意 给出 n 个人的位置,以及每个人的传染范围,当一个人患病时,他的传染范围内(包括边界上)的人全部会被感染并继续向外传播. 求以每个人为传染源最多有多少人被感染. 分析 首先二 ...

  10. 快来领取一场专门讲解UTF-8与UTF-16编码算法的GitChat活动的免费名额

    微信扫一扫,可打开该GitChat活动页面 字符编码是计算机世界里最基础.最重要.最令人困惑的一个主题之一.不过,在计算机教材中却往往浮光掠影般地草草带过,甚至连一本专门进行深入介绍的专著都找不到(对 ...