Localization: Removing right and action messages for the 'restrict' feature, which...
[mediawiki.git] / maintenance / mssql / README
blobbcdeb82ad7487cf21ee08e1bd9db4332a646203f
1 == Syntax differences between MySQL and MSSQL ==
2 {| border cellspacing=0 cellpadding=4
3 !MySQL!!MSSQL
4 |-
6 |AUTO_INCREMENT
7 |IDENTITY(1,1)
8 |-
10 |binary
11 |varchar NULL ''(MSSQL doesn't allow setting of binary's to string values, and won't implicitly allow NULL's)''
14 |bool
15 |bit
18 |[UN]SIGNED
19 |''not valid''
22 |SELECT * FROM foo LIMIT x
23 |SELECT TOP x * FROM foo
26 |SELECT * FROM foo LIMIT x,y|
27 ''not sure how to implement yet because it must be applied from within '''DatabaseMssql::limitResult'''''
30 |INSERT IGNORE INTO foo (foo_id,bar) VALUES ('1','xyz')
31 |IF NOT EXISTS (SELECT * FROM foo WHERE foo_id = '1') INSERT INTO foo (foo_id,bar) VALUES ('1','xyz')
34 |IF(cond,trueVal,falseVal)
35 |CASE WHEN cond THEN trueVal ELSE falseVal END
38 |SHOW TABLES
39 |SELECT * FROM INFORMATION_SCHEMA.TABLES
42 |ENUM
43 |''not natively supported, change to text''
46 == MSSQL Variables ==
47 {| border cellspacing=0 cellpadding=4
49 |@@VERSION
50 |Server version information
53 |@@IDENTITY
54 |Last inserted row
57 |@@ERROR
58 |Last error number
61 == Changes to INSERT wrapper ==
62 === AUTOINCREMENT vs IDENTITY ===
63 MySQL style ''AUTOINCREMENT'' columns are inplemented in MSSQL using ''IDENTITY(x,y)'' where ''x'' is the initial value and ''y'' is the amount to add on each insert. The last value resulting from an insert into an IDENTITY column is stored in the ''@@IDENTITY'' variable. These kinds of columns are usually used as primary keys and are therefore assigned the ''NOT NULL'' property.
65 In MySQL the standard way of inserting data into rows exhibiting AUTOINCREMENT columns is simply to use a ''NULL'' value which will be ignored. In MSSQL however assigning a ''NULL'' to an ''IDENTITY'' column is not allowed, instead the best way is not to include those items in the list of columns to be updated at all.
67 To get round this in the MediaWiki MSSQL layer, I've modified the insert wrapper in the ''DatabaseMssql'' class to check if the primary key is used in the insert and remove it if so. It checks this by assuming that the primary key will be of the same name as the table but with ''_id'' on the end, and that it will the first item in the list of columns to update.
69 === IGNORE ===
70 As you can see from the comparison table above, the MySQL ''INSERT IGNORE'' option takes quite a different form in MSSQL. This is handled in the ''insert'' wrapper method. In the case of multiple row inserts, a separate conditional insert query is performed for each item.
72 == NULL values and NOT NULL columns ==
73 MySQL implicitly casts NULL assignments to NOT NULL columns to an empty string or zero value accordingly, but MSSQL raises an error instead. This is a big problem within the MediaWiki environment because the code relies heavily on this implicit NULL casting. I've tried to get round the problem by replacing NULL's with empty strings from update and insert queries, and MSSQL is happy to cast the empty string to a numeric zero if necessary.
75 == See also ==
76 *[http://msdn.microsoft.com/en-us/library/ms188783.aspx MSSQL reference]
77 *[http://doc.ddart.net/mssql/sql70/ca-co_1.htm Type casting]
78 *[http://msdn.microsoft.com/en-us/library/ms187752.aspx TransactSQL datatypes]