Sqlite 建表语句

这篇博客讨论了如何在SQLite中使用SQL语句创建带有主键的表,特别是当主键是否设置为自动递增时的差异。作者回顾了之前在Android项目中创建不包含显式主键的表的情况,并疑惑这样的表为何可以正常工作,推测可能是SQLite默认生成了主键。
摘要由CSDN通过智能技术生成
[size=18px]今天看到sqlite ,要用sql语句建立一张表,其中有这么个主键的字段[/size]
 

 StringBuffer sqlBuffer = new StringBuffer();
        sqlBuffer.append("CREATE TABLE IF NOT EXISTS ");
        sqlBuffer.append(table.tableName);
        sqlBuffer.append(" ( ");

        if (id.isAutoIncrement()) {
            sqlBuffer.append("\"").append(id.getColumnName()).append("\"  ").append("INTEGER PRIMARY KEY AUTOINCREMENT,");
        } else {
            sqlBuffer.append("\"").append(id.getColumnName()).append("\"  ").append(id.getColumnDbType()).append(" PRIMARY KEY,");
        }


我记得刚学android 的时候做的项目中用到了sqlite,使用的建表语句,是没有主键的


    /**
     * 创建表
     */
@Override
public void onCreate(SQLiteDatabase db) {
String sql = " create table "+ APPFinal.TABLE_NAME +"("
 + APPFinal.F_MUSICNAME + " nvarchar(50),"
 + APPFinal.F_MUSICARTIST + " nvarchar(10),"
 + APPFinal.F_MUSICPATH + " nvarchar(100),"
 + APPFinal.F_MUSICALBUM + " nvarchar(150))";

db.execSQL(sql);

}
但是能正常使用.这是为什么呢?难道是默认了生成了一个主键????
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值