当前位置:文档之家› SQLite Expert Personal使用教程

SQLite Expert Personal使用教程

SQLite Expert Personal使用教程
SQLite Expert Personal使用教程

SQLite 圖形化操作軟體 – SQLite Expert Personal
小蛙今天要介紹一套圖形化的 SQLite 管理軟體,目前像 Android, iOS … 等手持式裝置內 部都支援使用 SQLite, 不外乎是因為它方便、 小、 速度快, SQLite 不像一般 MySQL、 Oracle、 MSSQL 這麼複雜,我們可以把 SQLite 想像成一個檔案(實際上存好之後也只有一個檔案), 但這一個檔案又比 Microsoft Access 有更大的便利性(可以在很多平台使用,不會只鎖定微 軟平台),想更了解 SQLite 可以參考 SQLite 官方說明書、或者是 WIKI-SQLite。SQLite Expert Personal 是小蛙今天要介紹的軟體,它不只可以瀏覽 SQLite 內儲存的資料,同時 也可以進行新增、修改、刪除…等操作,就像官網首頁寫的「SQLite Expert: A powerful administration tool for your SQLite databases」。
注意:這篇文章主要是以圖形化工具操作 SQLite,並不會讓你學到 SQLite 指令操作。 先到官網下載 SQLite Expert Personal 免費版, 上面的是專業版,只能試用 30 天,那小 蛙只是需要一些資料庫基本操作,選擇下面的 License 是 Freeware 的個人免費版。下載完 之後安裝,預設一直下一步直到安裝完成。

安裝完成後執行 SQLite Expert Personal,在桌面可以看到圖示,如果沒有的話到開始所有 程式(程式集)裡面去找「SQLite Expert」,點兩下執行。
啟動之後我們必須先建立一個新的資料庫, 點選左上角紅色框框新增資料庫, 並且輸入相關 設定。

新增完資料庫後,畫面左邊可以看到小蛙剛剛新增的資料庫「postman」,在資料庫上點選 滑鼠右鍵,選擇「New Table」來新增需要的表單。
先輸入「Table name」,這邊小蛙輸入「post_code」,並且在下面「Fields」的部份新增 需要的資料表欄位。這邊要注意的是如果要使用「自動遞增 auto_increment」功能的話,

必須要把該欄位的「Type」設定成「INTEGER」。新增完成後點選下方的「Apply」。

畫面的左邊可以看到新增完成的 Table, 右邊則是一些相關的操作畫面, 像是 「Database」 、 「SQL」、「Data」、「Design」、「DDL」。

「SQL」頁面可以讓我們測試所寫的 SQL 正不正確。
「Data」可以瀏覽目前資料表裡面包含的資料,並且新增、修改、刪除這些資料。小蛙試 了一下才知道要怎麼新增,點選「+」符號後會出現如下圖多一列都是的資料,在該

列上點兩下就可以進入編輯畫面(別點選有 Filter 的那列)。

「Design」就是剛剛我們新增資料表及欄位的地方,可以提供修改、刪除欄位,也包括了 Index, FK, Constraints, Triggers 等等的建立。

「DDL」則是可以看到這個資料表建立的語法。
設定完所有欄位後就可以開始新增資料了,新增資料以及設定 Index, 自動遞增…等,小蛙 將在下一篇文章中說明。下圖是剛剛我們建立的 sqlite,別看這小小的檔案,SQLite 可是麻 雀雖小,五臟俱全呢!
小蛙在上一篇文章中介紹 SQLite Expert Personal 簡單的使用方式,這篇文章小蛙要說明 怎麼設定每一筆資料都有一個可以自動新增的 id,相當於 Oracle 的 SEQUENCE,MySQL 的 AUTO_INCREMENT,設定及運作方式跟 MySQL 的差不多,只是小蛙一開始要設定的 時候還是小卡了一下。
這裡小蛙用實際的例子來說明, 原本在設計這個資料表的時候, 目的是在儲存台灣的郵遞區 號,ex.台北市,大安區,Da’an Dist.,,這個資料表裡面小蛙也設定了 id 屬性,目的是讓比 鄉鎮區以下的例如:村、里…等,可以用 id 來辨別是在哪個鄉鎮區。小蛙在設計到一半的 時候,發現 SQLite Expert Personal 裡面預覽資料的時候有個欄位叫做 RecNo,小蛙以為 這套 GUI 會產生自動遞增的欄位方便使用者操作, 但當小蛙透過程式存取 SQLite 的時候卻 又得不到 RecNo 這個欄位的值才恍然大悟,原來這套軟體產生的 RecNo 只是方便使用者

在 GUI 操作的時候辨識資料筆數。下圖是小蛙被騙的 RecNo。
在已經建立好資料,卻又要新增 not null 的 auto_increment 欄位的方法也不難,只是做個 小動作騙騙這套管理工具。在 Design 下的 Fields 頁面中選擇下方的 Add,將要新增的 id 欄位補上,注意 Type 一定要用 INTEGER。

如果上一步直接把 Not null 打勾的話一定會出現這個錯誤,因為已經把資料建好,而新增欄 位如果是 Not null,就違反了規則(新增出來的欄位裡面沒有值,當然就違反了)。
只要把 Not null 的勾勾先取消,點選 OK 後,繼續切換到 Indexes 頁面,點選下方 Add 後, 在要自動遞增的欄位上點兩下(會跑到右邊), 之後會發現上方有三個勾, 視需求勾選(Primary: PK,主要可以識別的的 Key,Unique: 唯一值,不可以重複,Autoincrement: 每一筆紀錄

都會自動增加 1)。確定後,點選下方的 Apply 就不會在出現上面的錯誤囉!
最後因為我們新增了 Autoincrement 這個屬性, 因此原本新增的 id 欄位就不再是 null, 接著 再回到 Fields 編輯剛剛的 id 欄位,把 id 欄位的 Not null 勾選就完成囉! 最後可以把經常查詢或是需要查詢的欄位建立 Index,如此一來可以加快我們搜尋資料的速 度。以下這段內容節錄自 SQL 語法教學。該網站舉了一個翻書的例子,如果我們在書裡有 索引(可以看成是目錄), 就可以很快的找到我們要查找的資料; 倘若有一本書沒有任何目錄, 那麼就必須逐字去尋找。 索引 (Index) 可以幫助我們從表格中快速地找到需要的資料。 … 從資料庫表格中尋找資料也是同樣的原理。 如果一個表格沒有索引的話, 資料庫系統就需要 將整個表格的資料讀出 (這個過程叫做’table scan’)。若有適當的索引存在,資料庫系統就 可以先由這個索引去找出需要的資料是在表格的什麼地方, 然後直接去那些地方抓資料。 這 樣子速度就快多了。

Android学习笔记---SQLite介绍,以及使用Sqlite,进行数据库的创建,完成数据添删改查的理解

Android学习笔记---SQLite介绍,以及使用Sqlite,进行数据库的创建,完成数据添删改查的理解 17_创建数据库与完成数据添删改查--------------------------------------1.SQLite介绍:最大特点是,无数据类型; 除了可以使用文件或SharedPreferences存储数据,还可以选择使用SQLite数据库存储数据。在Android平台上,集成了一个嵌入式关系型数据库—SQLite,SQLite3支持 NULL、INTEGER n n 、REAL(浮点数字)、TEXT(字符串文本)和BLOB(二进制对象)数据类型,虽然它支持的类型 n n 只有五种,但实际上sqlite3也接受varchar(n)、char(n)、decimal(p,s) 等数据类型,只不 n n 过在运算或保存时会转成对应的五种数据类型。 SQLite最大的特点是你可以把各种类型的数n n 据保存到任何字段中,而不用关心字段声明的数据类型是什么。例如:可以在Integer类型的 n n 字段中存放字符串,或者在布尔型字段中存放浮点数,或者在字符型字段中存放日期型值。n n n 但有一种情况例外:定义为INTEGER PRIMARY KEY的字段只能存储64位整数, 当向这种字段 n n 保存除整数以外的数据时,将会产生错误。 另外, SQLite 在解析CREATE TABLE 语句时, n n 会忽略 CREATE TABLE 语句中跟在字段名后面的数据类型信息,如下面语句会忽略 name字段 n n 的类型信息: CREATE TABLE person (personid integer primary key autoincrement, name varchar n n (20)) SQLite可以解析大部分标准SQL语句,如:查询语句:select * from 表名 where 条件子句 group by 分组字句 having ... order byn n n 排序子句如:select * from person n n n n select * from person order by id desc n n n n select name from person group by name having count(*)>1 ---------------------------------------------------------------------------2.a.分页SQL与mysql类似,下面SQL语句获取5条记录,跳过前面3条记录n n select * from Account limit 5 offset 3 或者 select * from Account limit 3,5 n b.select * from Account limit 3,5,指的是跳过前面的3条记录,然后获取5条记录n c.select * from Account limit 3,5是select * from Account limit 5 offset 3语句 n n 的简写版 -------------------------------------------------------------------------------n 3.常用操作: a.插入语句:insert into 表名(字段列表) values(值列表)。如: insert into person nn n n (name, age) values(‘传智’,3) b.更新语句:update 表名 set 字段名=值where 条件子句。如:update person set name=n n n n'credream ‘where id=10 c.删除语句:delete from 表名 where 条件子句。如:delete from person nwhere id=10 -------------------------------------------------------------------------------2.虽然无数据类型,但是建议加上,这样可以增加可读性,支持标准sql,oracle中的不行 ---------------------------------------------------3.获取添加记录后的自增长的ID值:select last_insert_rowid(); -----------------------------------------------------------4.在android中开发数据库应用: n a.创建数据库:以前在javaee时候,需要手工数据,但是android应用,需要运行在用户的 n n 手机上,所以,android应用,要有自动创建数据库功能,当第一次使用软件的时候 n n 就创建数据库----------------------------------------5.关于数据库自动创建的详细介绍: 我们在编写数据库应用软件时,需要考虑这样的问题:因为我们开发的软件可能会安装在很 n n 多用户的手机上,如果应用使用到了SQLite数据库,我们必须在用户初次使用软件时创建出 n n 应用使用到的数据库表结构及添加一些初始化记录,另外在软件升级的时候,也需要对数据 n n 表结构进行更新。那么,我们如何才能实现在用户初次使用或升级软件时自动在用户的手机 n n 上创建出应用需要的数据库表呢?总不能让我们在每个需要安装此软件的手机上通过手工方 n n 式创建数据库表吧?因为这种需求是每个数据库应用都要面临的,所以在Android系统,为我 n n 们提供了一个名为SQLiteOpenHelper的抽象类,必须继承它才能使用,它是通过对数据库版 n n 本进行管理来实现前面提出的需求。n -----------------------------------------6.SQLite数据库添加,删除,改查操作 n A.创建数据库:SQLiteOpenHelper .getWritableDatabase ()或getReadableDatabase() n n 可以创建数据库7.创建完成以后可以使用SQLITE Expert软件打开生成的数据库n 可以看到除了生成的自己的需要的表之外,还生成了一张:android_metadata表: n 如果在sqlite中使用数据库一定会有一张android_metadata表,用来登记用户的 n 使用语言:zh_cn -----------------------------------------------------n b.数据库自动创建的过程及方法详细介绍: n n我们在编写数据库应用软件时,需要考虑这样的问题:因为我们开发的软件可能会安装在 n n 很多用户的手机上,如果应用使用到了SQLite数据库,我们必须在用户初次使用软件时创建 n n 出应用使用到的数据库表结构及添加一些初始化记录,另外在软件升级的时候,也需要对数n n 据表结构进行更新。那么,我们如何才能实现在用户初次使用或升级软件时自动在用户的手 n n 机上创建出应用需要的数据库表呢?总不能让我们在每个需要安装此软件的手机上通过手工 n n 方式创建数据库表吧?因为这种需求是每个数据库应用都要面临的,所以在Android系统,为n n 我们提供了一个名为SQLiteOpenHelper的抽象类,必须继承它才能使用,它是通过对数据库n n 版本进行管理来实现前面提出的需求。n -------------------------------------------8.详细介绍: 为了实现对数据库版本进行管理,SQLiteOpenHelper类提供了两个重要的方法,分别是 n n onCreate(SQLiteDatabase db)和onUpgrade(SQLiteDatabase db, int oldVersion, intn n n newVersion),前者用于初次使用软件时生成数据库表,后者用于升级软件时更新数据库表结n n 构。当调用SQLiteOpenHelper的getWritableDatabase()或者getReadableDatabase()方法获n n 取用于操作数据库的SQLiteDatabase实例的时候,如果数据库不存在,Android系统会自动生 n n 成一个数据库,接着调用onCreate()方法,onCreate()方法在初次生成数据库时才会被调用 n n ,在onCreate()方法里可以生成数据库表结构及添加一些应用使用到的初始化数据。 n n onUpgrade()方法在数据库的版本发生变化时会被调用,一般在软件升级时才需改变版本号, n n 而数据库的版本是由程序员控制的,假设数据库现在的版本是1,由于业务的变更,修改了数n n 据库表结构,这时候就需要升级软件,升级软件时希望更新用户手机里的数据库表结构,为n n 了实现这一目的,可以把原来的数据库版本设置为2(有同学问设置为3行不行?当然可以,如 n n 果你愿意,设置为100也行),并且在onUpgrade()方法里面实现表结构的更新。当软件的版本 n n 升级次数比较多,这时在onUpgrade()方法里面可以根据原版号和目标版本号进行判断,然后 n n 作出相应的表结构及数据更新。 getWritableDatabase()和getReadableDatabase()方法都可以获取一个用于操作数据库的 n n SQLiteDatabase实例。但getWritableDatabase() 方法以读写方式打开数据库,一旦数据库n n 的磁盘空间满了,数据库就只能读而不能写,倘若使用的是getWritableDatabase() 方法就 n n 会出错。getReadableDatabase()方法先以读写方式打开数据库,如果数据库的磁盘空间满了 n n ,就会打开失败,当打开失败后会继续尝试以只读方式打开数据库。 ------------------------------------------------------------------------9.创建数据库的代码: n a.创建项目:DBSQLIte n b./DBSQLIte/src/com/credream/service/DBOpenHelter.java n n package com.credream.service; n n import android.content.Context; import android.database.sqlite.SQLiteDatabase; import android.database.sqlite.SQLiteOpenHelper; import android.database.sqlite.SQLiteDatabase.CursorFactory; n n public class DBOpenHelter extends SQLiteOpenHelper { //父类没有默认构造器,需要显示调用 public DBOpenHelter(Context context) { super (context, "credream.db", null, 1); //数据库创建完成后,默认会保存在<包>/database/文件夹下 //当修改版本号时候,会触发:onUpgrade方法 //第二个:指定数据库名称, //第三个:游标工厂,用来迭代,查询后的结果集,null代表使用系统默认的 n n 游标工厂//版本号,大于0 n } /** n* 这个方法是在数据库第一次被创建的时候调用的 n*/ @Override public void onCreate(SQLiteDatabase db) { //SQLiteDatabase这个类,封装了增删改查操作,也叫做数据库操作实例 db.execSQL("CREATE TABLE person (personid integer primary keyn n n autoincrement, name varchar(20))"); //这里也可以不写name的数据类型,因为sqlite是数据类型无关的,就是写n n 了varchar(20),也可以写入超过20的内容 n n } /** n* 当数据库的版本号变更的时候被调用 n*/ @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { db.execSQL("alter table person add phone varchar(12) null"); n n } n n } --------------------------------------------------------2.在清单文件中写入测试环境 n n n n n n n n n n ---------------------------------------------------- 3./DBSQLIte/src/com/credream/test/PersonServiceTest.java package com.credream.test; n n import com.credream.service.DBOpenHelter; n n import android.test.AndroidTestCase; n n public class PersonServiceTest extends AndroidTestCase { //创建数据库,在<包>/database/ public void testCreateDB(){ DBOpenHelter dbOpenHelter=new DBOpenHelter(getContext()); dbOpenHelter.getWritableDatabase(); n } n n } -------------------------------------------------------4.选择方法开始测试,然后,在data/data/<包>/database/下 n 查看并用sqlite打开生成的数据库检查是否正确---------------------------------------------然后将版本号,改成2,然后再次执行,看到,表已经被更新,增加了一列phone -----------------------------------------------5.了解sqlite工作的原理: n DBOpenHelter dbOpenHelter=new DBOpenHelter(getContext()); dbOpenHelter.getWritableDatabase(); n 打开getWritableDatabase();代码:

sqlite3常用命令及语法

https://www.doczj.com/doc/954005608.html,/linchunhua/article/details/7184439 sqlite数据库只用一个文件就ok,小巧方便,所以是一个非常不错的嵌入式数据库,SQLite 大量的被用于手机,PDA,MP3播放器以及机顶盒设备。 Mozilla Firefox使用SQLite作为数据库。 Mac计算机中的包含了多份SQLite的拷贝,用于不同的应用。 PHP将SQLite作为内置的数据库。 Skype客户端软件在内部使用SQLite。 SymbianOS(智能手机操作平台的领航)内置SQLite。 AOL邮件客户端绑定了SQLite。 Solaris 10在启动过程中需要使用SQLite。 McAfee杀毒软件使用SQLite。 iPhones使用SQLite。 Symbian和Apple以外的很多手机生产厂商使用SQLite。 下面就sqlite中的常用命令和语法介绍 https://www.doczj.com/doc/954005608.html,/download.html可下载不同操作系统的相关版本sqlite gedit 也可以使用火狐中的插件sqlite manager 新建数据库 sqlite3 databasefilename 检查databasefilename是否存在,如果不存在就创建并进入数据库(如果直接退出,数据库文件不会创建)如果已经存在直接进入数据库对数据库进行操作 sqlite中命令: 以.开头,大小写敏感(数据库对象名称是大小写不敏感的) .exit .help 查看帮助针对命令 .database 显示数据库信息;包含当前数据库的位置 .tables 或者.table 显示表名称没有表则不显示 .schema 命令可以查看创建数据对象时的SQL命令; .schema databaseobjectname查看创建该数据库对象时的SQL的命令;如果没有这个数据库对象就不显示内容,不会有错误提示 .read FILENAME 执行指定文件中的SQL语句 .headers on/off 显示表头默认off .mode list|column|insert|line|tabs|tcl|csv 改变输出格式,具体如下 sqlite> .mode list sqlite> select * from emp; 7369|SMITH|CLERK|7902|17-12-1980|800||20 7499|ALLEN|SALESMAN|7698|20-02-1981|1600|300|30 如果字段值为NULL 默认不显示也就是显示空字符串

初级中学三级-五级考试题型(国标版,新课标版)

第二十一届《新课标英语考级教程》初中三、四、五级考试题型 注意:此题考级的试题核心重点严格贯彻2011年6月版《英语课程标准》的要求和规定。 第二十一届新课标英语等级测试全国统一试题(EGT初中三、四、五级),本套试题总分120分,一共三部分—听力、笔试、口试。 第一部分为听力,分值为20分; 第二部分为基础知识与综合能力运用,分值为80分; 第三部分为口试,分值为20分。 全部答案都必须按要求在答题卡中相对应题号下填涂或书写,要求填涂正确、书写工整、清晰、规范,卷面清洁。 (考试只是手段,不是目的。所以能让学生在准备考试的过程中不断的提高才是考试的真正目的。不管是何种题型,都不该仅仅拘泥于对单个知识点的考查,而应考查学生在具体情境中运用所学英语知识与技能的综合语言运用能力。) 第Ⅰ卷听力占笔试20% (共20分每个小题1分) 一、听录音,从下面所给的选项中选择与句子内容相符的图片。每个对话读两遍。(共5分,每小题1分) 备注:难度递进,5级句子只读一遍。 e.g. (C)1. A. B. C.

录音原文:1. T om is reading. 评析 此题型要求学生听句子选择与句子描述相符合的图片。可以考查学生看图想其英语表达,听音联系其英文表达,达到通过一个题目考查学生三种能力的目的。注意在选图时,所使用的图画要清晰明了。尽量避免因学生的生活经验或文化背景的差异而导致不能正确识别图画的可能性。 二、听录音,根据你听到的句子,选出最恰当的应答。每个句子读两遍。(共5分,每小题1分) e.g.(A)1. A. Here you are. B. Here we are. C. It‘s yours. 录音原文:Q: Can I borrow your pen? 评析 此题型要求学生在听到句子后,给出相应的答语。考查学生反应能力。这种形式的题型很接近生活中英语的实际运用,即一些应答,寻求信息等。 三、听录音,判断下列句子是否符合你所听到的对话内容,符合的用“A”表示,不符合的用“B”表示。每个句子读两遍。(共5分,每小题1分) e.g. ( B ) 1.The dinner will be ready in an hour and hal f. 录音原文:---I am so hungry. When will the dinner be ready, mum?

sqlite3使用教程

Sqlite3教程 一、基本命令 1、进入命令行环境: 显示版本号,并告诉每一条SQL语句必须用分号;结尾2、命令行帮助:

3、退出命令行环境 或者 二、数据库相关命令 1、创建(或打开)一个新的数据库:文件名 若文件存在,刚打开该文件;若文件不存在,则创建一个*.db数据库文件。 导入SQL语句文件。

、列出所有数据表: 4、显示数据库结构: 用一些SQL语句描述数据库的结构。 5、显示表的结构:表名 6、导入数据:文件名表名 若导入csv文件,设置分隔符为逗号。 、导出数据:文件名 查询结果默认在终端显示,查询表格结构,语句查询表格数据。设置查询目标后,查询结果显示在设置的文件中 文件名 然后输入sql查询语句,查询的结果显示在设置的文件中,不在终端显示 运行恢复导出到终端(标准输出)。 导出数据到excle表格中 设置分隔符为逗号: 设置导出文件名,后缀为csv: 查询语句:表名

三、数据显示命令 运行表名,显示全表的内容 1.设置分隔符:分隔符 默认分隔符是“|”。 2.设置显示模式:模式

默认的是list显示模式,一般使用column模式。 3.显示标题栏: 4.设置每一列的显示宽度: 5.列出当前显示格式设置情况: 四、数据库基本操作 1.数据库定义语言DDL 在关系型数据库中,数据库中的表table、视图、索引、关系和触发器等等,构成了数据库的架构。在SQL语句中,专门有一些语句用来定义数据库架构,这些语句被称为“数据库定义语言”,即DDL。 SQLite数据库引擎支持下列三种DDL语句: ●CREATE:创建 ●ALTER TABLE:改变表的结构 ●DROP:删除

Android实验报告_基于SQLite的通信录

第一次实验Android界面设计 一. 实验目的及实验环境 1. 实验目的 1)掌握SQLiteOpenHelper类结构 2)掌握基于SQLite数据库的应用开发过程 3)掌握Content Provider发布数据的方法 4)掌握Content Resolver获取数据的方法 2.实验环境 系统开发平Android Studio 3.0 系统开发平台:Android 7.1 运行平台:Windows10 x64 运行环境:https://www.doczj.com/doc/954005608.html, Framework SDK 2.0 二. 实验教材、组织方式、实验容 1.实验教材:Andorid开发与应用 2.组织方式:个人独立完成 2.实验容: 实现基于SQLite数据库的通信录应用,通过单击增加图标打开添加通信录界面,通过单击通信录中的各条信息可删除选中项。 三.方案设计 Android系统中集成了SQLite数据库,并且为数据库的操作提供了相关的类和方法,便于没有数据库开发经验的开发者编写程序。另外,Android平台中利用Content Provider机制来实现跨应用程序数据共享。一个应用程序可以通过Content Provider来发布自己的数据,其他的应用程序可以通过Content Resolver来获取共享数据。

四.运行结果

五.总结 通过这次实验掌握了SQLite OpenHelper类结构,掌握了基于SQLite数据库的应用开发过程以及Content Provider发布数据的方法和掌握Content Resolver 获取数据的方法。 六.附录:源代码 主布局文件activity_main.xml:

SQLITE3的操作方法及应用

数据库的操作 我们在这个项目中使用的是SQLITE3数据库软件。 通过使用SQLITE3进行创建数据库,创建表,插入记录,查询记录,更新记录,关闭数据库等操作来实现将相应的数据存入数据库中。 1.打开数据库,创建表 1.1sqlite*db;定义一个sqlite*的变量 sqlite3_open(“./link.db”,&db); 在当前目录下打开一个名为link.db的数据库,若是没有则在当前目录下创建一个名为link.db 的数据库。 1.2sql="create table weblink(id integer primary key,domain text,page text,fromdomain text,status integer);" 在已打开的数据库中创建一个名weblink的表。表的属性如下: id integer primary key:ID号(表中黙认包含的) domain text:域名 page text:子网页 fromdomain text:源域名 status integer:状态标志 1.3sqlite3_exec(db,sql,NULL,NULL,NULL); 执行一条sql语句的函数。 函数原型:int sqlite3_exec(sqlite3*,const char*sql,sqlite3_callback,void*,char**errmsg) 第1个参数是前面open函数得到的指针。说了是关键数据结构。 第2个参数const char*sql是一条sql语句,以\0结尾。 第3个参数sqlite3_callback是回调,当这条语句执行之后,sqlite3会去调用你提供的这个函数。(什么是回调函数,自己找别的资料学习) 第4个参数void*是你所提供的指针,你可以传递任何一个指针参数到这里,这个参数最终会传到回调函数里面,如果不需要传递指针给回调函数,可以填NULL。等下我们再看回调函数的写法,以及这个参数的使用。 第5个参数char**errmsg是错误信息。注意是指针的指针。sqlite3里面有很多固定的错误信息。执行sqlite3_exec之后,执行失败时可以查阅这个指针(直接printf(“%s\n”,errmsg))得到一串字符串信息,这串信息告诉你错在什么地方。sqlite3_exec函数通过修改你传入的指针的指针,把你提供的指针指向错误提示信息,这样sqlite3_exec函数外面就可以通过这个char*得到具体错误提示。 说明:通常,sqlite3_callback和它后面的void*这两个位置都可以填NULL。填NULL表

Android 实验报告 Sqlite 数据库操作

2、掌握Android的SQLite数据库设计; 3、掌握Android的Activity 和Fragement用法; 4、熟悉XML 和JSon 文件读取 三、实验内容 要求使用SQLite数据库实现用户注册和登录,读取数据库信息,退出时生成XML文件或JSON文件。 四、实验过程和结果 content_main.xml: MainActivity.java: RegisterActivity.java: public class RegisterActivity extends Activity { SQLiteDatabase db; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(https://www.doczj.com/doc/954005608.html,yout.content_register); /*start*/ db = SQLiteDatabase.openOrCreateDatabase(this.getFilesDir().toString()+"/user.db3", null); /**/ Button register = (Button)findViewById(R.id.register); register.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { String username = ((EditText)findViewById(https://www.doczj.com/doc/954005608.html,ername)).getText().toString(); String password = ((EditText)findViewById(R.id.password)).getText().toString(); try{ String sql = "create table if not exists user_info (_id integer " + " primary key autoincrement," + " username varchar(255)," + " password varchar(255)" + ")"; db.execSQL(sql); sql = "insert into user_info values( null,?,?)";

sqlite 基本操作 全

sqlite3本地数据库学习 sqlite3只是一个轻型的嵌入式数据库引擎,占用资源非常低,处理速度比mysql还快,专门用于移动设备上进行适量的数据存取,它只是个文件,不需要服务器进程。 常用术语:表(table)、字段(colum,列,属性)、记录(row,record) 关键字:select、insert、updete、delete、from、creat、where、desc、order、by、group、table、alter、view、index等。 1、安装sqlite3 sudo()apt-get()install()sqlite3 2、存储类型 integer 整型:int,shoert,long text 文本字符串:string real 浮点型:float,double blob 二进制 3、字段结束 not null:字段的值不能为空 unique:字段的值必须是唯一的 default:指定字段的默认值 primarykey:主键,用来唯一的标识某条记录,相当于记录的身份证。主键可以是一个或多个字段,应由计算机自动生成和管理。主键字段默认包含了not null和unique两个约束。 autoincrement:当主键是integer类型时,应该增加autoincrement约束,能实现主键值的自动增长。 外键:利用外键可以用来建立表与表之间的联系,一般是一张表的某个字段,引用着另一张表的主键。 4、创建数据库usr.db在当前目录下 sqlite3()usr.db 5、创建表格,表格内容以树状存储 create()table()表名(字段名1()字段类型1,字段名2()字段类型2...) 6、数据库中不能使用关键字命名表和字段,不区分大小写,每条语句后加";"结尾 7、删除表格 drop()table()表名 8、向表格里添加数据 insert()into()表名(字段1,字段2...)values(字段1的值,字段2的值...) 8、修改表中的数据 updata()表名()set()字段1=字段1的值,字段2=字段2的值... //将字段为name全部修改成'Tom' updata()stu()set()name='Tom'; //将字段为id=1001的字段name修改成'Tom' updata()stu()set()name='Tom'()where()id=1001; //将字段为id=1001同时字段name='lisi'的字段name修改成'Tom' updata()stu()set()name='Tom'()where()id=1001()and()name='lisi'; 9、删除表中的数据

《新课标英语考级教程》小学一二级考试题型

十九届《新课标英语考级教程》小学一、二级考试题型 注意:此题考级的试题核心重点严格贯彻2011年6月版《英语课程标准》的要求和规定。 第十九届新课标英语等级测试全国统一试题(EGT小学一、二级),本套试题总分120分,一共三部分—听力、基础知识与综合能力运用和口试。 第一部分为听力,分值为20分; 第二部分为基础知识与综合能力运用,分值为80分; 第三部分为口试,分值为20分。 全部答案都必须按要求在答题卡中相对应题号下填涂或书写,要求填涂正确、书写工整、清晰、规范,卷面清洁。 (考试只是手段,不是目的。所以能让学生在准备考试的过程中不断的提高才是考试的真正目的。不管是何种题型,都不该仅仅拘泥于对单个知识点的考查,而应考查学生在具 体情境中运用所学英语知识与技能的综合语言运用能力。) 第Ⅰ卷听力理解占笔试20% (共20分每个小题1分) 一、听录音,选择你所听到的单词。每个单词只读一遍。(共5分,每小题1分) e.g. (C) 1. A. cup B. cap C. cake 录音原文:1. cake 评析 此题型要求学生听单词录音选择单词。主要考察学生对语音知识的掌握。题目中设计的单词都会含有相同或者相似的一部分字母或者字母组合,学生需要准确掌握其读音才能更准确地完成此题。 ) 二、听录音,选择与你所听到单词相符的图片。每个单词只读一遍。(共5分,每小题1分 录音原文:1. listen 评析 此题型要求学生听单词录音选择与单词相符合的图片。可以考查学生看图想其英语表达,听音联系其英文表达,达到通过一个题目考查学生三种能力的目的。注意在选图时,所使用的图画要清晰明了。尽量避免因学生的生活经验或文化背景的差异而导致不能正确识别图画的可能性。

QSQLite 数据库

这里我们只是演示了一下使用这个框架完成最简单的程序的过程,只起到抛砖引玉的作用。这个框架很复杂,但是功能也很强大,Qt Creator中自带了几个相关的例子(在帮助中查找Graphics View Examples即可),你可以参考一下。因为篇幅问题,我们就只讲这么多,如果以后有机会,我会推出一个相关的专题来讲述这个框架。 分类:Qt系列教程作者: yafeilinux 日期:四月 30th, 2010. 3,006 views Tags: 2D绘图, creator, qt, yafeilinux, 教程

二十一、Qt数据库(一)简介 本文章原创于https://www.doczj.com/doc/954005608.html,转载请注明出处。 从今天开始我们学习Qt数据库编程的内容。 先说明:我们以后使用现在最新的基于Qt 4.6.2的Qt Creator 1.3.1 Windows版本,该版本是2010年2月17日发布的。 数据库几乎是每个较大的软件所必须应用的,而在Qt中也使用QtSql模块实现了对数据库的完美支持。我们在Qt Creator的帮助中查找QtSql Module,其内容如下图: 可以看到这个模块是一组类的集合,使用这个模块我们需要加入头文件#include ,而在工程文件中需要加入一行代码:QT += sql 这里每个类的作用在后面都有简单的介绍,你也可以进入其中查看其详细内容。下面我们先简单的说一下QSqlDatabase类和QSqlQuery类。 QSqlDatabase类实现了数据库连接的操作,现在Qt支持的数据库类型有如下几种: 而现在我们使用的免费的Qt只提供了SQLite和ODBC数据库的驱动(我们可以在Qt Creator 安装目录下的qt\plugins\sqldrivers文件夹下查看),而其他数据库的驱动需要我们自己添加。SQLite是一个小巧的嵌入式数据库,关于它的介绍你可以自己在网上查找。 QSqlQuery类用来执行SQL语句。(关于SQL语句:在我的教程中只会出现很简单的SQL语句,你没有相关知识也可以看懂,但是如果想进行深入学习,就需要自己学习相关知识了。)

SQLITE最基本操作

SQLite数据库的基本操作 main.xml(主布局)

android:orientation="vertical">

SQLite语法与Android数据库操作

SQLite语法与Android数据库操作 学习android的小伙伴们在使用Android的SQLiteDatabase类进行数据库操作的时候总会有一些力不从心,特别是对于初涉数据库的小伙伴来说更是如此。 这是因为Android的SQLiteDatabase原本就不是依赖于Android而存在的,而是单独的作为一个个体而存在的,有着自己特有的体系和语言,而这就是SQL 语法了。 关于SQLite数据库的理论知识网上一搜一大片,这里就不多说。SQLite是一个轻量型的数据库,它对于大型数据库来说功能少,因此只需要学习一些通用的SQL语法就能够轻松掌握,而这些SQL语法对于其他的数据库来说也是基本不变化的。 但SQLite有个缺点,那就是作为轻量级选手的它,如果要保存大量数据会力有不及,因此它在android中适合保存个人设置等没有大量数据的信息。 好了,下面就是正式学习SQLite了,只有掌握了SQLite,掌握SQL语法,才能对Android中的数据库操作运用自如。 SQLite的数据类型 与Java语言一样,SQLite也有其特有的数据类型,当然相比MySQL来说只有5种数据类型算是很少了 NULL:空值相当于Java中的null INTEGER:带符号的整型,相当于Java中的int型 REAL:浮点数字,相当于Java中float/double型 TEXT/VARCHAR:字符串文本,相当于Java中String类 BLOB:二进制对象,相当于Java中的byte数组,用于存放图片、声音等文件 Sqlite3中的约束 SQLite的约束是什么呢?约束就是限定数据库字段的条件,如果有个student数据表,它里面有一个age年龄的属性字段,我们要求数据库保存age 这个字段的时候必须有值,不能为空,那么就可以设置为:"age INTEGER NOT NULL"。这句话的意思就是age字段是不能为空的整型 NOT NULL :非空

新课标英语考级教程三级A-1

新课标英语考级教程3A Lesson7 第3课时 What would you like? 浙江省象山协华外语学校Eva 一、Teaching contents: Dialogue1 —What would you like? 二、Teaching aims and demands: (1) M aster skillfully and use the pattern:would like sth, would like to do sth (2) L et Ss learn to make sentences with the substitutions. 三、Main points: Master and use the patterns:would like sth, would like to do sth 四、Difficult points: (1) would like “... ,想要...”,相当于want,是较委婉的表达方式,后接名词或动词不定式. (2) how much 多少,是对数量或价钱来提问. 五、 Teaching aids: (1) A recorder (2) some pictures 六、Teaching procedures: Step1 Preparation (1) T: Hello,everyone. S: Hello,Miss Yu. (2) T: Who is not here? S: Li Ming is not here. (3) T: What day is today? S: It’s Thursday. (4) T: How’s the weather? S: It’s sunny. (5) T: What food do you like? S: I like vegetables. (6) T: Do you like coffee? S: Yes, I do./ No, I don’t. Step2 Revision (1) Review the following words we have learned last class: well,fresh,Sprite, salad, biscuit, shopkeeper, done, medium, bean, order, dinner, waitress, steak, rare. a. Teacher speaks in English,Ss speak in Chinese quickly. b. Teacher speaks in Chinese, Ss speaks in English one by one. (2) Listen and write down the following words and their Chinese meanings: well,fresh,done, bean,order, steak. Step3 Presentation (1) Lead in the dialogue. T: We eat something every day,but some people like to eat apples,some people don’t. Now firstly, I tell you what I would like to eat.Listen to me carefully,then I will ask you. Teacher shows some pictures and says: I’d like some bread. I’d like some biscuits. I’d like to eat apples. I’d like to eat bananas. (Teacher writes down the four sentences on the blackboard and ask Ss to read them after the teacher.) T: What would you like? (Let Ss try to say,the teacher guides them.)

相关主题
文本预览
相关文档 最新文档