HK-2000数据采集仪数据库操作说明

  HK-2000数据采集仪数据库存储采集通道配置,站点信息配置,已经实时数据,报警数据等,下面将数据库中采集通道配置与站点信息配置表进行说明,因为用户会经常用到这2个表。
  tbChannel:采集通道配置表
  表结构说明如下:
        [ChannelID] int                    --采集通道值AD16+COMM6
        [Code] varchar(10) NOT NULL            --因子编码
        [Name] varchar(20) NOT NULL            --因子英文名称
        [CName] varchar(20) DEFAULT NULL        --因子中文名称
        [Unit] varchar(20) NOT NULL DEFAULT NULL    --因子单位
        [TField] varchar(20) NOT NULL            --因子采集存储的对应字段
        [CollectMode] varchar(20) NOT NULL        --因子采集方式:AD,RS232,RS485,RS422
        [CollectProtocol] varchar(20) NOT NULL        --因子采集协议:AD,Modbus
        [Coef] float(4,2) DEFAULT 1            --因子模拟采集转换系数 (A-B)*Coef=实际数字
        [B] float NOT NULL DEFAULT 0            --因子模拟采集偏差
        [NLength] int NOT NULL DEFAULT 4        --因子数据小数点前长度
        [NWidth] int NOT NULL DEFAULT 4        --因子数据小数点后宽度
        [CurDt] datetime                --因子实时数据采集的时间
        [CRtd] float                    --因子当前实时数据值
        [CMax] float                    --因子上限值
        [CMin] float                    --因子下限值
        [CAvg] float                    --因子平均值
        [CTime] varchar(50) DEFAULT '01:01'        --因子采集时间
        [Flag] varchar(5) NOT NULL DEFAULT N        --因子数据标记
        [IsUsed] bit DEFAULT 0                --是否启用该因子通道

  tbSitePar:站点信息配置表,在该表中我们存储了很多站点参数。
  表结构说明如下:
        [ParName] varchar(10) NOT NULL            --参数名称
        [ParValue] varchar(20) NOT NULL           --参数值  
     表中存储的参数(ParName)说明:
            MN:站点编号一般都有个默认值,用户在实际使用时根据当地环保局要求进行分配
            DataSaveIntvl:数据存储时间间隔,默认300秒
            PW:国标协议密码,默认123456
            ST:站点类别,32表示污水,31表示烟气
            RtdInterval:实时上报数据间隔,默认5分钟
            ReportTime|0101
            ReCount|5|
            OverTime|30
            WarnTime|30
            Note|NULL
            CTime|0101
            ServerIP:监控中心通讯IP地址,默认为192.168.0.6
            ServerPort:中心通讯IP对应的端口号,默认为5002

           
   对于HK2000数据采集仪上部署的通用的程序,因为参数等为常用的,可以使用H2000Config配置程序或使用H2000LCDKey程序进行配置,但对于各个根据当地需要而修改的程序,H2000Config没有相关参数的配置功能,需要用户使用sqlite3工具进行配置。如果需要操作的当前数据库中没有您需要配置的参数,需要您先往数据库中相应的表插书参数数据。
例如需要往amsdata.db数据库中tbsitepar表中添加K值数据,默认值为1,注意只能执行一次添加数据命令。如果数据库中已经添加了K值的记录,请不要使用Insert命令进行添加了,需要使用Update命令进行更改K值的操作,不许保证K值记录为一条。
进入bject目录下,查看是否有dbmng或sqlite3程序。
如果有dbmng程序,则通过命令
./dbmng amsdata.db "insert into tbsitepar(parname,parvalue) values('ParmK','1')"
如果有sqlite3程序,则通过命令
./sqlite3 amsdata.db "insert into tbsitepar(parname,parvalue) values('ParmK','1')"

当需要修改时使用SQL中的Update语句,假设将K值修改成5,
如果有dbmng程序,则通过命令
./dbmng amsdata.db "Update tbsitepar set parvalue='5' where parname='ParmK'"
如果有sqlite3程序,则通过命令
./sqlite3 amsdata.db "Update tbsitepar set parvalue='5' where parname='ParmK'"

对于其他参数的添加与配置修改可以仿照上面的命令格式。

注意:为了防止输入命令错误,可以使用右键中的拷贝,黏贴命令到telnet工具中的命令行执行,建议使用SecureCRT工具进行telnet登陆配置程序。
 

关于Sqlite3工具的详细说明与使用方法:
          
  打开amsdata.db数据库,仅仅需要敲入带有SQLite数据库名字的"sqlite3"命令即可。如果文件不存在,则创建一个新的(数据库)文件。然后sqlite3程序将提示你输入SQL。敲入SQL语句(以分号“;”结束),敲回车键之后,SQL语句就会执行。
./sqlite3 amsdata.db
SQLite version 3.3.8
Enter ".help" for instructions
sqlite>

   在此说明一下,用户当输入错误时,想用退格或删除键去删除错误的信息时,在命令环境不但没有删除,却多出来^H,这是因为在Linux环境下多使用强行退格命令Ctrl+BackSpace进行的。
#执行SQL命令,命令以;结束,按回车后执行.
sqlite> select * from tbrtd;
2007-11-23 17:02:36|16.545|21.261|0.031|0|0|0.005|0.005|0|0.005|0|0.005|0|0|0.005|0|0
2007-11-23 17:18:45|16.331|21.291|0|0.005|0.005|0|0|0|0.005|0|0|0|0.005|0|0|0
2007-11-23 17:35:03|16.026|21.306|0|0|0|0|0|0|0|0.005|0|0|0|0|0|0
2007-11-23 17:50:22|15.415|21.215|0.031|0|0|0|0|0|0|0|0.005|0|0.005|0|0|0
2007-11-23 18:06:47|15.354|21.2|0|0|0|0|0|0|0.005|0|0|0.005|0|0|0|0
2007-11-23 18:23:07|14.683|21.032|0|0|0|0|0|0|0|0|0.005|0|0|0.005|0|0
2007-11-23 18:40:07|14.988|21.047|0|0|0|0.005|0|0|0|0|0|0.005|0|0|0|0
2007-11-23 18:57:05|15.537|21.047|0.031|0|0|0.005|0|0|0|0|0|0.005|0|0.005|0|0
2007-11-23 19:13:59|15.598|20.925|0|0|0|0.005|0.005|0.005|0|0|0|0|0.005|0|0|0.005
2007-11-23 19:29:58|15.049|20.772|0|0|0|0.005|0|0|0|0|0.005|0.005|0|0|0|0
2007-11-23 19:45:54|14.713|20.604|0|0|0.005|0.005|0.005|0|0|0.005|0|0.005|0.005|0.005|0|0
sqlite>

#也可以使用./sqlite3 [OPTIONS] FILENAME [SQL] 执行SQL语法.
$./sqlite3 amsdata.db "select * from tbrtd"
2007-11-23 17:02:36|16.545|21.261|0.031|0|0|0.005|0.005|0|0.005|0|0.005|0|0|0.005|0|0
2007-11-23 17:18:45|16.331|21.291|0|0.005|0.005|0|0|0|0.005|0|0|0|0.005|0|0|0
2007-11-23 17:35:03|16.026|21.306|0|0|0|0|0|0|0|0.005|0|0|0|0|0|0
2007-11-23 17:50:22|15.415|21.215|0.031|0|0|0|0|0|0|0|0.005|0|0.005|0|0|0
2007-11-23 18:06:47|15.354|21.2|0|0|0|0|0|0|0.005|0|0|0.005|0|0|0|0
2007-11-23 18:23:07|14.683|21.032|0|0|0|0|0|0|0|0|0.005|0|0|0.005|0|0
2007-11-23 18:40:07|14.988|21.047|0|0|0|0.005|0|0|0|0|0|0.005|0|0|0|0
2007-11-23 18:57:05|15.537|21.047|0.031|0|0|0.005|0|0|0|0|0|0.005|0|0.005|0|0
2007-11-23 19:13:59|15.598|20.925|0|0|0|0.005|0.005|0.005|0|0|0|0|0.005|0|0|0.005
2007-11-23 19:29:58|15.049|20.772|0|0|0|0.005|0|0|0|0|0.005|0.005|0|0|0|0
2007-11-23 19:45:54|14.713|20.604|0|0|0.005|0.005|0.005|0|0|0.005|0|0.005|0.005|0.005|0|0
2007-11-23 20:01:47|14.255|20.421|0|0|0.005|0|0|0|0|0|0|0|0|0|0|0

#退出sqlite操作环境,输入.quit 或用Ctrl+Z.
    对于数据库的其他操作举例如下:但希望用户不用在系统数据库amsdata.db下使用调试这些命令,防止将数据库信息进行修改,实数据采集仪不能正常工作。你可以新建个测试的数据库文件用来学习。
例如,创建一个包含一个表"tb11"名字为"ex1"的SQLite数据库,你可以这样做:

$sqlite3 ex1
SQLite version 3.3.17
Enter ".help" for instructions
sqlite> create table tbl1(one varchar(10), two smallint);
sqlite> insert into tbl1 values('hello!', 10);
sqlite> insert into tbl1 values('goodbye', 20);
sqlite> select * from tbl1;
hello!|10
goodbye|20
sqlite>

   你可以通过敲你所用系统的文件结束符(通常是Ctrl + D)或者中断字符(通常是Ctrl + C)。来终止sqlite3程序。确定你在每个SQL语句结束敲入分号!sqlite3程序通过查找分号来决定一个SQL语句的结束。如果你省略分号,sqlite3将给你一个连续的命令提示符并等你给当前的SQL命令添加更多的文字。这个特点让你输入多行的多个SQL语句,例如:

sqlite> create table tbl2(
   ...> f1 varchar(30) primary key,
   ...> f2 text,
   ...> f3 real
   ...> );
sqlite>

题外话:查询SQLITE_MASTER表

    SQLite数据库的框架被保存在一个名叫"sqlite_master"的特殊的表中。你可以像查询其它表一样通过执行“SELECT”查询这个特殊的表。例如:


$ sqlite3 ex1
SQlite vresion 3.3.10
Enter ".help" for instructions
sqlite> select * from sqlite_master;
    type = table
    name = tbl1
tbl_name = tbl1
rootpage = 3
     sql = create table tbl1(one varchar(10), two smallint)
sqlite>

    但你不能在sqlite_master表中执行诸如DROP TABLE, UPDATE, INSERT 或者DELETE命令。sqlite_master表在你创建、删除和索引数据库时自动更新这个表。你不能手工更改sqlite_master表。
    TEMPORARY表的结构没有存储在"sqlite_master"表中,由于TEMPORARY表对应用是不可见的,而不是应用程序创建这个表。 TEMPORARY表结构被存储在另外一个名叫"sqlite_temp_master"的特定的表中。"sqlite_temp_master"表是临时表自身。

sqlite3的特殊命令
   大多数候,sqlite3读入输入行,并把它们传递到SQLite库中去运行。但是如果输入行以一个点(“.”)开始,那么这行将被sqlite3程序自己截取并解释。这些“点命令”通常被用来改变查询输出的格式,或者执行鞭个预封包(预定义prepackaged)的查询语句。

你可以在任何时候输入“.help”,列出可用的点命令。例如

sqlite> .help
.bail ON|OFF           Stop after hitting an error.  Default OFF
.databases             List names and files of attached databases
.dump ?TABLE? ...      Dump the database in an SQL text format
.echo ON|OFF           Turn command echo on or off
.exit                  Exit this program
.explain ON|OFF        Turn output mode suitable for EXPLAIN on or off.
.header(s) ON|OFF      Turn display of headers on or off
.help                  Show this message
.import FILE TABLE     Import data from FILE into TABLE
.indices TABLE         Show names of all indices on TABLE
.load FILE ?ENTRY?     Load an extension library
.mode MODE ?TABLE?     Set output mode where MODE is one of:
                         csv      Comma-separated values
                         column   Left-aligned columns.  (See .width)
                         html     HTML <table> code
                         insert   SQL insert statements for TABLE
                         line     One value per line
                         list     Values delimited by .separator string
                         tabs     Tab-separated values
                         tcl      TCL list elements
.nullvalue STRING      Print STRING in place of NULL values
.output FILENAME       Send output to FILENAME
.output stdout         Send output to the screen
.prompt MAIN CONTINUE  Replace the standard prompts
.quit                  Exit this program
.read FILENAME         Execute SQL in FILENAME
.schema ?TABLE?        Show the CREATE statements
.separator STRING      Change separator used by output mode and .import
.show                  Show the current values for various settings
.tables ?PATTERN?      List names of tables matching a LIKE pattern
.timeout MS            Try opening locked tables for MS milliseconds
.width NUM NUM ...     Set column widths for "column" mode
sqlite>

改变输出格式

    sqlite3程序可以以八种不同的格式显示一个查询的结果:"csv", "列", "html", "插入", "行", "制表"和"tcl"。你可以用".mode"点命令在这些输出格式之间切换。
    默认的输出格式是“列表”。在列表模式下,每条查询结果记录被写在一行中并且每列之间以一个字符串分割符隔开。默认的分隔符是一个管道符号(“|”)。列表符号在当你输出查询结果到另外一个符加处理的程序(如AWK)中去是尤为有用。

sqlite> .mode list
sqlite> select * from tbl1;
hello|10
goodbye|20
sqlite>

    你可以用“.separator”点命令来改变分界符。例如,为了把分割符改为一个逗号和一个空格,你可以这样做:

sqlite> .separator ", "
sqlite> select * from tbl1;
hello, 10
goodbye, 20
sqlite>

    在“line"模式下,每一个位于条记录中的列在它自己那行显示。每行由列名、一个等号和列数据组成。下一条记录以一个空行隔开。这是一个行模式输出的例子:

sqlite> .mode line
sqlite> select * from tbl1;
one = hello
two = 10

one = goodbye
two = 20
sqlite>

    在列模式下,每条记录在一个单独的行中以数据列对齐的方式显示。列如:

sqlite> .mode column
sqlite> select * from tbl1;
one         two      
----------  ----------
hello       10       
goodbye     20       
sqlite>

    在默认的情况下,每列至少10个字符宽。太宽的数据将被截取。你可以用“.width”命令来调整列宽。如下所示:

    sqlite> .width 12 6
    sqlite> select * from tbl1;
    one           two  
    ------------  ------
    hello         10   
    goodbye       20   
    sqlite>

    上面例子中".width"命令设置第一列宽为12第二列宽为6。其它的列宽不变。你可以指定与你查询结果需要的列数一样多的“.width”参数。
    如果你指定一列宽为0,那么这个列宽将自动以下面三个数字中的最大值做为列宽:10、表头宽度和最宽的数据列的宽度。这可以让列自动调整宽度。每列的默认设置为自动调整的0值。
    出现在输出开头两行的列标示可以用".header"点命令关闭。在上面的例子中,列标示是打开的。可以用下面的方法关闭列标示:

    sqlite> .header off
    sqlite> select * from tbl1;
    hello         10   
    goodbye       20   
    sqlite>

    另外一个有用的输出模式是"insert"。在插入模式下,被子格式化为看起来像SQL INSERT语句的样式。你可以用插入模式来产生文件(便于)以后用于不同数据库的输入。
    当指定插入模式时,你必须给定一个特定参数就是要插入的表名。例如:

    sqlite> .mode insert new_table
    sqlite> select * from tbl1;
    INSERT INTO 'new_table' VALUES('hello',10);
    INSERT INTO 'new_table' VALUES('goodbye',20);
    sqlite>

    最新的输出格式是“html”。在这种模式下,sqlite3把查询的结果写做XHTML表。开始的<TABLE>和结束的</TABLE>(标记)没有写出,但有<TR>、<TH>和<TD>等分界符。html输出对 CGI来说是相当有用地。
把结果写到文件中
    默认情况下,sqlte3把结送到标准输出。你可以用“.output”命令改变它。只须把输出文件名做为.output命令的输出参数然后所有后续查询结果将被写到那个文件中。用“.output stdout”再一次改为标准输出。例如:

    sqlite> .mode list
    sqlite> .separator |
    sqlite> .output test_file_1.txt
    sqlite> select * from tbl1;
    sqlite> .exit
    $ cat test_file_1.txt
    hello|10
    goodbye|20
    $

查询数据库结构
    sqlite3程序提供几个有用的用于查询数据库结构的快捷命令。这些不是不可以用别的方式来实现。这些命令仅仅是一个快捷方式而已。
    例如,为了查看数据库的表列表,你可以敲入“.tables”。

    sqlite> .tables
    tbl1
    tbl2
    sqlite>

    “.tables”命令相似于设置列表模式然后执行接下来的查询:

    SELECT name FROM sqlite_master
    WHERE type IN ('table','view') AND name NOT LIKE 'sqlite_%'
    UNION ALL
    SELECT name FROM sqlite_temp_master
    WHERE type IN ('table','view')
    ORDER BY 1

    事实上,你可以查看sqlite3的源代码(可以在源文件树的src/shell.c中),你可找到上面的具体的查询。
    “.indices”命令作用类似的方式是列出特定表的所有的索引。“.indics”命令须一个参数即所要索引表的表名。最后,但不是至少,是“.schema”命令。不带任何参数,“.schema”命令显示原始的用于创建当前数据库的CREATE TABLE和CREATE INDEX语句。如果你给".schema"命令一个表名,它显示原始的创建该表和它所有索引的CREATE语句。我们可以:

    sqlite> .schema
    create table tbl1(one varchar(10), two smallint)
    CREATE TABLE tbl2 (
      f1 varchar(30) primary key,
      f2 text,
      f3 real
    )
    sqlite> .schema tbl2
    CREATE TABLE tbl2 (
      f1 varchar(30) primary key,
      f2 text,
      f3 real
    )
    sqlite>

    ".schema"命令可以用设置列表然后执行以下查询来实现:

    SELECT sql FROM
       (SELECT * FROM sqlite_master UNION ALL
        SELECT * FROM sqlite_temp_master)
    WHERE type!='meta'
    ORDER BY tbl_name, type DESC, name

    或者,如果你给".schema"命令一个参数,由于你只想得到一个表的结构,查询可以是这样:

    SELECT sql FROM
       (SELECT * FROM sqlite_master UNION ALL
        SELECT * FROM sqlite_temp_master)
    WHERE type!='meta' AND sql NOT NULL AND name NOT LIKE 'sqlite_%'
    ORDER BY substr(type,2,1), name

    你可以担供一个参数给.schema命令。如果这橛,查询可以是这样的:

    SELECT sql FROM
       (SELECT * FROM sqlite_master UNION ALL
        SELECT * FROM sqlite_temp_master)
    WHERE tbl_name LIKE '%s'
      AND type!='meta' AND sql NOT NULL AND name NOT LIKE 'sqlite_%'
    ORDER BY substr(type,2,1), name

    在查询中“%S“为你的参数所取代。这使你可以询数据库结构的某个子集。

    sqlite> .schema %abc%

    与这些一起,“.table”命令也接受一个模式作为他的参数。如果你给“.table”一个参数,“%”将被前后扩展并且一个LIKE子句被附加到查询上。这让你可以列出只与特定模式相匹配的的表。

    “.datebasae”命令显示所有当前连接打开的数据库的一个列表。将允许一次到少两个。第一个是“main”,最初打开的那个数据库。第二个是"temp",用于临时表的数据库。对于用ATTACH语句附加的数据也许有附加数据库列表。输出的第一列与之相联的数据库名,第二列是外部文件名。

    sqlite> .databases

    将整个数据库转换为ASCII文本文件

    ".dump"命令成一个单一的ASCII文本文件。这个文件可以被用作管道传递给sqlite3命令来转换回数据库。

    一个最好的制作一个数据库档案拷贝的命令是:

    $ echo '.dump' | sqlite3 ex1 | gzip -c >ex1.dump.gz

    它产生一个一个名为ex1.dump.gz的文件,它包含了你以后或在其它机器上重构数据库的所有的信息。要重构数据库,只须敲入:

    $ zcat ex1.dump.gz | sqlite3 ex2

    这个文本格式是纯粹的SQL语句所以你可以用.dump命令来导出一个SQLite数据库到另一个常用的SQL数据库引擎。比如:

    $ createdb ex2
    $ sqlite3 ex1 .dump | psql ex2

其它的点命令

".explain"命令可以被用来设置输出格式为“column” 并设置列宽为EXPLAIN命令看起来比较合理的宽度。EXPLAIN命令是SQLite特有的SQL扩展,它是对调试有用。如果任何常规的SQL被EXPLAIN执行,那么SQL命令被分解并分析但并不执行。取而代之的是,虚拟机指令序列将被用于执行SQL命令并返回一个类似的查询结果。如:

    sqlite> .explain
    sqlite> explain delete from tbl1 where two<20;
    addr  opcode        p1     p2     p3         
    ----  ------------  -----  -----  -------------------------------------  
    0     ListOpen      0      0                 
    1     Open          0      1      tbl1       
    2     Next          0      9                 
    3     Field         0      1                 
    4     Integer       20     0                 
    5     Ge            0      2                 
    6     Key           0      0                 
    7     ListWrite     0      0                 
    8     Goto          0      2                 
    9     Noop          0      0                 
    10    ListRewind    0      0                 
    11    ListRead      0      14                
    12    Delete        0      0                 
    13    Goto          0      11                
    14    ListClose     0      0

    “.timeout”命令设置sqlite3等待一个试图存储文件锁定请除直到错误返回的总时间。默认的超时值是0因此如果任何需要的数据库表或序列列被锁定时它将立即返回一个错误。

    最后,我们提到“.exit”命令它交导致sqlite3退出。

在命令和脚本中使用sqlite3

    一个在脚本命令中使用sqlite3的方式是用“echo”或“cat”来产生一个命令序列在一个文件中,然后当从一个产生的命令行中重定向输入时调用sqlite3。它有用并且适应许多环境。但作为一附加的便利是,sqlite3允许一个单一的SQL语句在命令行中作为数据库名后的第二个参数输入。当sqlite3程序带着两个参数启动时,第二个参数被传递给SQLite库处理,查询以列表模式打印到标准输出,然后程序退出。这个机制被设计用于让sqlite3容易于用于连接诸如"AWK"的程序。例如:

    $ sqlite3 ex1 'select * from tbl1' |
    >  awk '{printf "<tr><td>%s<td>%s\n",$1,$2 }'
    <tr><td>hello<td>10
    <tr><td>goodbye<td>20
    $

结束命令行命令

    SQLite命令通常以一个分号结束。在一个命令行中你也可以用“GO”单词(大小写敏感)或者一个“/”斜线在它所在好行结束一个命令。这常被SQL Server和Oracle使用。这些将不在sqlite3_exec()中有用,因为命令行在传递它们到函数之前把这些翻译为分号。

从源文件中编译sqlite3

    sqlite3程序当你编译SQLite库时自动被建立。只须取得一个源文件树的拷贝,运行“configure"然后"make"即可。

本页最后一次候改2007/01/08 14:31:36



sqlite的语法现象和SQL92是比较相象的,或者说sqlite3兼容大部份SQL92的语法现象。
下面我们看看怎么用这些语法现象来创建数据库以及对数据库的各种操作。

2.1 新建一个数据库
例如我们想新建一个数据库命名为zieckey.db ,可以直接在shell下输入 sqlite3 zieckey.db ,

# sqlite3 zieckey.db
SQLite version 3.0.8
Enter ".help" for instructions
sqlite>

这里 SQLite version 3.0.8 是SQLite的版本信息。也就是说本文使用的sqlite版本为 version 3.0.8 .
这样就创建了一个新的数据库文件,命名为 zieckey.db

2.2 创建表和插入值
刚刚我们创建了一个新的数据库zieckey.db,加入我们想在其中新建一个名为 SensorData 的表,其包含五个列元素。
可以用CREATE TABLE语法命令。
CREATE TABLE语句基本上就是"CREATE TABLE"关键字后跟一个新的表名以及括号内的一堆定义和约束。表名可以是字符串或者标识符。以"sqlite_"开头的表名是留给sqlite数据库引擎使用的。每个字段的定义是字段名后跟字段的数据类型,接着是一个或多个的字段约束。字段的 数据类型并不限制字段中可以存放的数据。更多信息,参见sqlite的CREATE TABLE语法。

这里具体作法如下:

# sqlite3 zieckey.db
SQLite version 3.0.8
Enter ".help" for instructions
sqlite> CREATE TABLE SensorData(
...> ID INTEGER PRIMARY KEY,
...> SensorID INTEGER,
...> SiteNum INTEGER,
...> Time VARCHAR(12),
...> SensorParameter REAL
...> );

注意sqlite下除了特殊命令都要以分号 “;” 结尾,否则它将一直等待第一个分号的出现才判断这条命令结束。

现在我们可以用 schema 命令看看我们刚刚创建的表。具体作法如下:

sqlite> .schema
CREATE TABLE SensorData(
ID INTEGER PRIMARY KEY,
SensorID INTEGER,
SiteNum INTEGER,
Time VARCHAR(12),
SensorParameter REAL
);
sqlite>

.schema 是用来查看数据库中所有的表的定义内容。如果后面跟了具体的表名称,则显示该表的内容。

假如我们想想SensorData表中插入具体列元素值,该怎么办呢?这里可以用INSERT语句。
INSERT语句有两种基本形式。一种带有"VALUES"关键字,在已有表中插入一个新的行。若不定义字段列表,那么值的数目将与表中的字段数目相同。否则值的数目须与字段列表中的字段数目相同。不在字段列表中的字段被赋予缺省值或NULL(当未定义缺省值)。
INSERT的第二种形式从SELECT语句中获取数据。若未定义字段列表,则从SELECT得到的字段的数目必须与表中的字段数目相同,否则应与定义的字段列表中的字段数目相同。SELECT的每一行结果在表中插入一个新的条目。SELECT可以是简单的或者复合的。如果SELECT语句带有 ORDER BY子句,ORDER BY会被忽略。
这里我们可以这样做:

sqlite> INSERT INTO "SensorData" VALUES(NULL, 1, 0, '200605011206', 18.9);
sqlite> INSERT INTO "SensorData" VALUES(2, 1, 0, '200605011306', 16.4);
sqlite> INSERT INTO "SensorData" VALUES(3, 1, 0, '200605011406', 15.3);
sqlite> INSERT INTO "SensorData" VALUES(4, 1, 0, '200605011506', 15.5);
sqlite>


2.3 在线帮助

前面两节,我们已经知道了sqlite语法最基本的用法。下面可以看看如何获得联机帮助。
很简单,输入 .help 就行了。注意要help前加上“.”,这与上面说的以分号结尾有点不同,因为help命令被视为特殊命令。

sqlite> .help
.databases List names and files of attached databases
.dump ?TABLE? ... Dump the database in an SQL text format
.echo ON|OFF Turn command echo on or off
.exit Exit this program
.explain ON|OFF Turn output mode suitable for EXPLAIN on or off.
.header(s) ON|OFF Turn display of headers on or off
.help Show this message
.import FILE TABLE Import data from FILE into TABLE
.indices TABLE Show names of all indices on TABLE
.mode MODE ?TABLE? Set output mode where MODE is on of:
csv Comma-separated values
column Left-aligned columns. (See .width)
html HTML <table> code
insert SQL insert statements for TABLE
line One value per line
list Values delimited by .separator string
tabs Tab-separated values
tcl TCL list elements
.nullvalue STRING Print STRING in place of NULL values
.output FILENAME Send output to FILENAME
.output stdout Send output to the screen
.prompt MAIN CONTINUE Replace the standard prompts
.quit Exit this program
.read FILENAME Execute SQL in FILENAME
.schema ?TABLE? Show the CREATE statements
.separator STRING Change separator used by output mode and .import
.show Show the current values for various settings
.tables ?PATTERN? List names of tables matching a LIKE pattern
.timeout MS Try opening locked tables for MS milliseconds
.width NUM NUM ... Set column widths for "column" mode
sqlite>

这里看到的命令都带有“.”开头,或者说sqlite下,只有这些命令是需要带“.”的。我们会经常用到的命令有:

.output FILENAME
.output stdout
.quit
.read FILENAME
.schema ?TABLE?
.dump ?TABLE? ...
.echo ON|OFF
.exit
在下面会涉及到这些具体内容的。我们慢慢来。

2.4 退出sqlite3
对于初学者,也许不知道怎么安全退出,不过如果是从头看到此处的读者也许已经知道了,
因为刚才 .help 命令已经告诉我们答案了。安全退出有两个命令:.exit 和 .quit
好了,我们已经新建一个名为zieckey.db的数据库,并在其中新建一个名为 SensorData 的表.
现在我们想退出,那么可以用到刚刚提到的 .exit 和 .quit 命令。
例如我们可以这样退出:
sqlite> .exit
这里需要说明一下,如果不是用 .exit 和 .quit 这两个命令退出,我们对数据库的修改有可能丢失。

2.5 查看当前数据库下的所有表
当数据库越来越大时,我们也许并不太记得数据库中有多少个表了,这时就需要查看当前数据库下的有些什么表。
我们可以用 .tables 命令 。

sqlite> .tables
SensorData
sqlite>
posted @ 2007-12-11 10:37  曹立松  阅读(1062)  评论(0编辑  收藏  举报