Jump to content

Recommended Posts

I am using php to develop a financial database tracking income/expenses ect

 

I am to the point where it is working perfectly and I would like to add the ability to have 2 or 3 concurrent users

 

I have added a user in mysql through my webhost and linked the connect db to the specific users

 

My webhost says I need a vpn or dedicated host, i cannot have php add users to the mysql.user table

 

Am I missing something?

 

I can create a pool of them manually to be linked to new users as they are added but I wanted to to it automatically through the signup process and

not have to set up a pool periodically but it doesnt seem possible to do it any other way.

Link to comment
https://forums.phpfreaks.com/topic/237471-multiple-users-on-one-database/
Share on other sites

its a financial database for charitable contributions and expenses

now I have one of my testers want to be able to have 2 people entering data

 

I have been looking but cannot find the answers I am looking for

 

For example

 

If one goes to edit a contribution in the table and the other enters a new contribution on the same table but a different record number

will the table be inaccessible to him because the other table has a record being edited.

 

Each person has a username in the system (not mysql) for use with sessions

 

or would i be better of looking at the pages and make sure the mysql connection is closed after each page load, the pages do use a lot of jquery with ajax now also

 

Ok glad we cleared that up.

 

There is no reason for you to have mulitple "mysql user accounts" .  Your application is the one connecting to mysql, not the users themselves.  The concept of individual users should be something that exists in your application.  Typically people implement a user table.

 

Mysql is built for concurrent access.  There is nothing special you need to do. Someone editing a row does not stop another person from reading information or inserting new rows.

 

With that said, I don't want to write a novel here, but I highly recommend that you use the innodb engine type for your tables.  If you did not start that way it is not a major problem -- you can alter the tables to change them to innodb using the ALTER TABLE command.

 

For a system dealing with finance you will inevitably want to have transactions and mysql with the default isam engine does not support transactions.  Also innodb has constraints and implements row level locking, whereas myisam only can do table locking.  That does not mean that you will have contention problems because the way the table locks in myisam work is extremely fast.  However in general innodb performs better and has a lot of features that are considered essential in most other RDBMS's. 

 

In your code you can close your mysql connections if you want to, and it's good practice to have clean code, but it's not necessary as php has page scope and the connections will be garbage collected when the script has executed.  Unlike many other rdbms's the mysql connection process is extremely lightweight so making and closing connections in every script is not a performance concern.

 

 

This thread is more than a year old. Please don't revive it unless you have something important to add.

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

×
×
  • Create New...

Important Information

We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.