On 11/9/08, LordEricO <[EMAIL PROTECTED]> wrote:
>
>  I am using jdbc to work with my sqlite database in java.  I need to remove a
>  row of in my database.  However, I never really designed a column that could
>  be a primary key.  I think sqlite puts it's own auto-incremented value for
>  each row in automatically.  Is there a way I could use that to delete the
>  row?  Or do I have to create an "ID" column?
>  Thanks,
>  Eric
>
> --


did you read the docs at all? See http://www.sqlite.org/lang_createtable.html

"Specifying a PRIMARY KEY normally just creates a UNIQUE index on the
corresponding columns. However, if primary key is on a single column
that has datatype INTEGER, then that column is used internally as the
actual key of the B-Tree for the table. This means that the column may
only hold unique integer values. (Except for this one case, SQLite
ignores the datatype specification of columns and allows any kind of
data to be put in a column regardless of its declared datatype.) If a
table does not have an INTEGER PRIMARY KEY column, then the B-Tree key
will be a automatically generated integer. The B-Tree key for a row
can always be accessed using one of the special names "ROWID", "OID",
or "_ROWID_". This is true regardless of whether or not there is an
INTEGER PRIMARY KEY. An INTEGER PRIMARY KEY column can also include
the keyword AUTOINCREMENT. The AUTOINCREMENT keyword modified the way
that B-Tree keys are automatically generated. Additional detail on
automatic B-Tree key generation is available separately."




-- 
Puneet Kishor http://punkish.eidesis.org/
Nelson Institute for Environmental Studies http://www.nelson.wisc.edu/
Open Source Geospatial Foundation (OSGeo) http://www.osgeo.org/
_______________________________________________
sqlite-users mailing list
[email protected]
http://sqlite.org:8080/cgi-bin/mailman/listinfo/sqlite-users

Reply via email to