Page Menu
Home
Phorge
Search
Configure Global Search
Log In
Files
F120836463
mssql.initial.sql
No One
Temporary
Actions
View File
Edit File
Delete File
View Transforms
Subscribe
Flag For Later
Award Token
Authored By
Unknown
Size
12 KB
Referenced Files
None
Subscribers
None
mssql.initial.sql
View Options
CREATE
TABLE
[
dbo
].[
cache
]
(
[
user_id
]
[
int
]
NOT
NULL
,
[
cache_key
]
[
varchar
]
(
128
)
COLLATE
Latin1_General_CI_AI
NOT
NULL
,
[
created
]
[
datetime
]
NOT
NULL
,
[
data
]
[
text
]
COLLATE
Latin1_General_CI_AI
NOT
NULL
)
ON
[
PRIMARY
]
TEXTIMAGE_ON
[
PRIMARY
]
GO
CREATE
TABLE
[
dbo
].[
cache_index
]
(
[
user_id
]
[
int
]
NOT
NULL
,
[
mailbox
]
[
varchar
]
(
128
)
COLLATE
Latin1_General_CI_AI
NOT
NULL
,
[
changed
]
[
datetime
]
NOT
NULL
,
[
valid
]
[
char
]
(
1
)
COLLATE
Latin1_General_CI_AI
NOT
NULL
,
[
data
]
[
text
]
COLLATE
Latin1_General_CI_AI
NOT
NULL
)
ON
[
PRIMARY
]
TEXTIMAGE_ON
[
PRIMARY
]
GO
CREATE
TABLE
[
dbo
].[
cache_thread
]
(
[
user_id
]
[
int
]
NOT
NULL
,
[
mailbox
]
[
varchar
]
(
128
)
COLLATE
Latin1_General_CI_AI
NOT
NULL
,
[
changed
]
[
datetime
]
NOT
NULL
,
[
data
]
[
text
]
COLLATE
Latin1_General_CI_AI
NOT
NULL
)
ON
[
PRIMARY
]
TEXTIMAGE_ON
[
PRIMARY
]
GO
CREATE
TABLE
[
dbo
].[
cache_messages
]
(
[
user_id
]
[
int
]
NOT
NULL
,
[
mailbox
]
[
varchar
]
(
128
)
COLLATE
Latin1_General_CI_AI
NOT
NULL
,
[
uid
]
[
int
]
NOT
NULL
,
[
changed
]
[
datetime
]
NOT
NULL
,
[
data
]
[
text
]
COLLATE
Latin1_General_CI_AI
NOT
NULL
,
[
flags
]
[
int
]
NOT
NULL
)
ON
[
PRIMARY
]
TEXTIMAGE_ON
[
PRIMARY
]
GO
CREATE
TABLE
[
dbo
].[
contacts
]
(
[
contact_id
]
[
int
]
IDENTITY
(
1
,
1
)
NOT
NULL
,
[
user_id
]
[
int
]
NOT
NULL
,
[
changed
]
[
datetime
]
NOT
NULL
,
[
del
]
[
char
]
(
1
)
COLLATE
Latin1_General_CI_AI
NOT
NULL
,
[
name
]
[
varchar
]
(
128
)
COLLATE
Latin1_General_CI_AI
NOT
NULL
,
[
email
]
[
varchar
]
(
8000
)
COLLATE
Latin1_General_CI_AI
NOT
NULL
,
[
firstname
]
[
varchar
]
(
128
)
COLLATE
Latin1_General_CI_AI
NOT
NULL
,
[
surname
]
[
varchar
]
(
128
)
COLLATE
Latin1_General_CI_AI
NOT
NULL
,
[
vcard
]
[
text
]
COLLATE
Latin1_General_CI_AI
NULL
,
[
words
]
[
text
]
COLLATE
Latin1_General_CI_AI
NULL
)
ON
[
PRIMARY
]
TEXTIMAGE_ON
[
PRIMARY
]
GO
CREATE
TABLE
[
dbo
].[
contactgroups
]
(
[
contactgroup_id
]
[
int
]
IDENTITY
(
1
,
1
)
NOT
NULL
,
[
user_id
]
[
int
]
NOT
NULL
,
[
changed
]
[
datetime
]
NOT
NULL
,
[
del
]
[
char
]
(
1
)
COLLATE
Latin1_General_CI_AI
NOT
NULL
,
[
name
]
[
varchar
]
(
128
)
COLLATE
Latin1_General_CI_AI
NOT
NULL
)
ON
[
PRIMARY
]
GO
CREATE
TABLE
[
dbo
].[
contactgroupmembers
]
(
[
contactgroup_id
]
[
int
]
NOT
NULL
,
[
contact_id
]
[
int
]
NOT
NULL
,
[
created
]
[
datetime
]
NOT
NULL
)
ON
[
PRIMARY
]
GO
CREATE
TABLE
[
dbo
].[
identities
]
(
[
identity_id
]
[
int
]
IDENTITY
(
1
,
1
)
NOT
NULL
,
[
user_id
]
[
int
]
NOT
NULL
,
[
changed
]
[
datetime
]
NOT
NULL
,
[
del
]
[
char
]
(
1
)
COLLATE
Latin1_General_CI_AI
NOT
NULL
,
[
standard
]
[
char
]
(
1
)
COLLATE
Latin1_General_CI_AI
NOT
NULL
,
[
name
]
[
varchar
]
(
128
)
COLLATE
Latin1_General_CI_AI
NOT
NULL
,
[
organization
]
[
varchar
]
(
128
)
COLLATE
Latin1_General_CI_AI
NOT
NULL
,
[
email
]
[
varchar
]
(
128
)
COLLATE
Latin1_General_CI_AI
NOT
NULL
,
[
reply
-
to
]
[
varchar
]
(
128
)
COLLATE
Latin1_General_CI_AI
NOT
NULL
,
[
bcc
]
[
varchar
]
(
128
)
COLLATE
Latin1_General_CI_AI
NOT
NULL
,
[
signature
]
[
text
]
COLLATE
Latin1_General_CI_AI
NULL
,
[
html_signature
]
[
char
]
(
1
)
COLLATE
Latin1_General_CI_AI
NOT
NULL
)
ON
[
PRIMARY
]
TEXTIMAGE_ON
[
PRIMARY
]
GO
CREATE
TABLE
[
dbo
].[
session
]
(
[
sess_id
]
[
varchar
]
(
128
)
COLLATE
Latin1_General_CI_AI
NOT
NULL
,
[
created
]
[
datetime
]
NOT
NULL
,
[
changed
]
[
datetime
]
NULL
,
[
ip
]
[
varchar
]
(
40
)
COLLATE
Latin1_General_CI_AI
NOT
NULL
,
[
vars
]
[
text
]
COLLATE
Latin1_General_CI_AI
NOT
NULL
)
ON
[
PRIMARY
]
TEXTIMAGE_ON
[
PRIMARY
]
GO
CREATE
TABLE
[
dbo
].[
users
]
(
[
user_id
]
[
int
]
IDENTITY
(
1
,
1
)
NOT
NULL
,
[
username
]
[
varchar
]
(
128
)
COLLATE
Latin1_General_CI_AI
NOT
NULL
,
[
mail_host
]
[
varchar
]
(
128
)
COLLATE
Latin1_General_CI_AI
NOT
NULL
,
[
created
]
[
datetime
]
NOT
NULL
,
[
last_login
]
[
datetime
]
NULL
,
[
language
]
[
varchar
]
(
5
)
COLLATE
Latin1_General_CI_AI
NULL
,
[
preferences
]
[
text
]
COLLATE
Latin1_General_CI_AI
NULL
)
ON
[
PRIMARY
]
TEXTIMAGE_ON
[
PRIMARY
]
GO
CREATE
TABLE
[
dbo
].[
dictionary
]
(
[
user_id
]
[
int
]
,
[
language
]
[
varchar
]
(
5
)
COLLATE
Latin1_General_CI_AI
NOT
NULL
,
[
data
]
[
text
]
COLLATE
Latin1_General_CI_AI
NOT
NULL
)
ON
[
PRIMARY
]
TEXTIMAGE_ON
[
PRIMARY
]
GO
CREATE
TABLE
[
dbo
].[
searches
]
(
[
search_id
]
[
int
]
IDENTITY
(
1
,
1
)
NOT
NULL
,
[
user_id
]
[
int
]
NOT
NULL
,
[
type
]
[
tinyint
]
NOT
NULL
,
[
name
]
[
varchar
]
(
128
)
COLLATE
Latin1_General_CI_AI
NOT
NULL
,
[
data
]
[
text
]
COLLATE
Latin1_General_CI_AI
NOT
NULL
)
ON
[
PRIMARY
]
TEXTIMAGE_ON
[
PRIMARY
]
GO
ALTER
TABLE
[
dbo
].[
cache_index
]
WITH
NOCHECK
ADD
PRIMARY
KEY
CLUSTERED
(
[
user_id
],[
mailbox
]
)
ON
[
PRIMARY
]
GO
ALTER
TABLE
[
dbo
].[
cache_thread
]
WITH
NOCHECK
ADD
PRIMARY
KEY
CLUSTERED
(
[
user_id
],[
mailbox
]
)
ON
[
PRIMARY
]
GO
ALTER
TABLE
[
dbo
].[
cache_messages
]
WITH
NOCHECK
ADD
PRIMARY
KEY
CLUSTERED
(
[
user_id
],[
mailbox
],[
uid
]
)
ON
[
PRIMARY
]
GO
ALTER
TABLE
[
dbo
].[
contacts
]
WITH
NOCHECK
ADD
CONSTRAINT
[
PK_contacts_contact_id
]
PRIMARY
KEY
CLUSTERED
(
[
contact_id
]
)
ON
[
PRIMARY
]
GO
ALTER
TABLE
[
dbo
].[
contactgroups
]
WITH
NOCHECK
ADD
CONSTRAINT
[
PK_contactgroups_contactgroup_id
]
PRIMARY
KEY
CLUSTERED
(
[
contactgroup_id
]
)
ON
[
PRIMARY
]
GO
ALTER
TABLE
[
dbo
].[
contactgroupmembers
]
WITH
NOCHECK
ADD
CONSTRAINT
[
PK_contactgroupmembers_id
]
PRIMARY
KEY
CLUSTERED
(
[
contactgroup_id
],
[
contact_id
]
)
ON
[
PRIMARY
]
GO
ALTER
TABLE
[
dbo
].[
identities
]
WITH
NOCHECK
ADD
PRIMARY
KEY
CLUSTERED
(
[
identity_id
]
)
ON
[
PRIMARY
]
GO
ALTER
TABLE
[
dbo
].[
session
]
WITH
NOCHECK
ADD
CONSTRAINT
[
PK_session_sess_id
]
PRIMARY
KEY
CLUSTERED
(
[
sess_id
]
)
ON
[
PRIMARY
]
GO
ALTER
TABLE
[
dbo
].[
users
]
WITH
NOCHECK
ADD
CONSTRAINT
[
PK_users_user_id
]
PRIMARY
KEY
CLUSTERED
(
[
user_id
]
)
ON
[
PRIMARY
]
GO
ALTER
TABLE
[
dbo
].[
searches
]
WITH
NOCHECK
ADD
CONSTRAINT
[
PK_searches_search_id
]
PRIMARY
KEY
CLUSTERED
(
[
search_id
]
)
ON
[
PRIMARY
]
GO
ALTER
TABLE
[
dbo
].[
cache
]
ADD
CONSTRAINT
[
DF_cache_user_id
]
DEFAULT
(
'0'
)
FOR
[
user_id
],
CONSTRAINT
[
DF_cache_cache_key
]
DEFAULT
(
''
)
FOR
[
cache_key
],
CONSTRAINT
[
DF_cache_created
]
DEFAULT
(
getdate
())
FOR
[
created
]
GO
CREATE
INDEX
[
IX_cache_user_id
]
ON
[
dbo
].[
cache
]([
user_id
])
ON
[
PRIMARY
]
GO
CREATE
INDEX
[
IX_cache_cache_key
]
ON
[
dbo
].[
cache
]([
cache_key
])
ON
[
PRIMARY
]
GO
CREATE
INDEX
[
IX_cache_created
]
ON
[
dbo
].[
cache
]([
created
])
ON
[
PRIMARY
]
GO
ALTER
TABLE
[
dbo
].[
cache_index
]
ADD
CONSTRAINT
[
DF_cache_index_changed
]
DEFAULT
(
getdate
())
FOR
[
changed
],
CONSTRAINT
[
DF_cache_index_valid
]
DEFAULT
(
'0'
)
FOR
[
valid
]
GO
CREATE
INDEX
[
IX_cache_index_user_id
]
ON
[
dbo
].[
cache_index
]([
user_id
])
ON
[
PRIMARY
]
GO
ALTER
TABLE
[
dbo
].[
cache_thread
]
ADD
CONSTRAINT
[
DF_cache_thread_changed
]
DEFAULT
(
getdate
())
FOR
[
changed
]
GO
CREATE
INDEX
[
IX_cache_thread_user_id
]
ON
[
dbo
].[
cache_thread
]([
user_id
])
ON
[
PRIMARY
]
GO
ALTER
TABLE
[
dbo
].[
cache_messages
]
ADD
CONSTRAINT
[
DF_cache_messages_changed
]
DEFAULT
(
getdate
())
FOR
[
changed
],
CONSTRAINT
[
DF_cache_messages_flags
]
DEFAULT
(
0
)
FOR
[
flags
]
GO
CREATE
INDEX
[
IX_cache_messages_user_id
]
ON
[
dbo
].[
cache_messages
]([
user_id
])
ON
[
PRIMARY
]
GO
ALTER
TABLE
[
dbo
].[
contacts
]
ADD
CONSTRAINT
[
DF_contacts_user_id
]
DEFAULT
(
0
)
FOR
[
user_id
],
CONSTRAINT
[
DF_contacts_changed
]
DEFAULT
(
getdate
())
FOR
[
changed
],
CONSTRAINT
[
DF_contacts_del
]
DEFAULT
(
'0'
)
FOR
[
del
],
CONSTRAINT
[
DF_contacts_name
]
DEFAULT
(
''
)
FOR
[
name
],
CONSTRAINT
[
DF_contacts_email
]
DEFAULT
(
''
)
FOR
[
email
],
CONSTRAINT
[
DF_contacts_firstname
]
DEFAULT
(
''
)
FOR
[
firstname
],
CONSTRAINT
[
DF_contacts_surname
]
DEFAULT
(
''
)
FOR
[
surname
],
CONSTRAINT
[
CK_contacts_del
]
CHECK
([
del
]
=
'1'
or
[
del
]
=
'0'
)
GO
CREATE
INDEX
[
IX_contacts_user_id
]
ON
[
dbo
].[
contacts
]([
user_id
])
ON
[
PRIMARY
]
GO
ALTER
TABLE
[
dbo
].[
contactgroups
]
ADD
CONSTRAINT
[
DF_contactgroups_user_id
]
DEFAULT
(
0
)
FOR
[
user_id
],
CONSTRAINT
[
DF_contactgroups_changed
]
DEFAULT
(
getdate
())
FOR
[
changed
],
CONSTRAINT
[
DF_contactgroups_del
]
DEFAULT
(
'0'
)
FOR
[
del
],
CONSTRAINT
[
DF_contactgroups_name
]
DEFAULT
(
''
)
FOR
[
name
],
CONSTRAINT
[
CK_contactgroups_del
]
CHECK
([
del
]
=
'1'
or
[
del
]
=
'0'
)
GO
CREATE
INDEX
[
IX_contactgroups_user_id
]
ON
[
dbo
].[
contacts
]([
user_id
])
ON
[
PRIMARY
]
GO
ALTER
TABLE
[
dbo
].[
contactgroupmembers
]
ADD
CONSTRAINT
[
DF_contactgroupmembers_contactgroup_id
]
DEFAULT
(
0
)
FOR
[
contactgroup_id
],
CONSTRAINT
[
DF_contactgroupmembers_contact_id
]
DEFAULT
(
0
)
FOR
[
contact_id
],
CONSTRAINT
[
DF_contactgroupmembers_created
]
DEFAULT
(
getdate
())
FOR
[
created
]
GO
CREATE
INDEX
[
IX_contactgroupmembers_contact_id
]
ON
[
dbo
].[
contactgroupmembers
]([
contact_id
])
ON
[
PRIMARY
]
GO
ALTER
TABLE
[
dbo
].[
identities
]
ADD
CONSTRAINT
[
DF_identities_user
]
DEFAULT
(
'0'
)
FOR
[
user_id
],
CONSTRAINT
[
DF_identities_del
]
DEFAULT
(
'0'
)
FOR
[
del
],
CONSTRAINT
[
DF_identities_standard
]
DEFAULT
(
'0'
)
FOR
[
standard
],
CONSTRAINT
[
DF_identities_name
]
DEFAULT
(
''
)
FOR
[
name
],
CONSTRAINT
[
DF_identities_organization
]
DEFAULT
(
''
)
FOR
[
organization
],
CONSTRAINT
[
DF_identities_email
]
DEFAULT
(
''
)
FOR
[
email
],
CONSTRAINT
[
DF_identities_reply
]
DEFAULT
(
''
)
FOR
[
reply
-
to
],
CONSTRAINT
[
DF_identities_bcc
]
DEFAULT
(
''
)
FOR
[
bcc
],
CONSTRAINT
[
DF_identities_html_signature
]
DEFAULT
(
'0'
)
FOR
[
html_signature
],
CHECK
([
standard
]
=
'1'
or
[
standard
]
=
'0'
),
CHECK
([
del
]
=
'1'
or
[
del
]
=
'0'
)
GO
CREATE
INDEX
[
IX_identities_user_id
]
ON
[
dbo
].[
identities
]([
user_id
])
ON
[
PRIMARY
]
GO
CREATE
INDEX
[
IX_identities_email
]
ON
[
dbo
].[
identities
]([
email
],[
del
])
ON
[
PRIMARY
]
GO
ALTER
TABLE
[
dbo
].[
session
]
ADD
CONSTRAINT
[
DF_session_sess_id
]
DEFAULT
(
''
)
FOR
[
sess_id
],
CONSTRAINT
[
DF_session_created
]
DEFAULT
(
getdate
())
FOR
[
created
],
CONSTRAINT
[
DF_session_ip
]
DEFAULT
(
''
)
FOR
[
ip
]
GO
CREATE
INDEX
[
IX_session_changed
]
ON
[
dbo
].[
session
]([
changed
])
ON
[
PRIMARY
]
GO
ALTER
TABLE
[
dbo
].[
users
]
ADD
CONSTRAINT
[
DF_users_username
]
DEFAULT
(
''
)
FOR
[
username
],
CONSTRAINT
[
DF_users_mail_host
]
DEFAULT
(
''
)
FOR
[
mail_host
],
CONSTRAINT
[
DF_users_created
]
DEFAULT
(
getdate
())
FOR
[
created
]
GO
CREATE
UNIQUE
INDEX
[
IX_users_username
]
ON
[
dbo
].[
users
]([
username
],[
mail_host
])
ON
[
PRIMARY
]
GO
CREATE
UNIQUE
INDEX
[
IX_dictionary_user_language
]
ON
[
dbo
].[
dictionary
]([
user_id
],[
language
])
ON
[
PRIMARY
]
GO
ALTER
TABLE
[
dbo
].[
searches
]
ADD
CONSTRAINT
[
DF_searches_user
]
DEFAULT
(
0
)
FOR
[
user_id
],
CONSTRAINT
[
DF_searches_type
]
DEFAULT
(
0
)
FOR
[
type
]
GO
CREATE
UNIQUE
INDEX
[
IX_searches_user_type_name
]
ON
[
dbo
].[
searches
]([
user_id
],[
type
],[
name
])
ON
[
PRIMARY
]
GO
ALTER
TABLE
[
dbo
].[
identities
]
ADD
CONSTRAINT
[
FK_identities_user_id
]
FOREIGN
KEY
([
user_id
])
REFERENCES
[
dbo
].[
users
]
([
user_id
])
ON
DELETE
CASCADE
ON
UPDATE
CASCADE
GO
ALTER
TABLE
[
dbo
].[
contacts
]
ADD
CONSTRAINT
[
FK_contacts_user_id
]
FOREIGN
KEY
([
user_id
])
REFERENCES
[
dbo
].[
users
]
([
user_id
])
ON
DELETE
CASCADE
ON
UPDATE
CASCADE
GO
ALTER
TABLE
[
dbo
].[
contactgroups
]
ADD
CONSTRAINT
[
FK_contactgroups_user_id
]
FOREIGN
KEY
([
user_id
])
REFERENCES
[
dbo
].[
users
]
([
user_id
])
ON
DELETE
CASCADE
ON
UPDATE
CASCADE
GO
ALTER
TABLE
[
dbo
].[
cache
]
ADD
CONSTRAINT
[
FK_cache_user_id
]
FOREIGN
KEY
([
user_id
])
REFERENCES
[
dbo
].[
users
]
([
user_id
])
ON
DELETE
CASCADE
ON
UPDATE
CASCADE
GO
ALTER
TABLE
[
dbo
].[
cache_index
]
ADD
CONSTRAINT
[
FK_cache_index_user_id
]
FOREIGN
KEY
([
user_id
])
REFERENCES
[
dbo
].[
users
]
([
user_id
])
ON
DELETE
CASCADE
ON
UPDATE
CASCADE
GO
ALTER
TABLE
[
dbo
].[
cache_thread
]
ADD
CONSTRAINT
[
FK_cache_thread_user_id
]
FOREIGN
KEY
([
user_id
])
REFERENCES
[
dbo
].[
users
]
([
user_id
])
ON
DELETE
CASCADE
ON
UPDATE
CASCADE
GO
ALTER
TABLE
[
dbo
].[
cache_messages
]
ADD
CONSTRAINT
[
FK_cache_messages_user_id
]
FOREIGN
KEY
([
user_id
])
REFERENCES
[
dbo
].[
users
]
([
user_id
])
ON
DELETE
CASCADE
ON
UPDATE
CASCADE
GO
ALTER
TABLE
[
dbo
].[
contactgroupmembers
]
ADD
CONSTRAINT
[
FK_contactgroupmembers_contactgroup_id
]
FOREIGN
KEY
([
contactgroup_id
])
REFERENCES
[
dbo
].[
contactgroups
]
([
contactgroup_id
])
ON
DELETE
CASCADE
ON
UPDATE
CASCADE
GO
ALTER
TABLE
[
dbo
].[
searches
]
ADD
CONSTRAINT
[
FK_searches_user_id
]
FOREIGN
KEY
([
user_id
])
REFERENCES
[
dbo
].[
users
]
([
user_id
])
ON
DELETE
CASCADE
ON
UPDATE
CASCADE
GO
-- Use trigger instead of foreign key (#1487112)
-- "Introducing FOREIGN KEY constraint ... may cause cycles or multiple cascade paths."
CREATE
TRIGGER
[
contact_delete_member
]
ON
[
dbo
].[
contacts
]
AFTER
DELETE
AS
DELETE
FROM
[
dbo
].[
contactgroupmembers
]
WHERE
[
contact_id
]
IN
(
SELECT
[
contact_id
]
FROM
deleted
)
GO
File Metadata
Details
Attached
Mime Type
text/plain
Expires
Fri, Apr 24, 1:30 PM (14 h, 38 m)
Storage Engine
local-disk
Storage Format
Raw Data
Storage Handle
be/e8/6d39d5b42259593cdf8e0a61566a
Default Alt Text
mssql.initial.sql (12 KB)
Attached To
Mode
R113 roundcubemail
Attached
Detach File
Event Timeline