我是 TideSDK 的新手,正在努力让本地数据库正常工作。
首先,这是正确的使用方法吗?我希望用户加载游戏,放入一些东西(本地数据库)而不发送到服务器,退出游戏。然后稍后再回来(即使在关闭他的电脑或清除他的互联网之后),加载游戏并且所有本地数据库的东西仍然存在,然后他可以将其发送到服务器。(我应该改用本地文件吗?)
我得到的错误是:
db.execute("INSERT INTO Games(id, player, timeText) VALUES(1, 1, 0)"); // Putting a zero time in
它说这是一个不正确的sql语句或数据库不存在。
理想情况下,我也想用准备好的语句来做 sqlite,但我想开始更简单。
这是 HelloWorld 示例的 mod:
https://github.com/TideSDK/TideSDK-HelloWorld
我修改后的代码:
应用程序.js
function DoSqlCall() {
var lastTime;
//Open the database first
var db = Ti.Database.openFile(Ti.Filesystem.getFile(
Ti.Filesystem.getApplicationDataDirectory(), 'customdatabase.db'));
//Create a table and insert values into it
db.execute("CREATE TABLE IF NOT EXISTS Games(id INTEGER, player INTEGER, timeText TEXT)");
alert("Hello 1");
var rows = db.execute("SELECT * FROM Games WHERE 'id' = 1 AND 'player' = 1");
if(rows.isValidRow()) {
lastTime = rows.fieldByName('timeText');
alert("lastTime: " + lastTime.toString());
//rows.next();
} else {
db.execute("INSERT INTO Games(id, player, timeText) VALUES(1, 1, 0)"); // Putting a zero time in
alert("Put in zero time");
lastTime = 0;
}
//Release memory once you are done with the resultset and the database
rows.close();
db.close();
};
// create and set menu
var menu = Ti.UI.createMenu(),
fileItem = Ti.UI.createMenuItem('File'),
exitItem = fileItem.addItem('Exit', function() {
if (confirm('Are you sure you want to quit?')) {
Ti.App.exit();
}
});
menu.appendItem(fileItem);
Ti.UI.setMenu(menu);
索引.html
<!DOCTYPE html>
<html>
<head>
<title>Hello World</title>
<style type="text/css">
body {background: #fff;}
</style>
</head>
<body>
<h1>Hello World</h1>
<button id="m_Send" type="button" onclick="DoSqlCall()">Send</button>
<script type="text/javascript" src="app.js"></script>
</body>
</html>