friendica/doc/database/db_event.md
Alexandre Alapetite d2901dcb00 Fix for MySQL 5.7+
https://github.com/friendica/friendica/issues/2786

Only tested on Ubuntu 16.10 with MySQL 5.7.17.

https://dev.mysql.com/doc/refman/8.0/en/timestamp-initialization.html

https://dev.mysql.com/doc/refman/8.0/en/sql-mode.html#sqlmode_no_zero_date
As of MySQL 5.7.4, NO_ZERO_DATE is deprecated.

Patch based on the following search & replace (and then reverting some
changes in libraries):

```sh
grep -l '= "0000-00-00"' -r . | xargs sed -i -e "s/= \"0000-00-00\"/=
'0000-00-00'/g"

grep -l "0000-00-00" -r . | xargs sed -i -e "s/0000-00-00/0001-01-01/g"

grep -l "!= '0001-01-01'" -r . | xargs sed -i -e "s/!= '0001-01-01'/>
'0001-01-01'/g"

grep -l " === '0001-01-01'" -r . | xargs sed -i -e "s/ === '0001-01-01'/
<= '0001-01-01'/g"

grep -l " == '0001-01-01'" -r . | xargs sed -i -e "s/ == '0001-01-01'/
<= '0001-01-01'/g"

grep -l "strpos(\$dob, '0000-') === 0" -r . | xargs sed -i -e
"s/strpos(\$dob, '0000-') === 0/strpos(\$dob, '0000-') === 0 ||
strpos(\$dob, '0001-') === 0/g"

grep -l 'array("", "0001-01-01")' -r . | xargs sed -i -e 's/array("",
"0001-01-01")/array("", "0000-00-00", "0001-01-01")/g'

grep -l "\$dob = '0000-'" -r . | xargs sed -i -e "s/\$dob =
'0000-'/\$dob = '0001-'/g"
```
2017-04-11 23:00:45 +02:00

3.1 KiB

Table event

| Field | Description | Type | Null | Key | Default | Extra | | ---------- | ----------------------------------------------- -------| ------------------- | ---- | --- | ------------------- | --------------- | | id | sequential ID | int(11) | NO | PRI | NULL | auto_increment | | uid | user_id of the owner of this data | int(11) | NO | MUL | 0 | | | cid | contact_id (ID of the contact in contact table) | int(11) | NO | | 0 | | | uri | | varchar(255) | NO | | | | | created | creation time | datetime | NO | | 0001-01-01 00:00:00 | | | edited | last edit time | datetime | NO | | 0001-01-01 00:00:00 | | | start | event start time | datetime | NO | | 0001-01-01 00:00:00 | | | finish | event end time | datetime | NO | | 0001-01-01 00:00:00 | | | summary | short description or title of the event | text | NO | | NULL | | | desc | event description | text | NO | | NULL | | | location | event location | text | NO | | NULL | | | type | event or birthday | varchar(255) | NO | | | | | nofinish | if event does have no end this is 1 | tinyint(1) | NO | | 0 | | | adjust | adjust to timezone of the recipient (0 or 1) | tinyint(1) | NO | | 1 | | | ignore | 0 or 1 | tinyint(1) unsigned | NO | | 0 | | | allow_cid | Access Control - list of allowed contact.id '<19><78>' | mediumtext | NO | | NULL | | | allow_gid | Access Control - list of allowed groups | mediumtext | NO | | NULL | | | deny_cid | Access Control - list of denied contact.id | mediumtext | NO | | NULL | | | deny_gid | Access Control - list of denied groups | mediumtext | NO | | NULL | |

Return to database documentation