Blame view

sources/3rdparty/doctrine/dbal/UPGRADE 5.24 KB
31b7f2792   Kload   Upgrade to ownclo...
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
  # Upgrade to 2.3
  
  ## Oracle Session Init now sets Numeric Character
  
  Before 2.3 the Oracle Session Init did not care about the numeric character of the Session.
  This could lead to problems on non english locale systems that required a comma as a floating
  point seperator in Oracle. Since 2.3, using the Oracle Session Init on connection start the
  client session will be altered to set the numeric character to ".,":
  
      ALTER SESSION SET NLS_NUMERIC_CHARACTERS = '.,'
  
  See [DBAL-345](http://www.doctrine-project.org/jira/browse/DBAL-345) for more details.
  
  ## Doctrine\DBAL\Connection and Doctrine\DBAL\Statement
  
  The query related methods including but not limited to executeQuery, exec, query, and executeUpdate
  now wrap the driver exceptions such as PDOException with DBALException to add more debugging
  information such as the executed SQL statement, and any bound parameters.
  
  If you want to retrieve the driver specific exception, you can retrieve it by calling the
  ``getPrevious()`` method on DBALException.
  
  Before:
  
      catch(\PDOException $ex) {
          // ...
      }
  
  After:
  
      catch(\Doctrine\DBAL\DBALException $ex) {
          $pdoException = $ex->getPrevious();
          // ...
      }
  
  ## Doctrine\DBAL\Connection#setCharsetSQL() removed
  
  This method only worked on MySQL and it is considered unsafe on MySQL to use SET NAMES UTF-8 instead
  of setting the charset directly on connection already. Replace this behavior with the
  connection charset option:
  
  Before:
  
      $conn = DriverManager::getConnection(array(..));
      $conn->setCharset('UTF8');
  
  After:
  
      $conn = DriverManager::getConnection(array('charset' => 'UTF8', ..));
  
  ## Doctrine\DBAL\Schema\Table#renameColumn() removed
  
  Doctrine\DBAL\Schema\Table#renameColumn() was removed, because it drops and recreates
  the column instead. There is no fix available, because a schema diff
  cannot reliably detect if a column was renamed or one column was created
  and another one dropped.
  
  You should use explicit SQL ALTER TABLE statements to change columns names.
  
  ## Schema Filter paths
  
  The Filter Schema assets expression is not wrapped in () anymore for the regexp automatically.
  
  Before:
  
      $config->setFilterSchemaAssetsExpression('foo');
  
  After:
  
      $config->setFilterSchemaAssetsExpression('(foo)');
  
  ## Creating MySQL Tables now defaults to UTF-8
  
  If you are creating a new MySQL Table through the Doctrine API, charset/collate are
  now set to 'utf8'/'utf8_unicode_ci' by default. Previously the MySQL server defaults were used.
  
  # Upgrade to 2.2
  
  ## Doctrine\DBAL\Connection#insert and Doctrine\DBAL\Connnection#update
  
  Both methods now accept an optional last parameter $types with binding types of the values passed.
  This can potentially break child classes that have overwritten one of these methods.
  
  ## Doctrine\DBAL\Connection#executeQuery
  
  Doctrine\DBAL\Connection#executeQuery() got a new last parameter "QueryCacheProfile $qcp"
  
  ## Doctrine\DBAL\Driver\Statement split
  
  The Driver statement was split into a ResultStatement and the normal statement extending from it.
  This seperates the configuration and the retrieval API from a statement.
  
  ## MsSql Platform/SchemaManager renamed
  
  The MsSqlPlatform was renamed to SQLServerPlatform, the MsSqlSchemaManager was renamed
  to SQLServerSchemaManager.
  
  ## Cleanup SQLServer Platform version mess
  
  DBAL 2.1 and before were actually only compatible to SQL Server 2008, not earlier versions.
  Still other parts of the platform did use old features instead of newly introduced datatypes
  in SQL Server 2005. Starting with DBAL 2.2 you can pick the Doctrine abstraction exactly
  matching your SQL Server version.
  
  The PDO SqlSrv driver now uses the new `SQLServer2008Platform` as default platform.
  This platform uses new features of SQL Server as of version 2008. This also includes a switch
  in the used fields for "text" and "blob" field types to:
  
      "text" => "VARCHAR(MAX)"
      "blob" => "VARBINARY(MAX)"
  
  Additionally `SQLServerPlatform` in DBAL 2.1 and before used "DATE", "TIME" and "DATETIME2" for dates.
  This types are only available since version 2008 and the introduction of an explicit
  SQLServer 2008 platform makes this dependency explicit.
  
  An `SQLServer2005Platform` was also introduced to differentiate the features between
  versions 2003, earlier and 2005.
  
  With this change the `SQLServerPlatform` now throws an exception for using limit queries
  with an offset, since SQLServer 2003 and lower do not support this feature.
  
  To use the old SQL Server Platform, because you are using SQL Server 2003 and below use
  the following configuration code:
  
      use Doctrine\DBAL\DriverManager;
      use Doctrine\DBAL\Platforms\SQLServerPlatform;
      use Doctrine\DBAL\Platforms\SQLServer2005Platform;
  
      // You are using SQL Server 2003 or earlier
      $conn = DriverManager::getConnection(array(
          'driver' => 'pdo_sqlsrv',
          'platform' => new SQLServerPlatform()
          // .. additional parameters
      ));
  
      // You are using SQL Server 2005
      $conn = DriverManager::getConnection(array(
          'driver' => 'pdo_sqlsrv',
          'platform' => new SQLServer2005Platform()
          // .. additional parameters
      ));
  
      // You are using SQL Server 2008
      $conn = DriverManager::getConnection(array(
          'driver' => 'pdo_sqlsrv',
          // 2008 is default platform
          // .. additional parameters
      ));