hoeveel mailadressen en tel.nrs

Overzicht Reageren

Sponsored by: Vacatures door Monsterboard

Pagina: 1 2 volgende »

Ozzie PHP

Ozzie PHP

09/04/2014 00:47:21
Quote Anchor link
Ola,

Niet een hele spannende vraag, maar vooral uit nieuwsgierigheid.

Ik ben benieuwd hoeveel tel.nrs en e-mailadressen een user kan invoeren op jouw website. Vaak zie je bij het inschrijven 2 velden voor een tel.nr. (een vast en een mobiel nummer). Is dat nog nodig, of is 1 tel.nr. tegenwoordig gebruikelijker? En dezelfde vraag voor een e-mailadres. Bied je de gebruiker de mogelijkheid om 1 e-mailadres in te voeren, of geef je hem de mogelijkheid om nog een extra e-mailadres in te voeren zodat de mail altijd naar 2 adressen wordt verstuurd?
 
PHP hulp

PHP hulp

28/11/2024 18:45:00
 
Donny Wie weet

Donny Wie weet

09/04/2014 00:49:56
Quote Anchor link
Ikzelf doe altijd maar 1 telefoon nummer vragen. Een 2e word of niet ingevuld of als het verplicht is (huisnummer en mobiel) dan vul ik zelf altijd bullshit in. 1 is ruim voldoende vind ik zelf
 
Ozzie PHP

Ozzie PHP

09/04/2014 00:50:52
Quote Anchor link
Thanks voor je reactie Donny! En hoeveel mailadressen?
 
Jan R

Jan R

09/04/2014 07:37:26
Quote Anchor link
Zowel op telefoon als gsm als email is het bij mij onbeperkt.
Meer nog. Inloggen kan met elk gekozen emailadres

Jan
 
Ward van der Put
Moderator

Ward van der Put

09/04/2014 07:54:02
Quote Anchor link
Eén e-mailadres en één telefoonnummer verplicht met optioneel een tweede telefoonnummer.

Voor één site heb ik wel eens een uitzondering gemaakt omdat we voor dat project contactpersonen snel te pakken moeten kunnen krijgen: twee e-mailadressen plus een vast telefoonnummer en een mobiel telefoonnummer, alle vier verplicht.
 
Ozzie PHP

Ozzie PHP

09/04/2014 08:24:36
Quote Anchor link
@Jan R

>> Zowel op telefoon als gsm als email is het bij mij onbeperkt.

Vanuit welke gedachte heb je dat gedaan?

>> Meer nog. Inloggen kan met elk gekozen emailadres

Oké... da's apart. Ook hier weer de vraag... waarom deze aanpak?

@Ward

>> Eén e-mailadres en één telefoonnummer verplicht met optioneel een tweede telefoonnummer.

Oké, en sla je dat optionele mailadres en tel.nr. dan op in de user tabel (dus bij de user zelf) of in een aparte tabel?
 
Ward van der Put
Moderator

Ward van der Put

09/04/2014 09:34:17
Quote Anchor link
>> Oké, en sla je dat optionele mailadres en tel.nr. dan op in de user tabel (dus bij de user zelf) of in een aparte tabel?

In twee extra velden in de usertabel. Dit is een situatie die je in theorie zou moeten normaliseren, maar die in de praktijk leidt tot over-normalisatie. Bij een kleine database merk je er niets van, maar bij een grote database gaat de JOIN in de weg zitten.
 
Jan R

Jan R

09/04/2014 10:08:24
Quote Anchor link
Zelf heb ik een 20-tal adressen. Vandaar meerdere ingave.
Gezien ik soms niet meer weet wat ik waar gebruik :) allemaal toegankelijk. Was wel (voor mij ) een beetje moeilijke sql.
 
Ozzie PHP

Ozzie PHP

09/04/2014 13:55:49
Quote Anchor link
@Ward

>> In twee extra velden in de usertabel.

Oké. En dan accepteer je dus als ik het goed begrijp het feit dat die 2 velden niet altijd gevuld zijn?

@Jan R

>> Zelf heb ik een 20-tal adressen. Vandaar meerdere ingave.
Gezien ik soms niet meer weet wat ik waar gebruik :)

Oké, bijzonder ;) Ik vraag me wel af of je daarmee niet een potentieel beveiligingsrisico creëert, maar dat terzijde...
 
Ward van der Put
Moderator

Ward van der Put

09/04/2014 14:16:23
Quote Anchor link
>> Oké. En dan accepteer je dus als ik het goed begrijp het feit dat die 2 velden niet altijd gevuld zijn?

Ja, net als bij tussenvoegsels bij achternamen, mocht je die apart willen opslaan.
 
Ozzie PHP

Ozzie PHP

09/04/2014 14:26:16
Quote Anchor link
Oké, helder! Klinkt aannemelijk.
 
Ger van Steenderen
Tutorial mod

Ger van Steenderen

09/04/2014 21:21:51
Quote Anchor link
Oké. En dan accepteer je dus als ik het goed begrijp het feit dat die 2 velden niet altijd gevuld zijn?
Er bestaat een verschil tussen wat mensen opgeven en wat je in de database opslaat.

Volgens de normalisatie theorieën kan je geen nullable kolommen in een tabel hebben, maar je moet daar praktisch mee omgaan.

Wards voorbeeld met tussenvoegsels is daar een goed voorbeeld voor. (Overigens bestaat er in MySQL een verschil tussen null en ''.

Een andere sitautie is als je een factuuradres en verzendadres hebt, 1 op de mss 30 keer zit daar verschil tussen en dan kies ik ervoor omdat in een aparte table op te slaan.
Gewijzigd op 09/04/2014 21:22:53 door Ger van Steenderen
 
Ozzie PHP

Ozzie PHP

09/04/2014 21:50:02
Quote Anchor link
Hey Ger,

>> Volgens de normalisatie theorieën kan je geen nullable kolommen in een tabel hebben, maar je moet daar praktisch mee omgaan.

Wat bedoel je precies. Ben je het wel of niet met de methode van Ward eens? Dus 2 mailadres velden en 2 tel.nr. velden, maar accepteren dat vaak 2 velden leeg zijn?

>> Er bestaat een verschil tussen wat mensen opgeven en wat je in de database opslaat.

Wat zou jij dan invullen indien men geen extra tel.nr. / mailadres opgeeft?
 
Ger van Steenderen
Tutorial mod

Ger van Steenderen

09/04/2014 22:04:24
Quote Anchor link
Ik ben het in zoverre met Ward eens dat je niet moet gaan over-normaliseren.
Maar ikzelf sla altijd iets op bv:

Voor het extra tel nr. 0 en voor het extra emailadres 'none'
 
Ozzie PHP

Ozzie PHP

09/04/2014 22:33:56
Quote Anchor link
Ah, op die manier bedoel je.

En wat is het voordeel om altijd iets op te slaan? Waarom niet een default null waarde?
 
Ger van Steenderen
Tutorial mod

Ger van Steenderen

09/04/2014 22:52:08
Quote Anchor link
Heel bot gezegd is het voordeel dat je geen gezeur aan je kop krijgt over normalisatie.

Normalistaie gaat over afhankelijkeden en iets wat niet bestaat kan nergens afhankelijk van zijn.
 
Ozzie PHP

Ozzie PHP

09/04/2014 22:56:41
Quote Anchor link
>> Heel bot gezegd is het voordeel dat je geen gezeur aan je kop krijgt over normalisatie.

Van wie? Van de normalisatiepolitie? Hehe, grapje hoor ;)
Ik snap alleen niet echt wat je doet. Omdat volgens de theorie een veld niet leeg mag zijn, zet je er toch maar iets in? Is dat waar het dan op neerkomt, of zie ik het helemaal verkeerd? Zou zo maar kunnen hoor?
 
Ward van der Put
Moderator

Ward van der Put

10/04/2014 07:36:34
Quote Anchor link
Er is een verschil tussen "we weten niet of het bestaat" en "het bestaat niet", maar in beide gevallen sta je met lege handen. (Om de argumentatie om te keren: als er nergens een God te bekennen is, kan dat "we weten niet of God bestaat" betekenen maar ook "God bestaat niet".)

Volgens sommigen zou je daarvoor het verschil tussen NULL en '' moeten gebruiken.

Stel, iemand meldt zich aan bij een site, maar gebruikte daarvoor het nieuwsbriefformulier. Daarin hoef je alleen voornaam en e-mailadres in te vullen. Van de volledige naam weten we alleen de voornaam, de andere data zijn nooit gecontroleerd of in actie gekomen.

Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
+----------+----------------+------------+
| Voornaam | Tussenvoegsels | Achternaam |
+----------+----------------+------------+
| 'Jan'    | NULL           | NULL       |
+----------+----------------+------------+


Later plaatst onze gebruiker een bestelling en leren we zijn volledige naam: Jan Jansen, zonder tussenvoegsels. We kunnen de NULL voor "weet niet" nu vervangen door '' voor "bestaat niet":

Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
+----------+----------------+------------+
| Voornaam | Tussenvoegsels | Achternaam |
+----------+----------------+------------+
| 'Jan'    | ''             | 'Jansen'   |
+----------+----------------+------------+


In theorie klinkt dat heel mooi. In de praktijk gaat het fout om verschillende redenen. Niet alle applicatiebouwers houden zich aan het verschil tussen '' en NULL, of weten niet hoe je NULL in een INSERT zet, waardoor onze database in hoog tempo vervuilt. Bovendien handelen MyISAM en InnoDB die NULL ook nog anders af.

Vandaar dat de oplossing van Ger een slim alternatief is: gebruik bijvoorbeeld 0 in de betekenis "we hebben de naam gecontroleerd en er zijn nul tussenvoegsels.

Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
+----------+----------------+------------+
| Voornaam | Tussenvoegsels | Achternaam |
+----------+----------------+------------+
| 'Jan'    | 0              | 'Jansen'   |
+----------+----------------+------------+
Gewijzigd op 10/04/2014 07:39:32 door Ward van der Put
 
Ozzie PHP

Ozzie PHP

10/04/2014 14:34:23
Quote Anchor link
Ward, dankjewel voor je uitleg.

>> Niet alle applicatiebouwers houden zich aan het verschil tussen '' en NULL, of weten niet hoe je NULL in een INSERT zet

Je kunt de waarde toch ook gewoon niet inserten als ie leeg is en dan defaulten naar null?

Ik snap de insteek enigszins, maar wat maakt het in de praktijk uit of het "weet niet" of "bestaat niet" is. Ik zou gewoon denken "we hebben 'm niet" :) Waarom we 'm niet hebben doet er niet toe.
 
Vincent Post

Vincent Post

10/04/2014 15:38:40
Quote Anchor link
Hallo,

Ik zou alleen 2 email's gebruiken als je daar van plan bent gebruik van te maken

voor het geval dat iemand niet meer op z'n mail kan kunnen ze een alternatief email adres gebruiken om een nieuw wachtwoord aan te vragen of dat soort dingen

Succes!
 
Ger van Steenderen
Tutorial mod

Ger van Steenderen

10/04/2014 15:41:53
Quote Anchor link
>>
>> Niet alle applicatiebouwers houden zich aan het verschil tussen '' en NULL, of weten niet hoe je NULL in een INSERT zet
Je kunt de waarde toch ook gewoon niet inserten als ie leeg is en dan defaulten naar null?


Dat kan ja, maar dan kan het nog steeds voorkomen dat iemand anders het wel doet maar dan met '' in plaats van NULL.

Met een NOT NULL constraint dwing je af dat er iets opgegeven wordt, of je kan met een default value afdwingen dat het niets altijd hetzelfde is.
 

Pagina: 1 2 volgende »



Overzicht Reageren

 
 

Om de gebruiksvriendelijkheid van onze website en diensten te optimaliseren maken wij gebruik van cookies. Deze cookies gebruiken wij voor functionaliteiten, analytische gegevens en marketing doeleinden. U vindt meer informatie in onze privacy statement.