1 /* 2 ** 2005 February 15 3 ** 4 ** The author disclaims copyright to this source code. In place of 5 ** a legal notice, here is a blessing: 6 ** 7 ** May you do good and not evil. 8 ** May you find forgiveness for yourself and forgive others. 9 ** May you share freely, never taking more than you give. 10 ** 11 ************************************************************************* 12 ** This file contains C code routines that used to generate VDBE code 13 ** that implements the ALTER TABLE command. 14 ** 15 ** $Id: alter.c,v 1.43 2008/03/19 21:45:51 drh Exp $ 16 */ 17 #include "sqliteInt.h" 18 #include <ctype.h> 19 20 /* 21 ** The code in this file only exists if we are not omitting the 22 ** ALTER TABLE logic from the build. 23 */ 24 #ifndef SQLITE_OMIT_ALTERTABLE 25 26 27 /* 28 ** This function is used by SQL generated to implement the 29 ** ALTER TABLE command. The first argument is the text of a CREATE TABLE or 30 ** CREATE INDEX command. The second is a table name. The table name in 31 ** the CREATE TABLE or CREATE INDEX statement is replaced with the third 32 ** argument and the result returned. Examples: 33 ** 34 ** sqlite_rename_table('CREATE TABLE abc(a, b, c)', 'def') 35 ** -> 'CREATE TABLE def(a, b, c)' 36 ** 37 ** sqlite_rename_table('CREATE INDEX i ON abc(a)', 'def') 38 ** -> 'CREATE INDEX i ON def(a, b, c)' 39 */ 40 static void renameTableFunc( 41 sqlite3_context *context, 42 int argc, 43 sqlite3_value **argv 44 ){ 45 unsigned char const *zSql = sqlite3_value_text(argv[0]); 46 unsigned char const *zTableName = sqlite3_value_text(argv[1]); 47 48 int token; 49 Token tname; 50 unsigned char const *zCsr = zSql; 51 int len = 0; 52 char *zRet; 53 54 sqlite3 *db = sqlite3_context_db_handle(context); 55 56 /* The principle used to locate the table name in the CREATE TABLE 57 ** statement is that the table name is the first token that is immediatedly 58 ** followed by a left parenthesis - TK_LP - or "USING" TK_USING. 59 */ 60 if( zSql ){ 61 do { 62 if( !*zCsr ){ 63 /* Ran out of input before finding an opening bracket. Return NULL. */ 64 return; 65 } 66 67 /* Store the token that zCsr points to in tname. */ 68 tname.z = zCsr; 69 tname.n = len; 70 71 /* Advance zCsr to the next token. Store that token type in 'token', 72 ** and its length in 'len' (to be used next iteration of this loop). 73 */ 74 do { 75 zCsr += len; 76 len = sqlite3GetToken(zCsr, &token); 77 } while( token==TK_SPACE ); 78 assert( len>0 ); 79 } while( token!=TK_LP && token!=TK_USING ); 80 81 zRet = sqlite3MPrintf(db, "%.*s\"%w\"%s", tname.z - zSql, zSql, 82 zTableName, tname.z+tname.n); 83 sqlite3_result_text(context, zRet, -1, sqlite3_free); 84 } 85 } 86 87 #ifndef SQLITE_OMIT_TRIGGER 88 /* This function is used by SQL generated to implement the 89 ** ALTER TABLE command. The first argument is the text of a CREATE TRIGGER 90 ** statement. The second is a table name. The table name in the CREATE 91 ** TRIGGER statement is replaced with the third argument and the result 92 ** returned. This is analagous to renameTableFunc() above, except for CREATE 93 ** TRIGGER, not CREATE INDEX and CREATE TABLE. 94 */ 95 static void renameTriggerFunc( 96 sqlite3_context *context, 97 int argc, 98 sqlite3_value **argv 99 ){ 100 unsigned char const *zSql = sqlite3_value_text(argv[0]); 101 unsigned char const *zTableName = sqlite3_value_text(argv[1]); 102 103 int token; 104 Token tname; 105 int dist = 3; 106 unsigned char const *zCsr = zSql; 107 int len = 0; 108 char *zRet; 109 110 sqlite3 *db = sqlite3_context_db_handle(context); 111 112 /* The principle used to locate the table name in the CREATE TRIGGER 113 ** statement is that the table name is the first token that is immediatedly 114 ** preceded by either TK_ON or TK_DOT and immediatedly followed by one 115 ** of TK_WHEN, TK_BEGIN or TK_FOR. 116 */ 117 if( zSql ){ 118 do { 119 120 if( !*zCsr ){ 121 /* Ran out of input before finding the table name. Return NULL. */ 122 return; 123 } 124 125 /* Store the token that zCsr points to in tname. */ 126 tname.z = zCsr; 127 tname.n = len; 128 129 /* Advance zCsr to the next token. Store that token type in 'token', 130 ** and its length in 'len' (to be used next iteration of this loop). 131 */ 132 do { 133 zCsr += len; 134 len = sqlite3GetToken(zCsr, &token); 135 }while( token==TK_SPACE ); 136 assert( len>0 ); 137 138 /* Variable 'dist' stores the number of tokens read since the most 139 ** recent TK_DOT or TK_ON. This means that when a WHEN, FOR or BEGIN 140 ** token is read and 'dist' equals 2, the condition stated above 141 ** to be met. 142 ** 143 ** Note that ON cannot be a database, table or column name, so 144 ** there is no need to worry about syntax like 145 ** "CREATE TRIGGER ... ON ON.ON BEGIN ..." etc. 146 */ 147 dist++; 148 if( token==TK_DOT || token==TK_ON ){ 149 dist = 0; 150 } 151 } while( dist!=2 || (token!=TK_WHEN && token!=TK_FOR && token!=TK_BEGIN) ); 152 153 /* Variable tname now contains the token that is the old table-name 154 ** in the CREATE TRIGGER statement. 155 */ 156 zRet = sqlite3MPrintf(db, "%.*s\"%w\"%s", tname.z - zSql, zSql, 157 zTableName, tname.z+tname.n); 158 sqlite3_result_text(context, zRet, -1, sqlite3_free); 159 } 160 } 161 #endif /* !SQLITE_OMIT_TRIGGER */ 162 163 /* 164 ** Register built-in functions used to help implement ALTER TABLE 165 */ 166 void sqlite3AlterFunctions(sqlite3 *db){ 167 static const struct { 168 char *zName; 169 signed char nArg; 170 void (*xFunc)(sqlite3_context*,int,sqlite3_value **); 171 } aFuncs[] = { 172 { "sqlite_rename_table", 2, renameTableFunc}, 173 #ifndef SQLITE_OMIT_TRIGGER 174 { "sqlite_rename_trigger", 2, renameTriggerFunc}, 175 #endif 176 }; 177 int i; 178 179 for(i=0; i<sizeof(aFuncs)/sizeof(aFuncs[0]); i++){ 180 sqlite3CreateFunc(db, aFuncs[i].zName, aFuncs[i].nArg, 181 SQLITE_UTF8, 0, aFuncs[i].xFunc, 0, 0); 182 } 183 } 184 185 /* 186 ** Generate the text of a WHERE expression which can be used to select all 187 ** temporary triggers on table pTab from the sqlite_temp_master table. If 188 ** table pTab has no temporary triggers, or is itself stored in the 189 ** temporary database, NULL is returned. 190 */ 191 static char *whereTempTriggers(Parse *pParse, Table *pTab){ 192 Trigger *pTrig; 193 char *zWhere = 0; 194 char *tmp = 0; 195 const Schema *pTempSchema = pParse->db->aDb[1].pSchema; /* Temp db schema */ 196 197 /* If the table is not located in the temp-db (in which case NULL is 198 ** returned, loop through the tables list of triggers. For each trigger 199 ** that is not part of the temp-db schema, add a clause to the WHERE 200 ** expression being built up in zWhere. 201 */ 202 if( pTab->pSchema!=pTempSchema ){ 203 sqlite3 *db = pParse->db; 204 for( pTrig=pTab->pTrigger; pTrig; pTrig=pTrig->pNext ){ 205 if( pTrig->pSchema==pTempSchema ){ 206 if( !zWhere ){ 207 zWhere = sqlite3MPrintf(db, "name=%Q", pTrig->name); 208 }else{ 209 tmp = zWhere; 210 zWhere = sqlite3MPrintf(db, "%s OR name=%Q", zWhere, pTrig->name); 211 sqlite3_free(tmp); 212 } 213 } 214 } 215 } 216 return zWhere; 217 } 218 219 /* 220 ** Generate code to drop and reload the internal representation of table 221 ** pTab from the database, including triggers and temporary triggers. 222 ** Argument zName is the name of the table in the database schema at 223 ** the time the generated code is executed. This can be different from 224 ** pTab->zName if this function is being called to code part of an 225 ** "ALTER TABLE RENAME TO" statement. 226 */ 227 static void reloadTableSchema(Parse *pParse, Table *pTab, const char *zName){ 228 Vdbe *v; 229 char *zWhere; 230 int iDb; /* Index of database containing pTab */ 231 #ifndef SQLITE_OMIT_TRIGGER 232 Trigger *pTrig; 233 #endif 234 235 v = sqlite3GetVdbe(pParse); 236 if( !v ) return; 237 assert( sqlite3BtreeHoldsAllMutexes(pParse->db) ); 238 iDb = sqlite3SchemaToIndex(pParse->db, pTab->pSchema); 239 assert( iDb>=0 ); 240 241 #ifndef SQLITE_OMIT_TRIGGER 242 /* Drop any table triggers from the internal schema. */ 243 for(pTrig=pTab->pTrigger; pTrig; pTrig=pTrig->pNext){ 244 int iTrigDb = sqlite3SchemaToIndex(pParse->db, pTrig->pSchema); 245 assert( iTrigDb==iDb || iTrigDb==1 ); 246 sqlite3VdbeAddOp4(v, OP_DropTrigger, iTrigDb, 0, 0, pTrig->name, 0); 247 } 248 #endif 249 250 /* Drop the table and index from the internal schema */ 251 sqlite3VdbeAddOp4(v, OP_DropTable, iDb, 0, 0, pTab->zName, 0); 252 253 /* Reload the table, index and permanent trigger schemas. */ 254 zWhere = sqlite3MPrintf(pParse->db, "tbl_name=%Q", zName); 255 if( !zWhere ) return; 256 sqlite3VdbeAddOp4(v, OP_ParseSchema, iDb, 0, 0, zWhere, P4_DYNAMIC); 257 258 #ifndef SQLITE_OMIT_TRIGGER 259 /* Now, if the table is not stored in the temp database, reload any temp 260 ** triggers. Don't use IN(...) in case SQLITE_OMIT_SUBQUERY is defined. 261 */ 262 if( (zWhere=whereTempTriggers(pParse, pTab))!=0 ){ 263 sqlite3VdbeAddOp4(v, OP_ParseSchema, 1, 0, 0, zWhere, P4_DYNAMIC); 264 } 265 #endif 266 } 267 268 /* 269 ** Generate code to implement the "ALTER TABLE xxx RENAME TO yyy" 270 ** command. 271 */ 272 void sqlite3AlterRenameTable( 273 Parse *pParse, /* Parser context. */ 274 SrcList *pSrc, /* The table to rename. */ 275 Token *pName /* The new table name. */ 276 ){ 277 int iDb; /* Database that contains the table */ 278 char *zDb; /* Name of database iDb */ 279 Table *pTab; /* Table being renamed */ 280 char *zName = 0; /* NULL-terminated version of pName */ 281 sqlite3 *db = pParse->db; /* Database connection */ 282 int nTabName; /* Number of UTF-8 characters in zTabName */ 283 const char *zTabName; /* Original name of the table */ 284 Vdbe *v; 285 #ifndef SQLITE_OMIT_TRIGGER 286 char *zWhere = 0; /* Where clause to locate temp triggers */ 287 #endif 288 int isVirtualRename = 0; /* True if this is a v-table with an xRename() */ 289 290 if( db->mallocFailed ) goto exit_rename_table; 291 assert( pSrc->nSrc==1 ); 292 assert( sqlite3BtreeHoldsAllMutexes(pParse->db) ); 293 294 pTab = sqlite3LocateTable(pParse, 0, pSrc->a[0].zName, pSrc->a[0].zDatabase); 295 if( !pTab ) goto exit_rename_table; 296 iDb = sqlite3SchemaToIndex(pParse->db, pTab->pSchema); 297 zDb = db->aDb[iDb].zName; 298 299 /* Get a NULL terminated version of the new table name. */ 300 zName = sqlite3NameFromToken(db, pName); 301 if( !zName ) goto exit_rename_table; 302 303 /* Check that a table or index named 'zName' does not already exist 304 ** in database iDb. If so, this is an error. 305 */ 306 if( sqlite3FindTable(db, zName, zDb) || sqlite3FindIndex(db, zName, zDb) ){ 307 sqlite3ErrorMsg(pParse, 308 "there is already another table or index with this name: %s", zName); 309 goto exit_rename_table; 310 } 311 312 /* Make sure it is not a system table being altered, or a reserved name 313 ** that the table is being renamed to. 314 */ 315 if( strlen(pTab->zName)>6 && 0==sqlite3StrNICmp(pTab->zName, "sqlite_", 7) ){ 316 sqlite3ErrorMsg(pParse, "table %s may not be altered", pTab->zName); 317 goto exit_rename_table; 318 } 319 if( SQLITE_OK!=sqlite3CheckObjectName(pParse, zName) ){ 320 goto exit_rename_table; 321 } 322 323 #ifndef SQLITE_OMIT_VIEW 324 if( pTab->pSelect ){ 325 sqlite3ErrorMsg(pParse, "view %s may not be altered", pTab->zName); 326 goto exit_rename_table; 327 } 328 #endif 329 330 #ifndef SQLITE_OMIT_AUTHORIZATION 331 /* Invoke the authorization callback. */ 332 if( sqlite3AuthCheck(pParse, SQLITE_ALTER_TABLE, zDb, pTab->zName, 0) ){ 333 goto exit_rename_table; 334 } 335 #endif 336 337 #ifndef SQLITE_OMIT_VIRTUALTABLE 338 if( sqlite3ViewGetColumnNames(pParse, pTab) ){ 339 goto exit_rename_table; 340 } 341 if( IsVirtual(pTab) && pTab->pMod->pModule->xRename ){ 342 isVirtualRename = 1; 343 } 344 #endif 345 346 /* Begin a transaction and code the VerifyCookie for database iDb. 347 ** Then modify the schema cookie (since the ALTER TABLE modifies the 348 ** schema). Open a statement transaction if the table is a virtual 349 ** table. 350 */ 351 v = sqlite3GetVdbe(pParse); 352 if( v==0 ){ 353 goto exit_rename_table; 354 } 355 sqlite3BeginWriteOperation(pParse, isVirtualRename, iDb); 356 sqlite3ChangeCookie(pParse, iDb); 357 358 /* If this is a virtual table, invoke the xRename() function if 359 ** one is defined. The xRename() callback will modify the names 360 ** of any resources used by the v-table implementation (including other 361 ** SQLite tables) that are identified by the name of the virtual table. 362 */ 363 #ifndef SQLITE_OMIT_VIRTUALTABLE 364 if( isVirtualRename ){ 365 int i = ++pParse->nMem; 366 sqlite3VdbeAddOp4(v, OP_String8, 0, i, 0, zName, 0); 367 sqlite3VdbeAddOp4(v, OP_VRename, i, 0, 0,(const char*)pTab->pVtab, P4_VTAB); 368 } 369 #endif 370 371 /* figure out how many UTF-8 characters are in zName */ 372 zTabName = pTab->zName; 373 nTabName = sqlite3Utf8CharLen(zTabName, -1); 374 375 /* Modify the sqlite_master table to use the new table name. */ 376 sqlite3NestedParse(pParse, 377 "UPDATE %Q.%s SET " 378 #ifdef SQLITE_OMIT_TRIGGER 379 "sql = sqlite_rename_table(sql, %Q), " 380 #else 381 "sql = CASE " 382 "WHEN type = 'trigger' THEN sqlite_rename_trigger(sql, %Q)" 383 "ELSE sqlite_rename_table(sql, %Q) END, " 384 #endif 385 "tbl_name = %Q, " 386 "name = CASE " 387 "WHEN type='table' THEN %Q " 388 "WHEN name LIKE 'sqlite_autoindex%%' AND type='index' THEN " 389 "'sqlite_autoindex_' || %Q || substr(name,%d+18) " 390 "ELSE name END " 391 "WHERE tbl_name=%Q AND " 392 "(type='table' OR type='index' OR type='trigger');", 393 zDb, SCHEMA_TABLE(iDb), zName, zName, zName, 394 #ifndef SQLITE_OMIT_TRIGGER 395 zName, 396 #endif 397 zName, nTabName, zTabName 398 ); 399 400 #ifndef SQLITE_OMIT_AUTOINCREMENT 401 /* If the sqlite_sequence table exists in this database, then update 402 ** it with the new table name. 403 */ 404 if( sqlite3FindTable(db, "sqlite_sequence", zDb) ){ 405 sqlite3NestedParse(pParse, 406 "UPDATE \"%w\".sqlite_sequence set name = %Q WHERE name = %Q", 407 zDb, zName, pTab->zName); 408 } 409 #endif 410 411 #ifndef SQLITE_OMIT_TRIGGER 412 /* If there are TEMP triggers on this table, modify the sqlite_temp_master 413 ** table. Don't do this if the table being ALTERed is itself located in 414 ** the temp database. 415 */ 416 if( (zWhere=whereTempTriggers(pParse, pTab))!=0 ){ 417 sqlite3NestedParse(pParse, 418 "UPDATE sqlite_temp_master SET " 419 "sql = sqlite_rename_trigger(sql, %Q), " 420 "tbl_name = %Q " 421 "WHERE %s;", zName, zName, zWhere); 422 sqlite3_free(zWhere); 423 } 424 #endif 425 426 /* Drop and reload the internal table schema. */ 427 reloadTableSchema(pParse, pTab, zName); 428 429 exit_rename_table: 430 sqlite3SrcListDelete(pSrc); 431 sqlite3_free(zName); 432 } 433 434 435 /* 436 ** This function is called after an "ALTER TABLE ... ADD" statement 437 ** has been parsed. Argument pColDef contains the text of the new 438 ** column definition. 439 ** 440 ** The Table structure pParse->pNewTable was extended to include 441 ** the new column during parsing. 442 */ 443 void sqlite3AlterFinishAddColumn(Parse *pParse, Token *pColDef){ 444 Table *pNew; /* Copy of pParse->pNewTable */ 445 Table *pTab; /* Table being altered */ 446 int iDb; /* Database number */ 447 const char *zDb; /* Database name */ 448 const char *zTab; /* Table name */ 449 char *zCol; /* Null-terminated column definition */ 450 Column *pCol; /* The new column */ 451 Expr *pDflt; /* Default value for the new column */ 452 sqlite3 *db; /* The database connection; */ 453 454 if( pParse->nErr ) return; 455 pNew = pParse->pNewTable; 456 assert( pNew ); 457 458 db = pParse->db; 459 assert( sqlite3BtreeHoldsAllMutexes(db) ); 460 iDb = sqlite3SchemaToIndex(db, pNew->pSchema); 461 zDb = db->aDb[iDb].zName; 462 zTab = pNew->zName; 463 pCol = &pNew->aCol[pNew->nCol-1]; 464 pDflt = pCol->pDflt; 465 pTab = sqlite3FindTable(db, zTab, zDb); 466 assert( pTab ); 467 468 #ifndef SQLITE_OMIT_AUTHORIZATION 469 /* Invoke the authorization callback. */ 470 if( sqlite3AuthCheck(pParse, SQLITE_ALTER_TABLE, zDb, pTab->zName, 0) ){ 471 return; 472 } 473 #endif 474 475 /* If the default value for the new column was specified with a 476 ** literal NULL, then set pDflt to 0. This simplifies checking 477 ** for an SQL NULL default below. 478 */ 479 if( pDflt && pDflt->op==TK_NULL ){ 480 pDflt = 0; 481 } 482 483 /* Check that the new column is not specified as PRIMARY KEY or UNIQUE. 484 ** If there is a NOT NULL constraint, then the default value for the 485 ** column must not be NULL. 486 */ 487 if( pCol->isPrimKey ){ 488 sqlite3ErrorMsg(pParse, "Cannot add a PRIMARY KEY column"); 489 return; 490 } 491 if( pNew->pIndex ){ 492 sqlite3ErrorMsg(pParse, "Cannot add a UNIQUE column"); 493 return; 494 } 495 if( pCol->notNull && !pDflt ){ 496 sqlite3ErrorMsg(pParse, 497 "Cannot add a NOT NULL column with default value NULL"); 498 return; 499 } 500 501 /* Ensure the default expression is something that sqlite3ValueFromExpr() 502 ** can handle (i.e. not CURRENT_TIME etc.) 503 */ 504 if( pDflt ){ 505 sqlite3_value *pVal; 506 if( sqlite3ValueFromExpr(db, pDflt, SQLITE_UTF8, SQLITE_AFF_NONE, &pVal) ){ 507 db->mallocFailed = 1; 508 return; 509 } 510 if( !pVal ){ 511 sqlite3ErrorMsg(pParse, "Cannot add a column with non-constant default"); 512 return; 513 } 514 sqlite3ValueFree(pVal); 515 } 516 517 /* Modify the CREATE TABLE statement. */ 518 zCol = sqlite3DbStrNDup(db, (char*)pColDef->z, pColDef->n); 519 if( zCol ){ 520 char *zEnd = &zCol[pColDef->n-1]; 521 while( (zEnd>zCol && *zEnd==';') || isspace(*(unsigned char *)zEnd) ){ 522 *zEnd-- = '\0'; 523 } 524 sqlite3NestedParse(pParse, 525 "UPDATE \"%w\".%s SET " 526 "sql = substr(sql,1,%d) || ', ' || %Q || substr(sql,%d) " 527 "WHERE type = 'table' AND name = %Q", 528 zDb, SCHEMA_TABLE(iDb), pNew->addColOffset, zCol, pNew->addColOffset+1, 529 zTab 530 ); 531 sqlite3_free(zCol); 532 } 533 534 /* If the default value of the new column is NULL, then set the file 535 ** format to 2. If the default value of the new column is not NULL, 536 ** the file format becomes 3. 537 */ 538 sqlite3MinimumFileFormat(pParse, iDb, pDflt ? 3 : 2); 539 540 /* Reload the schema of the modified table. */ 541 reloadTableSchema(pParse, pTab, pTab->zName); 542 } 543 544 /* 545 ** This function is called by the parser after the table-name in 546 ** an "ALTER TABLE <table-name> ADD" statement is parsed. Argument 547 ** pSrc is the full-name of the table being altered. 548 ** 549 ** This routine makes a (partial) copy of the Table structure 550 ** for the table being altered and sets Parse.pNewTable to point 551 ** to it. Routines called by the parser as the column definition 552 ** is parsed (i.e. sqlite3AddColumn()) add the new Column data to 553 ** the copy. The copy of the Table structure is deleted by tokenize.c 554 ** after parsing is finished. 555 ** 556 ** Routine sqlite3AlterFinishAddColumn() will be called to complete 557 ** coding the "ALTER TABLE ... ADD" statement. 558 */ 559 void sqlite3AlterBeginAddColumn(Parse *pParse, SrcList *pSrc){ 560 Table *pNew; 561 Table *pTab; 562 Vdbe *v; 563 int iDb; 564 int i; 565 int nAlloc; 566 sqlite3 *db = pParse->db; 567 568 /* Look up the table being altered. */ 569 assert( pParse->pNewTable==0 ); 570 assert( sqlite3BtreeHoldsAllMutexes(db) ); 571 if( db->mallocFailed ) goto exit_begin_add_column; 572 pTab = sqlite3LocateTable(pParse, 0, pSrc->a[0].zName, pSrc->a[0].zDatabase); 573 if( !pTab ) goto exit_begin_add_column; 574 575 #ifndef SQLITE_OMIT_VIRTUALTABLE 576 if( IsVirtual(pTab) ){ 577 sqlite3ErrorMsg(pParse, "virtual tables may not be altered"); 578 goto exit_begin_add_column; 579 } 580 #endif 581 582 /* Make sure this is not an attempt to ALTER a view. */ 583 if( pTab->pSelect ){ 584 sqlite3ErrorMsg(pParse, "Cannot add a column to a view"); 585 goto exit_begin_add_column; 586 } 587 588 assert( pTab->addColOffset>0 ); 589 iDb = sqlite3SchemaToIndex(db, pTab->pSchema); 590 591 /* Put a copy of the Table struct in Parse.pNewTable for the 592 ** sqlite3AddColumn() function and friends to modify. 593 */ 594 pNew = (Table*)sqlite3DbMallocZero(db, sizeof(Table)); 595 if( !pNew ) goto exit_begin_add_column; 596 pParse->pNewTable = pNew; 597 pNew->nRef = 1; 598 pNew->nCol = pTab->nCol; 599 assert( pNew->nCol>0 ); 600 nAlloc = (((pNew->nCol-1)/8)*8)+8; 601 assert( nAlloc>=pNew->nCol && nAlloc%8==0 && nAlloc-pNew->nCol<8 ); 602 pNew->aCol = (Column*)sqlite3DbMallocZero(db, sizeof(Column)*nAlloc); 603 pNew->zName = sqlite3DbStrDup(db, pTab->zName); 604 if( !pNew->aCol || !pNew->zName ){ 605 db->mallocFailed = 1; 606 goto exit_begin_add_column; 607 } 608 memcpy(pNew->aCol, pTab->aCol, sizeof(Column)*pNew->nCol); 609 for(i=0; i<pNew->nCol; i++){ 610 Column *pCol = &pNew->aCol[i]; 611 pCol->zName = sqlite3DbStrDup(db, pCol->zName); 612 pCol->zColl = 0; 613 pCol->zType = 0; 614 pCol->pDflt = 0; 615 } 616 pNew->pSchema = db->aDb[iDb].pSchema; 617 pNew->addColOffset = pTab->addColOffset; 618 pNew->nRef = 1; 619 620 /* Begin a transaction and increment the schema cookie. */ 621 sqlite3BeginWriteOperation(pParse, 0, iDb); 622 v = sqlite3GetVdbe(pParse); 623 if( !v ) goto exit_begin_add_column; 624 sqlite3ChangeCookie(pParse, iDb); 625 626 exit_begin_add_column: 627 sqlite3SrcListDelete(pSrc); 628 return; 629 } 630 #endif /* SQLITE_ALTER_TABLE */ 631