import win.ui;
/*DSG{{*/
mainForm = win.form(text="sqlite 入门";right=425;bottom=498)
mainForm.add(
button={cls="button";text="查询";left=297;top=7;right=396;bottom=42;z=2};
editResult={cls="edit";left=12;top=61;right=400;bottom=491;edge=1;multiline=1;z=3};
editUser={cls="edit";text="小王";left=14;top=11;right=282;bottom=40;edge=1;multiline=1;z=1}
)
/*}}*/
import sqlite;
var db = sqlite("/intro2.db");//打开数据库连接,参数指定硬盘文件路径
//创建数据表
if( not db.existsTable("工作日志表") /*是否已存在指定的表*/ ) {
db.exec( "CREATE TABLE [工作日志表]( 姓名,工作地点,时间);" );
}
//创建预处理命令,用 @ 字符作为 SQL 命名参数的前缀
var cmd = db.prepare("INSERT INTO [工作日志表] VALUES ( @姓名,@工作地点,@时间 );")
//执行命令语句,插入测试数据,并指定 SQL 命名参数
cmd.step(
姓名 = "小张";
工作地点 = "北京";
时间 = time.now();
);
//插入测试数据,函数唯一的表参数首尾的 { } 可以省略
cmd.step( {
姓名 = "小王";
工作地点 = "上海";
时间 = time.now();
} );
//响应按钮事件
mainForm.button.oncommand = function(id,event){
//查询一条数据,查询多条请改用 db.each() 或者 db.getTable() 函数
var result = db.stepQuery("SELECT * FROM [工作日志表] WHERE ??",{ {
姓名 = mainForm.editUser.text;
} } )
/*
SQL语句中 @ 字符开始的命名参数使用参数表的名值对元素格式化,
SQL语句中 ? 或 ?? 占位符使用参数表的数组元素格式化,
其中 ?? 格式化为标识符,其他占位符格式化为参数值。
??占位符用于格式化的参数如果是一个表,表中的键值对以 AND 为分隔符,并将数组值转换为IN语句。
*/
if(result){
mainForm.editResult.print( result.姓名 );
mainForm.editResult.print( result.工作地点 );
mainForm.editResult.print( result.时间 );
}
}
mainForm.show();
win.loopMessage();