os/persistentdata/persistentstorage/sqlite3api/TEST/TclScript/intpkey.test
author sl@SLION-WIN7.fritz.box
Fri, 15 Jun 2012 03:10:57 +0200 (2012-06-15)
changeset 0 bde4ae8d615e
permissions -rw-r--r--
First public contribution.
sl@0
     1
# 2001 September 15
sl@0
     2
#
sl@0
     3
# The author disclaims copyright to this source code.  In place of
sl@0
     4
# a legal notice, here is a blessing:
sl@0
     5
#
sl@0
     6
#    May you do good and not evil.
sl@0
     7
#    May you find forgiveness for yourself and forgive others.
sl@0
     8
#    May you share freely, never taking more than you give.
sl@0
     9
#
sl@0
    10
#***********************************************************************
sl@0
    11
# This file implements regression tests for SQLite library.
sl@0
    12
#
sl@0
    13
# This file implements tests for the special processing associated
sl@0
    14
# with INTEGER PRIMARY KEY columns.
sl@0
    15
#
sl@0
    16
# $Id: intpkey.test,v 1.24 2007/11/29 17:43:28 danielk1977 Exp $
sl@0
    17
sl@0
    18
set testdir [file dirname $argv0]
sl@0
    19
source $testdir/tester.tcl
sl@0
    20
sl@0
    21
# Create a table with a primary key and a datatype other than
sl@0
    22
# integer
sl@0
    23
#
sl@0
    24
do_test intpkey-1.0 {
sl@0
    25
  execsql {
sl@0
    26
    CREATE TABLE t1(a TEXT PRIMARY KEY, b, c);
sl@0
    27
  }
sl@0
    28
} {}
sl@0
    29
sl@0
    30
# There should be an index associated with the primary key
sl@0
    31
#
sl@0
    32
do_test intpkey-1.1 {
sl@0
    33
  execsql {
sl@0
    34
    SELECT name FROM sqlite_master
sl@0
    35
    WHERE type='index' AND tbl_name='t1';
sl@0
    36
  }
sl@0
    37
} {sqlite_autoindex_t1_1}
sl@0
    38
sl@0
    39
# Now create a table with an integer primary key and verify that
sl@0
    40
# there is no associated index.
sl@0
    41
#
sl@0
    42
do_test intpkey-1.2 {
sl@0
    43
  execsql {
sl@0
    44
    DROP TABLE t1;
sl@0
    45
    CREATE TABLE t1(a INTEGER PRIMARY KEY, b, c);
sl@0
    46
    SELECT name FROM sqlite_master
sl@0
    47
      WHERE type='index' AND tbl_name='t1';
sl@0
    48
  }
sl@0
    49
} {}
sl@0
    50
sl@0
    51
# Insert some records into the new table.  Specify the primary key
sl@0
    52
# and verify that the key is used as the record number.
sl@0
    53
#
sl@0
    54
do_test intpkey-1.3 {
sl@0
    55
  execsql {
sl@0
    56
    INSERT INTO t1 VALUES(5,'hello','world');
sl@0
    57
  }
sl@0
    58
  db last_insert_rowid
sl@0
    59
} {5}
sl@0
    60
do_test intpkey-1.4 {
sl@0
    61
  execsql {
sl@0
    62
    SELECT * FROM t1;
sl@0
    63
  }
sl@0
    64
} {5 hello world}
sl@0
    65
do_test intpkey-1.5 {
sl@0
    66
  execsql {
sl@0
    67
    SELECT rowid, * FROM t1;
sl@0
    68
  }
sl@0
    69
} {5 5 hello world}
sl@0
    70
sl@0
    71
# Attempting to insert a duplicate primary key should give a constraint
sl@0
    72
# failure.
sl@0
    73
#
sl@0
    74
do_test intpkey-1.6 {
sl@0
    75
  set r [catch {execsql {
sl@0
    76
     INSERT INTO t1 VALUES(5,'second','entry');
sl@0
    77
  }} msg]
sl@0
    78
  lappend r $msg
sl@0
    79
} {1 {PRIMARY KEY must be unique}}
sl@0
    80
do_test intpkey-1.7 {
sl@0
    81
  execsql {
sl@0
    82
    SELECT rowid, * FROM t1;
sl@0
    83
  }
sl@0
    84
} {5 5 hello world}
sl@0
    85
do_test intpkey-1.8 {
sl@0
    86
  set r [catch {execsql {
sl@0
    87
     INSERT INTO t1 VALUES(6,'second','entry');
sl@0
    88
  }} msg]
sl@0
    89
  lappend r $msg
sl@0
    90
} {0 {}}
sl@0
    91
do_test intpkey-1.8.1 {
sl@0
    92
  db last_insert_rowid
sl@0
    93
} {6}
sl@0
    94
do_test intpkey-1.9 {
sl@0
    95
  execsql {
sl@0
    96
    SELECT rowid, * FROM t1;
sl@0
    97
  }
sl@0
    98
} {5 5 hello world 6 6 second entry}
sl@0
    99
sl@0
   100
# A ROWID is automatically generated for new records that do not specify
sl@0
   101
# the integer primary key.
sl@0
   102
#
sl@0
   103
do_test intpkey-1.10 {
sl@0
   104
  execsql {
sl@0
   105
    INSERT INTO t1(b,c) VALUES('one','two');
sl@0
   106
    SELECT b FROM t1 ORDER BY b;
sl@0
   107
  }
sl@0
   108
} {hello one second}
sl@0
   109
sl@0
   110
# Try to change the ROWID for the new entry.
sl@0
   111
#
sl@0
   112
do_test intpkey-1.11 {
sl@0
   113
  execsql {
sl@0
   114
    UPDATE t1 SET a=4 WHERE b='one';
sl@0
   115
    SELECT * FROM t1;
sl@0
   116
  }
sl@0
   117
} {4 one two 5 hello world 6 second entry}
sl@0
   118
sl@0
   119
# Make sure SELECT statements are able to use the primary key column
sl@0
   120
# as an index.
sl@0
   121
#
sl@0
   122
do_test intpkey-1.12.1 {
sl@0
   123
  execsql {
sl@0
   124
    SELECT * FROM t1 WHERE a==4;
sl@0
   125
  }
sl@0
   126
} {4 one two}
sl@0
   127
do_test intpkey-1.12.2 {
sl@0
   128
  set sqlite_query_plan
sl@0
   129
} {t1 *}
sl@0
   130
sl@0
   131
# Try to insert a non-integer value into the primary key field.  This
sl@0
   132
# should result in a data type mismatch.
sl@0
   133
#
sl@0
   134
do_test intpkey-1.13.1 {
sl@0
   135
  set r [catch {execsql {
sl@0
   136
    INSERT INTO t1 VALUES('x','y','z');
sl@0
   137
  }} msg]
sl@0
   138
  lappend r $msg
sl@0
   139
} {1 {datatype mismatch}}
sl@0
   140
do_test intpkey-1.13.2 {
sl@0
   141
  set r [catch {execsql {
sl@0
   142
    INSERT INTO t1 VALUES('','y','z');
sl@0
   143
  }} msg]
sl@0
   144
  lappend r $msg
sl@0
   145
} {1 {datatype mismatch}}
sl@0
   146
do_test intpkey-1.14 {
sl@0
   147
  set r [catch {execsql {
sl@0
   148
    INSERT INTO t1 VALUES(3.4,'y','z');
sl@0
   149
  }} msg]
sl@0
   150
  lappend r $msg
sl@0
   151
} {1 {datatype mismatch}}
sl@0
   152
do_test intpkey-1.15 {
sl@0
   153
  set r [catch {execsql {
sl@0
   154
    INSERT INTO t1 VALUES(-3,'y','z');
sl@0
   155
  }} msg]
sl@0
   156
  lappend r $msg
sl@0
   157
} {0 {}}
sl@0
   158
do_test intpkey-1.16 {
sl@0
   159
  execsql {SELECT * FROM t1}
sl@0
   160
} {-3 y z 4 one two 5 hello world 6 second entry}
sl@0
   161
sl@0
   162
#### INDICES
sl@0
   163
# Check to make sure indices work correctly with integer primary keys
sl@0
   164
#
sl@0
   165
do_test intpkey-2.1 {
sl@0
   166
  execsql {
sl@0
   167
    CREATE INDEX i1 ON t1(b);
sl@0
   168
    SELECT * FROM t1 WHERE b=='y'
sl@0
   169
  }
sl@0
   170
} {-3 y z}
sl@0
   171
do_test intpkey-2.1.1 {
sl@0
   172
  execsql {
sl@0
   173
    SELECT * FROM t1 WHERE b=='y' AND rowid<0
sl@0
   174
  }
sl@0
   175
} {-3 y z}
sl@0
   176
do_test intpkey-2.1.2 {
sl@0
   177
  execsql {
sl@0
   178
    SELECT * FROM t1 WHERE b=='y' AND rowid<0 AND rowid>=-20
sl@0
   179
  }
sl@0
   180
} {-3 y z}
sl@0
   181
do_test intpkey-2.1.3 {
sl@0
   182
  execsql {
sl@0
   183
    SELECT * FROM t1 WHERE b>='y'
sl@0
   184
  }
sl@0
   185
} {-3 y z}
sl@0
   186
do_test intpkey-2.1.4 {
sl@0
   187
  execsql {
sl@0
   188
    SELECT * FROM t1 WHERE b>='y' AND rowid<10
sl@0
   189
  }
sl@0
   190
} {-3 y z}
sl@0
   191
sl@0
   192
do_test intpkey-2.2 {
sl@0
   193
  execsql {
sl@0
   194
    UPDATE t1 SET a=8 WHERE b=='y';
sl@0
   195
    SELECT * FROM t1 WHERE b=='y';
sl@0
   196
  }
sl@0
   197
} {8 y z}
sl@0
   198
do_test intpkey-2.3 {
sl@0
   199
  execsql {
sl@0
   200
    SELECT rowid, * FROM t1;
sl@0
   201
  }
sl@0
   202
} {4 4 one two 5 5 hello world 6 6 second entry 8 8 y z}
sl@0
   203
do_test intpkey-2.4 {
sl@0
   204
  execsql {
sl@0
   205
    SELECT rowid, * FROM t1 WHERE b<'second'
sl@0
   206
  }
sl@0
   207
} {5 5 hello world 4 4 one two}
sl@0
   208
do_test intpkey-2.4.1 {
sl@0
   209
  execsql {
sl@0
   210
    SELECT rowid, * FROM t1 WHERE 'second'>b
sl@0
   211
  }
sl@0
   212
} {5 5 hello world 4 4 one two}
sl@0
   213
do_test intpkey-2.4.2 {
sl@0
   214
  execsql {
sl@0
   215
    SELECT rowid, * FROM t1 WHERE 8>rowid AND 'second'>b
sl@0
   216
  }
sl@0
   217
} {4 4 one two 5 5 hello world}
sl@0
   218
do_test intpkey-2.4.3 {
sl@0
   219
  execsql {
sl@0
   220
    SELECT rowid, * FROM t1 WHERE 8>rowid AND 'second'>b AND 0<rowid
sl@0
   221
  }
sl@0
   222
} {4 4 one two 5 5 hello world}
sl@0
   223
do_test intpkey-2.5 {
sl@0
   224
  execsql {
sl@0
   225
    SELECT rowid, * FROM t1 WHERE b>'a'
sl@0
   226
  }
sl@0
   227
} {5 5 hello world 4 4 one two 6 6 second entry 8 8 y z}
sl@0
   228
do_test intpkey-2.6 {
sl@0
   229
  execsql {
sl@0
   230
    DELETE FROM t1 WHERE rowid=4;
sl@0
   231
    SELECT * FROM t1 WHERE b>'a';
sl@0
   232
  }
sl@0
   233
} {5 hello world 6 second entry 8 y z}
sl@0
   234
do_test intpkey-2.7 {
sl@0
   235
  execsql {
sl@0
   236
    UPDATE t1 SET a=-4 WHERE rowid=8;
sl@0
   237
    SELECT * FROM t1 WHERE b>'a';
sl@0
   238
  }
sl@0
   239
} {5 hello world 6 second entry -4 y z}
sl@0
   240
do_test intpkey-2.7 {
sl@0
   241
  execsql {
sl@0
   242
    SELECT * FROM t1
sl@0
   243
  }
sl@0
   244
} {-4 y z 5 hello world 6 second entry}
sl@0
   245
sl@0
   246
# Do an SQL statement.  Append the search count to the end of the result.
sl@0
   247
#
sl@0
   248
proc count sql {
sl@0
   249
  set ::sqlite_search_count 0
sl@0
   250
  return [concat [execsql $sql] $::sqlite_search_count]
sl@0
   251
}
sl@0
   252
sl@0
   253
# Create indices that include the integer primary key as one of their
sl@0
   254
# columns.
sl@0
   255
#
sl@0
   256
do_test intpkey-3.1 {
sl@0
   257
  execsql {
sl@0
   258
    CREATE INDEX i2 ON t1(a);
sl@0
   259
  }
sl@0
   260
} {}
sl@0
   261
do_test intpkey-3.2 {
sl@0
   262
  count {
sl@0
   263
    SELECT * FROM t1 WHERE a=5;
sl@0
   264
  }
sl@0
   265
} {5 hello world 0}
sl@0
   266
do_test intpkey-3.3 {
sl@0
   267
  count {
sl@0
   268
    SELECT * FROM t1 WHERE a>4 AND a<6;
sl@0
   269
  }
sl@0
   270
} {5 hello world 2}
sl@0
   271
do_test intpkey-3.4 {
sl@0
   272
  count {
sl@0
   273
    SELECT * FROM t1 WHERE b>='hello' AND b<'hello2';
sl@0
   274
  }
sl@0
   275
} {5 hello world 3}
sl@0
   276
do_test intpkey-3.5 {
sl@0
   277
  execsql {
sl@0
   278
    CREATE INDEX i3 ON t1(c,a);
sl@0
   279
  }
sl@0
   280
} {}
sl@0
   281
do_test intpkey-3.6 {
sl@0
   282
  count {
sl@0
   283
    SELECT * FROM t1 WHERE c=='world';
sl@0
   284
  }
sl@0
   285
} {5 hello world 3}
sl@0
   286
do_test intpkey-3.7 {
sl@0
   287
  execsql {INSERT INTO t1 VALUES(11,'hello','world')}
sl@0
   288
  count {
sl@0
   289
    SELECT * FROM t1 WHERE c=='world';
sl@0
   290
  }
sl@0
   291
} {5 hello world 11 hello world 5}
sl@0
   292
do_test intpkey-3.8 {
sl@0
   293
  count {
sl@0
   294
    SELECT * FROM t1 WHERE c=='world' AND a>7;
sl@0
   295
  }
sl@0
   296
} {11 hello world 4}
sl@0
   297
do_test intpkey-3.9 {
sl@0
   298
  count {
sl@0
   299
    SELECT * FROM t1 WHERE 7<a;
sl@0
   300
  }
sl@0
   301
} {11 hello world 1}
sl@0
   302
sl@0
   303
# Test inequality constraints on integer primary keys and rowids
sl@0
   304
#
sl@0
   305
do_test intpkey-4.1 {
sl@0
   306
  count {
sl@0
   307
    SELECT * FROM t1 WHERE 11=rowid
sl@0
   308
  }
sl@0
   309
} {11 hello world 0}
sl@0
   310
do_test intpkey-4.2 {
sl@0
   311
  count {
sl@0
   312
    SELECT * FROM t1 WHERE 11=rowid AND b=='hello'
sl@0
   313
  }
sl@0
   314
} {11 hello world 0}
sl@0
   315
do_test intpkey-4.3 {
sl@0
   316
  count {
sl@0
   317
    SELECT * FROM t1 WHERE 11=rowid AND b=='hello' AND c IS NOT NULL;
sl@0
   318
  }
sl@0
   319
} {11 hello world 0}
sl@0
   320
do_test intpkey-4.4 {
sl@0
   321
  count {
sl@0
   322
    SELECT * FROM t1 WHERE rowid==11
sl@0
   323
  }
sl@0
   324
} {11 hello world 0}
sl@0
   325
do_test intpkey-4.5 {
sl@0
   326
  count {
sl@0
   327
    SELECT * FROM t1 WHERE oid==11 AND b=='hello'
sl@0
   328
  }
sl@0
   329
} {11 hello world 0}
sl@0
   330
do_test intpkey-4.6 {
sl@0
   331
  count {
sl@0
   332
    SELECT * FROM t1 WHERE a==11 AND b=='hello' AND c IS NOT NULL;
sl@0
   333
  }
sl@0
   334
} {11 hello world 0}
sl@0
   335
sl@0
   336
do_test intpkey-4.7 {
sl@0
   337
  count {
sl@0
   338
    SELECT * FROM t1 WHERE 8<rowid;
sl@0
   339
  }
sl@0
   340
} {11 hello world 1}
sl@0
   341
do_test intpkey-4.8 {
sl@0
   342
  count {
sl@0
   343
    SELECT * FROM t1 WHERE 8<rowid AND 11>=oid;
sl@0
   344
  }
sl@0
   345
} {11 hello world 1}
sl@0
   346
do_test intpkey-4.9 {
sl@0
   347
  count {
sl@0
   348
    SELECT * FROM t1 WHERE 11<=_rowid_ AND 12>=a;
sl@0
   349
  }
sl@0
   350
} {11 hello world 1}
sl@0
   351
do_test intpkey-4.10 {
sl@0
   352
  count {
sl@0
   353
    SELECT * FROM t1 WHERE 0>=_rowid_;
sl@0
   354
  }
sl@0
   355
} {-4 y z 1}
sl@0
   356
do_test intpkey-4.11 {
sl@0
   357
  count {
sl@0
   358
    SELECT * FROM t1 WHERE a<0;
sl@0
   359
  }
sl@0
   360
} {-4 y z 1}
sl@0
   361
do_test intpkey-4.12 {
sl@0
   362
  count {
sl@0
   363
    SELECT * FROM t1 WHERE a<0 AND a>10;
sl@0
   364
  }
sl@0
   365
} {1}
sl@0
   366
sl@0
   367
# Make sure it is OK to insert a rowid of 0
sl@0
   368
#
sl@0
   369
do_test intpkey-5.1 {
sl@0
   370
  execsql {
sl@0
   371
    INSERT INTO t1 VALUES(0,'zero','entry');
sl@0
   372
  }
sl@0
   373
  count {
sl@0
   374
    SELECT * FROM t1 WHERE a=0;
sl@0
   375
  }
sl@0
   376
} {0 zero entry 0}
sl@0
   377
do_test intpkey-5.2 {
sl@0
   378
  execsql {
sl@0
   379
    SELECT rowid, a FROM t1
sl@0
   380
  }
sl@0
   381
} {-4 -4 0 0 5 5 6 6 11 11}
sl@0
   382
sl@0
   383
# Test the ability of the COPY command to put data into a
sl@0
   384
# table that contains an integer primary key.
sl@0
   385
#
sl@0
   386
# COPY command has been removed.  But we retain these tests so
sl@0
   387
# that the tables will contain the right data for tests that follow.
sl@0
   388
#
sl@0
   389
do_test intpkey-6.1 {
sl@0
   390
  execsql {
sl@0
   391
    BEGIN;
sl@0
   392
    INSERT INTO t1 VALUES(20,'b-20','c-20');
sl@0
   393
    INSERT INTO t1 VALUES(21,'b-21','c-21');
sl@0
   394
    INSERT INTO t1 VALUES(22,'b-22','c-22');
sl@0
   395
    COMMIT;
sl@0
   396
    SELECT * FROM t1 WHERE a>=20;
sl@0
   397
  }
sl@0
   398
} {20 b-20 c-20 21 b-21 c-21 22 b-22 c-22}
sl@0
   399
do_test intpkey-6.2 {
sl@0
   400
  execsql {
sl@0
   401
    SELECT * FROM t1 WHERE b=='hello'
sl@0
   402
  }
sl@0
   403
} {5 hello world 11 hello world}
sl@0
   404
do_test intpkey-6.3 {
sl@0
   405
  execsql {
sl@0
   406
    DELETE FROM t1 WHERE b='b-21';
sl@0
   407
    SELECT * FROM t1 WHERE b=='b-21';
sl@0
   408
  }
sl@0
   409
} {}
sl@0
   410
do_test intpkey-6.4 {
sl@0
   411
  execsql {
sl@0
   412
    SELECT * FROM t1 WHERE a>=20
sl@0
   413
  }
sl@0
   414
} {20 b-20 c-20 22 b-22 c-22}
sl@0
   415
sl@0
   416
# Do an insert of values with the columns specified out of order.
sl@0
   417
#
sl@0
   418
do_test intpkey-7.1 {
sl@0
   419
  execsql {
sl@0
   420
    INSERT INTO t1(c,b,a) VALUES('row','new',30);
sl@0
   421
    SELECT * FROM t1 WHERE rowid>=30;
sl@0
   422
  }
sl@0
   423
} {30 new row}
sl@0
   424
do_test intpkey-7.2 {
sl@0
   425
  execsql {
sl@0
   426
    SELECT * FROM t1 WHERE rowid>20;
sl@0
   427
  }
sl@0
   428
} {22 b-22 c-22 30 new row}
sl@0
   429
sl@0
   430
# Do an insert from a select statement.
sl@0
   431
#
sl@0
   432
do_test intpkey-8.1 {
sl@0
   433
  execsql {
sl@0
   434
    CREATE TABLE t2(x INTEGER PRIMARY KEY, y, z);
sl@0
   435
    INSERT INTO t2 SELECT * FROM t1;
sl@0
   436
    SELECT rowid FROM t2;
sl@0
   437
  }
sl@0
   438
} {-4 0 5 6 11 20 22 30}
sl@0
   439
do_test intpkey-8.2 {
sl@0
   440
  execsql {
sl@0
   441
    SELECT x FROM t2;
sl@0
   442
  }
sl@0
   443
} {-4 0 5 6 11 20 22 30}
sl@0
   444
sl@0
   445
do_test intpkey-9.1 {
sl@0
   446
  execsql {
sl@0
   447
    UPDATE t1 SET c='www' WHERE c='world';
sl@0
   448
    SELECT rowid, a, c FROM t1 WHERE c=='www';
sl@0
   449
  }
sl@0
   450
} {5 5 www 11 11 www}
sl@0
   451
sl@0
   452
sl@0
   453
# Check insert of NULL for primary key
sl@0
   454
#
sl@0
   455
do_test intpkey-10.1 {
sl@0
   456
  execsql {
sl@0
   457
    DROP TABLE t2;
sl@0
   458
    CREATE TABLE t2(x INTEGER PRIMARY KEY, y, z);
sl@0
   459
    INSERT INTO t2 VALUES(NULL, 1, 2);
sl@0
   460
    SELECT * from t2;
sl@0
   461
  }
sl@0
   462
} {1 1 2}
sl@0
   463
do_test intpkey-10.2 {
sl@0
   464
  execsql {
sl@0
   465
    INSERT INTO t2 VALUES(NULL, 2, 3);
sl@0
   466
    SELECT * from t2 WHERE x=2;
sl@0
   467
  }
sl@0
   468
} {2 2 3}
sl@0
   469
do_test intpkey-10.3 {
sl@0
   470
  execsql {
sl@0
   471
    INSERT INTO t2 SELECT NULL, z, y FROM t2;
sl@0
   472
    SELECT * FROM t2;
sl@0
   473
  }
sl@0
   474
} {1 1 2 2 2 3 3 2 1 4 3 2}
sl@0
   475
sl@0
   476
# This tests checks to see if a floating point number can be used
sl@0
   477
# to reference an integer primary key.
sl@0
   478
#
sl@0
   479
do_test intpkey-11.1 {
sl@0
   480
  execsql {
sl@0
   481
    SELECT b FROM t1 WHERE a=2.0+3.0;
sl@0
   482
  }
sl@0
   483
} {hello}
sl@0
   484
do_test intpkey-11.1 {
sl@0
   485
  execsql {
sl@0
   486
    SELECT b FROM t1 WHERE a=2.0+3.5;
sl@0
   487
  }
sl@0
   488
} {}
sl@0
   489
sl@0
   490
integrity_check intpkey-12.1
sl@0
   491
sl@0
   492
# Try to use a string that looks like a floating point number as
sl@0
   493
# an integer primary key.  This should actually work when the floating
sl@0
   494
# point value can be rounded to an integer without loss of data.
sl@0
   495
#
sl@0
   496
do_test intpkey-13.1 {
sl@0
   497
  execsql {
sl@0
   498
    SELECT * FROM t1 WHERE a=1;
sl@0
   499
  }
sl@0
   500
} {}
sl@0
   501
do_test intpkey-13.2 {
sl@0
   502
  execsql {
sl@0
   503
    INSERT INTO t1 VALUES('1.0',2,3);
sl@0
   504
    SELECT * FROM t1 WHERE a=1;
sl@0
   505
  }
sl@0
   506
} {1 2 3}
sl@0
   507
do_test intpkey-13.3 {
sl@0
   508
  catchsql {
sl@0
   509
    INSERT INTO t1 VALUES('1.5',3,4);
sl@0
   510
  }
sl@0
   511
} {1 {datatype mismatch}}
sl@0
   512
ifcapable {bloblit} {
sl@0
   513
  do_test intpkey-13.4 {
sl@0
   514
    catchsql {
sl@0
   515
      INSERT INTO t1 VALUES(x'123456',3,4);
sl@0
   516
    }
sl@0
   517
  } {1 {datatype mismatch}}
sl@0
   518
}
sl@0
   519
do_test intpkey-13.5 {
sl@0
   520
  catchsql {
sl@0
   521
    INSERT INTO t1 VALUES('+1234567890',3,4);
sl@0
   522
  }
sl@0
   523
} {0 {}}
sl@0
   524
sl@0
   525
# Compare an INTEGER PRIMARY KEY against a TEXT expression. The INTEGER
sl@0
   526
# affinity should be applied to the text value before the comparison
sl@0
   527
# takes place.
sl@0
   528
#
sl@0
   529
do_test intpkey-14.1 {
sl@0
   530
  execsql {
sl@0
   531
    CREATE TABLE t3(a INTEGER PRIMARY KEY, b INTEGER, c TEXT);
sl@0
   532
    INSERT INTO t3 VALUES(1, 1, 'one');
sl@0
   533
    INSERT INTO t3 VALUES(2, 2, '2');
sl@0
   534
    INSERT INTO t3 VALUES(3, 3, 3);
sl@0
   535
  }
sl@0
   536
} {}
sl@0
   537
do_test intpkey-14.2 {
sl@0
   538
  execsql {
sl@0
   539
    SELECT * FROM t3 WHERE a>2;
sl@0
   540
  }
sl@0
   541
} {3 3 3}
sl@0
   542
do_test intpkey-14.3 {
sl@0
   543
  execsql {
sl@0
   544
    SELECT * FROM t3 WHERE a>'2';
sl@0
   545
  }
sl@0
   546
} {3 3 3}
sl@0
   547
do_test intpkey-14.4 {
sl@0
   548
  execsql {
sl@0
   549
    SELECT * FROM t3 WHERE a<'2';
sl@0
   550
  }
sl@0
   551
} {1 1 one}
sl@0
   552
do_test intpkey-14.5 {
sl@0
   553
  execsql {
sl@0
   554
    SELECT * FROM t3 WHERE a<c;
sl@0
   555
  }
sl@0
   556
} {1 1 one}
sl@0
   557
do_test intpkey-14.6 {
sl@0
   558
  execsql {
sl@0
   559
    SELECT * FROM t3 WHERE a=c;
sl@0
   560
  }
sl@0
   561
} {2 2 2 3 3 3}
sl@0
   562
sl@0
   563
# Check for proper handling of primary keys greater than 2^31.
sl@0
   564
# Ticket #1188
sl@0
   565
#
sl@0
   566
do_test intpkey-15.1 {
sl@0
   567
  execsql {
sl@0
   568
    INSERT INTO t1 VALUES(2147483647, 'big-1', 123);
sl@0
   569
    SELECT * FROM t1 WHERE a>2147483648;
sl@0
   570
  }
sl@0
   571
} {}
sl@0
   572
do_test intpkey-15.2 {
sl@0
   573
  execsql {
sl@0
   574
    INSERT INTO t1 VALUES(NULL, 'big-2', 234);
sl@0
   575
    SELECT b FROM t1 WHERE a>=2147483648;
sl@0
   576
  }
sl@0
   577
} {big-2}
sl@0
   578
do_test intpkey-15.3 {
sl@0
   579
  execsql {
sl@0
   580
    SELECT b FROM t1 WHERE a>2147483648;
sl@0
   581
  }
sl@0
   582
} {}
sl@0
   583
do_test intpkey-15.4 {
sl@0
   584
  execsql {
sl@0
   585
    SELECT b FROM t1 WHERE a>=2147483647;
sl@0
   586
  }
sl@0
   587
} {big-1 big-2}
sl@0
   588
do_test intpkey-15.5 {
sl@0
   589
  execsql {
sl@0
   590
    SELECT b FROM t1 WHERE a<2147483648;
sl@0
   591
  }
sl@0
   592
} {y zero 2 hello second hello b-20 b-22 new 3 big-1}
sl@0
   593
do_test intpkey-15.6 {
sl@0
   594
  execsql {
sl@0
   595
    SELECT b FROM t1 WHERE a<12345678901;
sl@0
   596
  }
sl@0
   597
} {y zero 2 hello second hello b-20 b-22 new 3 big-1 big-2}
sl@0
   598
do_test intpkey-15.7 {
sl@0
   599
  execsql {
sl@0
   600
    SELECT b FROM t1 WHERE a>12345678901;
sl@0
   601
  }
sl@0
   602
} {}
sl@0
   603
sl@0
   604
sl@0
   605
finish_test