更新时间:2020-01-22编辑:佚名阅读(1559)
sqlite会自动维护一个系统表sqlite_master,该表存储了我们所创建的各个table, view, trigger等等信息。
sqlite_master表数据字段:
type: 类型,取值一般为table, view
name:
tbl_name: 表名
rootpage:
sql:创建表或者视图的sql语句,可以从该sql语句中判断某字段是否存在
sqlite_master表结构如下:
CREATE TABLE sqlite_master ( type TEXT, name TEXT, tbl_name TEXT, rootpage INTEGER, sql TEXT );
例如:
select * from sqlite_master where type = 'table' and name = 't_cmpt_cp'
1. 查询与判断表
查询sqlite中所有表,可用如下sql语句。
select name from sqlite_master where type='table' order by name;
我们可以通过如下语句查看这个内建表的所有记录:
select * from sqlite_master
由此可以进一步引申:判断指定的表是否存在,可以用如下语句:
select count(*) from sqlite_master where type='table' and name = 'yourtablename';
或者
其中yourtablename表示你要判断的表名,如果查询结果大于0,表示该表存在于数据库中,否则不存在。
2. 查询与判断列
通过以下语句可查询出某个表的所有字段信息
PRAGMA table_info([tablename])
比如:我想查看表catalog的所有列信息,可以用下述代码,结果如图所示:
PRAGMA table_info(t_cmpt_cp)
判断某列是否存在的方法:
方法1:
/** * 检查表中某列是否存在 * @param db * @param tableName 表名 * @param columnName 列名 * @return */ private boolean checkColumnExists2(SQLiteDatabase db, String tableName , String columnName) { boolean result = false ; Cursor cursor = null ; try{ cursor = db.rawQuery( "select * from sqlite_master where name = ? and sql like ?" , new String[]{tableName , "%" + columnName + "%"} ); result = null != cursor && cursor.moveToFirst() ; }catch (Exception e){ Log.e(TAG,"checkColumnExists2..." + e.getMessage()) ; }finally{ if(null != cursor && !cursor.isClosed()){ cursor.close() ; } } return result ; }
方法2:
/** * 判断某表里某字段是否存在 * * @param db * @param tableName * @param fieldName * @return */ private boolean isFieldExist(SQLiteDatabase db, String tableName, String fieldName) { String queryStr = "select sql from sqlite_master where type = 'table' and name = '%s'"; queryStr = String.format(queryStr, tableName); Cursor c = db.rawQuery(queryStr, null); String tableCreateSql = null; try { if (c != null && c.moveToFirst()) { tableCreateSql = c.getString(c.getColumnIndex("sql")); } } finally { if (c != null) c.close(); } if (tableCreateSql != null && tableCreateSql.contains(fieldName)) return true; return false; }
方法3:
根据 cursor.getColumnIndex(String columnName) 的返回值判断,如果为-1表示表中无此字段
/** * 检查某表列是否存在 * @param db * @param tableName 表名 * @param columnName 列名 * @return */ private boolean checkColumnExist1(SQLiteDatabase db, String tableName , String columnName) { boolean result = false ; Cursor cursor = null ; try{ //查询一行 cursor = db.rawQuery( "SELECT * FROM " + tableName + " LIMIT 0" , null ); result = cursor != null && cursor.getColumnIndex(columnName) != -1 ; }catch (Exception e){ Log.e(TAG,"checkColumnExists1..." + e.getMessage()) ; }finally{ if(null != cursor && !cursor.isClosed()){ cursor.close() ; } } return result ; }
3. Sqlite中新增、删除、重命名列
3.1 新增一列
方法:使用sql命令
命令:ALTER TABLE table-name ADD COLUMN column-name column-type
例如:在student表中添加一列名为name,类型为varchar:
alter table student add column name varchar; alter table catalog add column xxx1 char(20) default '';
3.2 删除一列
方法:由于drop命令在sqlite中不可用于删除列,
alter table student drop column name // 该行在SQlite中不能用,SQlite不支持drop
可采用如下思路,类似于swap()函数的过程。
比如我有表A,A中有x、y、z三列。我要将表A中的x列删掉。那么,
第1步,新建一个表B,B中含有y、z两个字段,且类型与A中的y、z类型相同。
第2步,将A中的所有y、z两列的值拷贝到B中。
上面两步使用一句命令即可完成
create table B as select y,z from A
注意,如果A中y的类型为char,则上面create命令会在B中创建类型为TEXT的y列。即char类型会被改变。
第3步,将A表删除
drop table if exists A
第4步,将B重命名为A
alter table B rename to A
3.3 重命名一列
方法:与删除一列相同,在sqlite中alter同样无法重命名一列。如果想重命名,那么思路与删除一列相同。
4. Sqlite中新增、删除、重命名表
Sql语句在3.2中已有。整理如下。
4.1 新增表
create table A(id char(20),channeltext,name text,primary key (id)) create table B as select y,z from A
4.2 删除表
drop table if exists A
4.3 重命名表
alter table B rename to A
下一篇:唱戏机内存卡解密
0人
0人
1人
0人