Na minha opinião, você pode pensar em fazer do primeiro jeito se:
Os perfis são imutáveis, ou seja, depois de criados ficam com aqueles acessos para sempre.
E
Não será necessário fazer pesquisas por acesso (por exemplo, listar usuários que possuem acesso X)
Mas veja bem, eu disse que pode PENSAR em fazer… mesmo assim o segundo continua sendo mais correto.
E
Edenilton_Fr_s
Eu usaria as Tabelas 2.
Motivos:
1- Qual seria o espaço destinado para o campo ‘acessos’? Se for pequeno, pode não caber num momento futuro. Se for grande, você pode estar alocando espaço desnecessário;
2- Economia de tempo na inserção. Você não precisa procurar um determinado registro para atualizá-lo. Simplesmente insere uma nova linha;
2- É a mais correta.
[]'s
rcipriani
gomesrod:
Na minha opinião, você pode pensar em fazer do primeiro jeito se:
Os perfis são imutáveis, ou seja, depois de criados ficam com aqueles acessos para sempre.
E
Não será necessário fazer pesquisas por acesso (por exemplo, listar usuários que possuem acesso X)
Mas veja bem, eu disse que pode PENSAR em fazer… mesmo assim o segundo continua sendo mais correto.
Não discordando de você, mas …
1) Os perfis são imutáveis, ou seja, depois de criados ficam com aqueles acessos para sempre.
Se forem imutaveis, não muda nada, pois vai mudar a String, to errado?
E 2) Não será necessário fazer pesquisas por acesso (por exemplo, listar usuários que possuem acesso X)
Se eu for listar também da do primeiro SELECT … WHERE perfil.acesso LIKE “%algum.acesso%”
Que acham? :?:
rcipriani
Era mais pra ouvir umas opiniões, acho que a segunda forma é melhor mesmo…
O comando SQL nem fica complicado.
Vlw ai, fica o tópico ai pr ase alguém passar por isso.
[size=7]Palavras chaves:
db, bd, permissões, acesso, mysql, banco de dados, como fazer[/size]
L
leoduval
Opa… blz?
Eu pessoalmente prefiro trabalhar com a seguinte estrutura:
Desta forma tu consegue criar perfis e associar ao usuario e caso necessite de alguma permissao especifica que nao existe no perfil pode adicionar separadamente(PermissaoUsuario)
Eu gosto desta abordagem… espero ter contribuido…
Abs
rcipriani
leoduval:
Opa… blz?
Eu pessoalmente prefiro trabalhar com a seguinte estrutura:
Desta forma tu consegue criar perfis e associar ao usuario e caso necessite de alguma permissao especifica que nao existe no perfil pode adicionar separadamente(PermissaoUsuario)
Eu gosto desta abordagem… espero ter contribuido…
Abs
Então, permissão especifica?
Que fuja do perfil?
Se for isso, boa a idéia, mas digamos que vai virar uma zuera, pq se tem perfil (gerente, atendente, estagiario), é para o funcionario se enquadrar em algum, não acha?
L
leoduval
rcipriani:
leoduval:
Opa… blz?
Eu pessoalmente prefiro trabalhar com a seguinte estrutura:
Desta forma tu consegue criar perfis e associar ao usuario e caso necessite de alguma permissao especifica que nao existe no perfil pode adicionar separadamente(PermissaoUsuario)
Eu gosto desta abordagem… espero ter contribuido…
Abs
Então, permissão especifica?
Que fuja do perfil?
Se for isso, boa a idéia, mas digamos que vai virar uma zuera, pq se tem perfil (gerente, atendente, estagiario), é para o funcionario se enquadrar em algum, não acha?
A ideia é inserir na tabela Permissoes todas as permissões do sistemas (Incluir Usuario, Excluir Usuario, Pesq. Usuario, Incluir Perfil…etc) Na tabela Perfil tu cadastra somente o perfil e na tabela PerfilPermissao tu associa todas as permissoes ao perfil… até ai ok? O usuario que tiver este perfil vai ter estas permissoes associadas… supondo que o usuario gerente de determinado setor da empresa precisa de uma permissao especifica do modulo financeiro e não tem a necessidade de adicionar esta permissao ao perfil tu podes somente associar a permissao ao usuario através da tabela PermissaoUsuario.
Se tiver alguma duvida da um tok…
abs
Felagund
Eu prefiro optar pelos perfis, nada além disso, se o usuário precisa de uma permissão maior que outros do mesmo perfil, deve-se criar um perfil novo com as novas permissões.
Eu prefiro a segunda abordagem, não é complexo buscar os acessos, basta um join a mais xD
L
leoduval
Eu prefiro a abordagem que falei porque acho que fica mais flexivel… mas vai de cada um…
Abs
rcipriani
leoduval:
rcipriani:
leoduval:
Opa… blz?
Eu pessoalmente prefiro trabalhar com a seguinte estrutura:
Desta forma tu consegue criar perfis e associar ao usuario e caso necessite de alguma permissao especifica que nao existe no perfil pode adicionar separadamente(PermissaoUsuario)
Eu gosto desta abordagem… espero ter contribuido…
Abs
Então, permissão especifica?
Que fuja do perfil?
Se for isso, boa a idéia, mas digamos que vai virar uma zuera, pq se tem perfil (gerente, atendente, estagiario), é para o funcionario se enquadrar em algum, não acha?
A ideia é inserir na tabela Permissoes todas as permissões do sistemas (Incluir Usuario, Excluir Usuario, Pesq. Usuario, Incluir Perfil…etc) Na tabela Perfil tu cadastra somente o perfil e na tabela PerfilPermissao tu associa todas as permissoes ao perfil… até ai ok? O usuario que tiver este perfil vai ter estas permissoes associadas… supondo que o usuario gerente de determinado setor da empresa precisa de uma permissao especifica do modulo financeiro e não tem a necessidade de adicionar esta permissao ao perfil tu podes somente associar a permissao ao usuario através da tabela PermissaoUsuario.
Se tiver alguma duvida da um tok…
abs
Então, essa forma é boa sim, aqui na empresa o sistema é feito assim, porém o perfil não fica sendo do usuário, e sim, um pacote de permissões…
Com certeza essa forma é mais flexível, entretanto aqui por ser flexivel vira uma bagunça, pois tem gente que tem permissão que não deveria…
De qualquer forma acho que vou adotar esta opção, mas por enquanto não vou disponibilizar no sistema a função de permitir acessos fora do perfil… ai se no futuro neessitar, o programa e o banco ja estão criados da maneira mais dinâmica.