Flex中的MySQL管理(3)_MySQL
我省略了与前例类似的部分代码,以缩短代码段长度。差别重点在于
该方法最有价值的部分如下:
myservice.lastResult..database.* 登录后复制 |
看看这个语句。如果之前不了解E4X的作用,我可以稍加解释。myservice.lastResult变量实际上是一个XML文档。‘..’句法等价于XPath ‘//’句法。它表示“将具有此名字的任何一个标签给我”,在本例中就是“将任何一个数据库标签给我”。星号表示数据库标签的任何子标签。由于数据库标签只有一个子标签,即数据库名称的文字部分,因此这段代码就表示“将XML文档中每个数据库的名称给我”。这个功能真的很好用!
正是由于ActionScript的这种E4X扩展,Flex才能够方便地与XML数据源进行通讯。据我所知,还没有其他语言能够如此方便地查询XML文档。因此利用强大的E4X,就可以在浏览器中运行该应用程序,并得到如图2所示的结果。
![]() |
图2:填充数据库名称的数据库组合框 |
单击该组合框时,将弹出下拉列表,并显示机器中的数据库列表。是的,其中有很多数据库。几乎每篇有关PHP、Flex、Rails或其他技术的文章都会用到数据库,所以我拥有大量的数据库。
创建表视图代码
创建示例Flex应用程序的最后一步就是添加表格的下拉菜单,并在数据网格中显示选中表格的数据。该例的完整代码如清单4所示。
清单4:flexmysql.mxml
<p><?xml version="1.0" encoding="utf-8"?><br><application xmlns:mx="<FONT color=#333333 size=3>http://www.adobe.com/2006/mxml</FONT>" layout="vertical">initialize="onInitialize()"><br><script><br>import mx.collections.ArrayCollection;<br>private static const SERVICE_BASE:String = "<font color="#333333" size="3">http://localhost/sql/req.php</font>";<br>private var loadingDatabases:Boolean = true;<br>private var loadingTables:Boolean = false;<br>public function onInitialize():void<br>{<br>loadingDatabases = true;<br>myservice.url = SERVICE_BASE;<br>myservice.send( null );<br>} public function onResult(event:Event):void<br>{<br>if ( loadingDatabases )<br>{<br>loadingDatabases = false;<br>selectedDatabase.dataProvider = myservice.lastResult..database.*;<br>onSelectDatabase();<br>}<br>else if ( loadingTables )<br>{<br>loadingTables = false;<br>var tables:Array = new Array();<br>for each ( var tablRecord:XML in myservice.lastResult..record )<br>{<br>for each( var tablCol:XML in tablRecord.* )<br>tables.push( tablCol..*.toString() );<br>}<br>selectedTable.dataProvider = tables;<br>onSelectTable();<br>} else<br>{<br>var records:Array = new Array();<br>for each ( var record:XML in myservice.lastResult..record )<br>{<br>var outRecord:Array = new Array();<br>for each( var column:XML in record.* )<br>outRecord[ column.name() ] = column..*.toString();<br>records.push( outRecord );<br>}<br>var data:ArrayCollection = new ArrayCollection( records );<br>dg1.dataProvider = data;<br>}<br>} public function onSelectDatabase():void<br>{<br>loadingDatabases = false;<br>loadingTables = true;<br>var <font color="#333333" size="3">url:String</font> = SERVICE_BASE;<br>url += "?mode=getTables&db="+selectedDatabase.selectedLabel;<br>myservice.url = url;<br>myservice.send(null);<br>} public function onSelectTable():void<br>{<br>var <font color="#333333" size="3">url:String</font> = SERVICE_BASE;<br>url += "?mode=getData&db="+selectedDatabase.selectedLabel;<br>url += "&table="+selectedTable.selectedLabel;<br>myservice.url = url;<br>myservice.send(null);<br>}<br>]]><br></script><br><httpservice id="myservice" result="onResult(event)" resultformat="e4x"><br></httpservice><br><vbox horizontalalign="left"><br><hbox><br><label text="Database:"></label><br><combobox id="selectedDatabase" width="381" height="21">change="onSelectDatabase()"><br></combobox><br></hbox><br><hbox><br><label text="Table:"></label><br><combobox id="selectedTable" width="381" height="21">change="onSelectTable()"><br></combobox><br></hbox><br><datagrid id="dg1" width="452"><br></datagrid><br></vbox><br></application></p> 登录后复制 |
其中有一处重要修改,即添加了onSelectDatabase()函数的代码,以获取表格列表,然后将其输入到onResult()函数中,还添加了onSelectTable()函数,该函数可检索表格中的数据,并在onResult()处理器中设置数据网格

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

本文探讨了Docker中的优化MySQL内存使用量。 它讨论了监视技术(Docker统计,性能架构,外部工具)和配置策略。 其中包括Docker内存限制,交换和cgroups

本文介绍了MySQL的“无法打开共享库”错误。 该问题源于MySQL无法找到必要的共享库(.SO/.DLL文件)。解决方案涉及通过系统软件包M验证库安装

本文讨论了使用MySQL的Alter Table语句修改表,包括添加/删除列,重命名表/列以及更改列数据类型。

本文比较使用/不使用PhpMyAdmin的Podman容器直接在Linux上安装MySQL。 它详细介绍了每种方法的安装步骤,强调了Podman在孤立,可移植性和可重复性方面的优势,还

本文提供了SQLite的全面概述,SQLite是一个独立的,无服务器的关系数据库。 它详细介绍了SQLite的优势(简单,可移植性,易用性)和缺点(并发限制,可伸缩性挑战)。 c

本指南展示了使用自制在MacOS上安装和管理多个MySQL版本。 它强调使用自制装置隔离安装,以防止冲突。 本文详细详细介绍了安装,起始/停止服务和最佳PRA

文章讨论了为MySQL配置SSL/TLS加密,包括证书生成和验证。主要问题是使用自签名证书的安全含义。[角色计数:159]

文章讨论了流行的MySQL GUI工具,例如MySQL Workbench和PhpMyAdmin,比较了它们对初学者和高级用户的功能和适合性。[159个字符]
