Advertisement
Help Keep Boards Alive. Support us by going ad free today. See here: https://subscriptions.boards.ie/.
If we do not hit our goal we will be forced to close the site.

Current status: https://keepboardsalive.com/

Annual subs are best for most impact. If you are still undecided on going Ad Free - you can also donate using the Paypal Donate option. All contribution helps. Thank you.
https://www.boards.ie/group/1878-subscribers-forum

Private Group for paid up members of Boards.ie. Join the club.

Mysql vert quick question

  • 31-01-2009 07:29PM
    #1
    Registered Users, Registered Users 2 Posts: 3,875 ✭✭✭


    I have a student table
    have a registration table
    and I have a curse table

    I want students to be bale to sign up for multiple courses and each time appear on the registration table with a different registration Id this part is fine.

    I want it to stop the same student registering for the same course twice however.

    how do i do this

    Registration_Id is currently the primary key for my reg table
    can i make it so that there cant be two instaces of the same student id and course id?


Comments

  • Registered Users, Registered Users 2 Posts: 2,699 ✭✭✭samhail


    quick solution would be to run a quick select statement on your table to see if there is a row that matchs the student if and course id before you insert. would be able to handle it better on the front end.

    you could try to make the student id and course id both primary keys and both unique - though i am totally guessing on that one. no idea what it would do tbh :)


  • Registered Users, Registered Users 2 Posts: 197 ✭✭pauldiv


    In the registrations table you could create a composite primary key consisting of the following fields:

    registration_id
    student_id (primary key)
    course_id (primary key)

    The student_id and course_id fields will link to the corresponding primaries from the student and course tables.

    This will ensure that no student can be registered for the same course twice.


  • Registered Users, Registered Users 2 Posts: 3,875 ✭✭✭ShoulderChip


    pauldiv wrote: »
    In the registrations table you could create a composite primary key consisting of the following fields:

    registration_id
    student_id (primary key)
    course_id (primary key)

    The student_id and course_id fields will link to the corresponding primaries from the student and course tables.

    This will ensure that no student can be registered for the same course twice.

    yeah thats what I thought but phpmyadmin will not let me have more than one primary key,
    I set them both to indexes but I am not sure what this did.


  • Closed Accounts Posts: 2,046 ✭✭✭democrates


    yeah thats what I thought but phpmyadmin will not let me have more than one primary key,
    I set them both to indexes but I am not sure what this did.
    Get rid of the individual indexes on studentid and courseid.

    Have a look at phpmyadmin again and use the option under "Indexes":
    Create an index on [2] columns (GO)
    Then you can pick studentid and courseid.


  • Registered Users, Registered Users 2 Posts: 3,875 ✭✭✭ShoulderChip


    democrates wrote: »
    Get rid of the individual indexes on studentid and courseid.

    Have a look at phpmyadmin again and use the option under "Indexes":
    Create an index on [2] columns (GO)
    Then you can pick studentid and courseid.

    cheers but i tried that and it still hasn't changed anything

    Under indexes i know have
    Keyname Type Cardinality Action Field
    PRIMARY PRIMARY 25 Edit Drop Registration Id

    newkey INDEX 25 Edit Drop Student Id, Course ID


  • Advertisement
  • Registered Users, Registered Users 2 Posts: 197 ✭✭pauldiv


    Here is a post asking how to create a composite primary key -
    http://forums.mysql.com/read.php?125,116303,116303#msg-116303

    You might get some ideaS from reading the replies.

    Also, to use foreign keys in mySQL you may need to be using the InnoDb storage engine. You can specify what storage engine to use when issuing a CREATE TABLE statement.

    You could also try executing a CREATE TABLE statement in SQL such as -

    CREATE TABLE registrations(
    reg_id MEDIUMINT NOT NULL AUTO_INCREMENT,
    student_id MEDIUMINT NOT NULL,
    course_id MEDIUMINT NOT NULL,
    PRIMARY KEY (student_id, course_id)
    )


Advertisement