Creation/Dev/Gscript/Using SQLite: Difference between revisions
No edit summary |
No edit summary |
||
Line 41: | Line 41: | ||
temp.pls = req("SELECT * FROM players WHERE hours > 5"); | temp.pls = req("SELECT * FROM players WHERE hours > 5"); | ||
In essence, SQLite is a fast, easy, and organized way to store your data. | |||
== Getting Started == | |||
Getting started with SQLite is extremely easy, but for the purpose of this tutorial, I'm going to point you toward a tool that will help you greatly. Before that, though, you will need access to a server where you can learn. If you don't already have access to some server, you can sign up for the [[Worlds/Testbed Server|Testbed Server]] | |||
If you aren't using the Testbed Server, you will need to upload a tool to help with this tutorial | |||
* Go to [http://forums.graalonline.com/forums/showthread.php?t=134256319 this forum post] and download the text of the "SQL Explorer". | |||
* Create a new weapon, and name it "Tools/SQL Explorer" (or any other name). Paste the text of the SQL explorer in here. | |||
** Before you save the weapon, change line 29, to "false". This will be discussed later on. | |||
* Add yourself the weapon | |||
If you ''are'' using the Testbed Server, just add yourself the weapon "Tools/SQL Explorer". |
Revision as of 18:43, 5 December 2009
Preamble
Target Audience
This guide will not teach you how to script. It is directed toward already-competent scripters who wish to incorporate SQLite into their scripts.
Required Skills and Knowledge
- Basic understanding of GS2
- Basic understanding of storing data in traditional ways (flatfile)
- Basic understanding of the way tables work (for example, Microsoft Excel)
Introduction
What is SQLite?
SQLite is a software library that implements a self-contained, serverless, zero-configuration, transactional SQL database engine.
In English, it is a script that stores data into tables, the way any SQL language works (e.g. MySQL).
Why use SQLite?
There are advantages and disadvantages to using SQLite for storing data. Like any data storage method, there are times where it is practical to use it, and times when it isn't so practical.
The main advantage to using SQLite is that all of your data is stored in a central location. This allows you to compare the data quickly and easily, without a lot of extra code.
This isn't going to make a lot of sense until later, but let's pretend I have a table with two columns: "account" and "hours". If I wanted to figure out which players have more than 5 hours and less then 10, I can simply run a query like this:
SELECT * FROM players WHERE hours > 5
Using traditional storage methods, such as flatfile, the file might look something like this:
(npcserver)=6 Stefan=10 unixmad=3
In order to figure out which of these players has more than 5 hours, I would need to do something to this effect:
temp.file.loadVars("data/file.txt"); temp.pls = {}; for (temp.pl : file.getDynamicVarNames()) { if (file.(@ pl) > 5) { // has more than 5 hours pls.add({pl, file.(@ pl)}); } }
The equivalent code for a properly organized SQL table might be:
temp.pls = req("SELECT * FROM players WHERE hours > 5");
In essence, SQLite is a fast, easy, and organized way to store your data.
Getting Started
Getting started with SQLite is extremely easy, but for the purpose of this tutorial, I'm going to point you toward a tool that will help you greatly. Before that, though, you will need access to a server where you can learn. If you don't already have access to some server, you can sign up for the Testbed Server
If you aren't using the Testbed Server, you will need to upload a tool to help with this tutorial
- Go to this forum post and download the text of the "SQL Explorer".
- Create a new weapon, and name it "Tools/SQL Explorer" (or any other name). Paste the text of the SQL explorer in here.
- Before you save the weapon, change line 29, to "false". This will be discussed later on.
- Add yourself the weapon
If you are using the Testbed Server, just add yourself the weapon "Tools/SQL Explorer".