O JavaScript pode se conectar ao MySQL? Se sim, como?
javascript
mysql
ajax
json
Anônimo, o Grande
fonte
fonte
Respostas:
Não, o JavaScript não pode se conectar diretamente ao MySQL. Mas você pode misturar JS com PHP para fazer isso.
JavaScript é uma linguagem do lado do cliente e seu banco de dados MySQL será executado em um servidor
fonte
O JavaScript do lado do cliente não pode acessar o MySQL sem algum tipo de ponte. Mas as afirmações em negrito acima de que o JavaScript é apenas uma linguagem do lado do cliente estão incorretas - o JavaScript pode ser executado no lado do cliente e no lado do servidor, como no Node.js.
O Node.js pode acessar o MySQL por meio de algo como https://github.com/sidorares/node-mysql2
Você também pode desenvolver algo usando Socket.IO
Você quis dizer se um aplicativo JS do lado do cliente pode acessar o MySQL? Não tenho certeza se essas bibliotecas existem, mas são possíveis.
EDIT : Desde que escrevemos, agora temos cluster MySQL :
JSDB oferece uma interface JS para bancos de dados.
Um conjunto curado de pacotes de banco de dados para Node.js de sindresorhus.
fonte
Se você deseja se conectar a um banco de dados MySQL usando JavaScript, pode usar Node.js e uma biblioteca chamada mysql . Você pode criar consultas e obter resultados como uma matriz de registros. Se você quiser tentar, pode usar meu gerador de projeto para criar um back-end e escolher o MySQL como o banco de dados a ser conectado. Em seguida, apenas exponha sua nova API REST ou terminal GraphQL à sua frente e comece a trabalhar com seu banco de dados MySQL.
ANTIGA RESPOSTA DEIXADA PELA NOSTALGIA
ENTÃO
Pelo que entendi a pergunta e corrijo-me se estiver errado, ela se refere ao modelo de servidor clássico com JavaScript apenas no lado do cliente. Neste modelo clássico, com servidores LAMP (Linux, Apache, MySQL, PHP) a linguagem em contato com o banco de dados era o PHP, então para solicitar dados ao banco de dados você precisa escrever scripts PHP e ecoar os dados de retorno para o cliente. Basicamente, a distribuição das linguagens de acordo com as máquinas físicas era:
Isso respondeu a um modelo MVC (Model, View, Controller) onde tínhamos a seguinte funcionalidade:
Para o controlador, temos ferramentas realmente interessantes como jQuery , como uma biblioteca de "baixo nível" para controlar a estrutura HTML (DOM), e então novas, mais de alto nível como Knockout.js que nos permitem criar observadores que conectam diferentes Elementos DOM atualizando-os quando os eventos ocorrem. Existe também o Angular.js do Google que funciona de maneira semelhante, mas parece ser um ambiente completo. Para ajudá-lo a escolher entre eles, aqui você tem duas análises excelentes das duas ferramentas: Knockout vs. Angular.js e Knockout.js vs. Angular.js . Eu ainda estou lendo. Espero que eles ajudem você.
AGORA
Em servidores modernos baseados em Node.js, usamos JavaScript para tudo. Node.js é um ambiente JavaScript com muitas bibliotecas que funcionam com Google V8, motor Chrome JavaScript. A maneira como trabalhamos com esses novos servidores é:
Então, nós temos muitos pacotes que podemos instalar usando o NPM (gerenciador de pacotes Node.js) e usá-los diretamente em nosso servidor Node.js apenas exigindo (para aqueles que desejam aprender Node.js, experimente este tutorial para iniciantes para uma visão geral). E entre esses pacotes, você tem alguns deles para acessar bancos de dados. Usando isso, você pode usar JavaScript no lado do servidor para acessar meus bancos de dados SQL.
Mas o melhor que você pode fazer se for trabalhar com Node.js é usar os novos bancos de dados NoSQL, como MongoDB , com base em arquivos JSON. Em vez de armazenar tabelas como o MySQL, ele armazena os dados em estruturas JSON, para que você possa colocar dados diferentes dentro de cada estrutura, como vetores numéricos longos, em vez de criar tabelas enormes para o tamanho do maior.
Espero que esta breve explicação seja útil para você e, se quiser saber mais sobre isso, aqui estão alguns recursos que podem ser usados:
Espero que ajude você a começar.
Diverta-se!
fonte
Acho que você precisaria adicionar algo como PHP na equação. PHP para interagir com o banco de dados e então você pode fazer chamadas AJAX com Javascript.
fonte
Um pouco tarde, mas recentemente descobri que o MySql 5.7 tem um plug-in http através do qual o usuário pode se conectar diretamente ao mysql agora.
Procure Cliente Http para mysql 5.7
fonte
A resposta simples é: não.
JavaScript é uma linguagem do lado do cliente executada no navegador ( não obstante o node.js ) e o MySQL é uma tecnologia do lado do servidor executada no servidor.
Isso significa que você normalmente usa uma linguagem do lado do servidor como ASP.NET ou PHP para se conectar ao banco de dados.
fonte
SIM? Dê uma olhada em um meteoro. Links:
http://meteor.com/screencast e http://net.tutsplus.com/tutorials/javascript-ajax/whats-this-meteor-thing/
Não entendo como isso é feito. Mas a Nettuts + colocou isso na seção javascript-ajax, talvez mágica aconteça.
Também mostra alguma maneira de conectar e inserir no MongoDB com JS, como este:
fonte
Dependendo do seu ambiente, você pode usar o Rhino para fazer isso, consulte o site do Rhino . Isso lhe dá acesso a todas as bibliotecas Java de dentro do JavaScript.
fonte
Sim. Existe um plugin HTTP para MySQL.
http://blog.ulf-wendel.de/2014/mysql-5-7-http-plugin-mysql/
Estou apenas pesquisando sobre isso agora, o que me levou a esta questão stackoverflow. Você deve ser capaz de usar AJAX em um banco de dados MySQL agora ou no futuro próximo (eles afirmam que não está pronto para produção).
fonte
Normalmente, você precisa de uma linguagem de script do lado do servidor, como PHP, para se conectar ao MySQL; no entanto, se você estiver apenas fazendo uma maquete rápida, poderá usar http://www.mysqljs.com para se conectar ao MySQL a partir de Javascript usando o código como segue:
Deve-se mencionar que esta não é uma forma segura de acessar o MySql e só é adequada para demonstrações privadas ou cenários onde o código-fonte não pode ser acessado por usuários finais, como em aplicativos iOS Phonegap.
fonte
var strSrc = "http://mysqljs.com/sql.aspx?";
Você pode enviar solicitações AJAX para alguns wrappers RESTful do lado do servidor para MySQL, como DBSlayer , PhpRestSQL ou AlsoSQL (para Drizzle , um fork do MySQL).
fonte
Sim você pode. Os conectores MySQL usam TCP para conexão, e em JS há uma pequena versão modificada do cliente TCP chamada Websocket. Mas você não pode se conectar diretamente ao servidor MySQL com websocket. Você precisará de alguma ponte de terceiros entre o websocket e o mysql. Recebe a consulta do websocket, envia para o mysql, responde o resultado e reenvia para JS.
E este é meu exemplo de bridge escrito em C # com biblioteca websocket-sharp:
Lado JS:
fonte
Não.
Você precisa escrever um wrapper em PHP e, em seguida, exportar os dados retornados (provavelmente como Json). NUNCA, obtenha do seu "_GET" o código SQL, pois isso é chamado de injeção SQL (as pessoas que aprenderem isso terão controle total sobre o seu banco de dados).
Este é um exemplo que escrevi:
Aprenda sobre injeções de SQL, por favor.
fonte
Você pode se conectar ao MySQL a partir de Javascript por meio de um miniaplicativo JAVA. O miniaplicativo JAVA incorporaria o driver JDBC para MySQL que permitirá a conexão com o MySQL.
Lembre-se de que se quiser se conectar a um servidor MySQL remoto (diferente daquele de onde baixou o miniaplicativo), você precisará pedir aos usuários que concedam permissões estendidas ao miniaplicativo. Por padrão, o miniaplicativo só pode se conectar ao servidor de onde foram baixados.
fonte
Se você não está bloqueado no MySQL, pode alternar para PostgreSQL. Ele suporta procedimentos JavaScript (PL / V8) dentro do banco de dados. É muito rápido e poderoso. Confira esta postagem .
fonte
JavaScript não pode se conectar diretamente ao banco de dados para obter os dados necessários, mas você pode usar AJAX. Para fazer uma solicitação AJAX fácil para o servidor, você pode usar o framework jQuery JS http://jquery.com . Aqui está um pequeno exemplo
JS:
PHP:
fonte
Eu entendi sua pergunta, acho que você está confundindo com linguagens como dot.net e java, onde você pode abrir uma conexão DB dentro do seu código. Não, o JavaScript não pode se conectar diretamente ao MySQL, pois o JavaScript é uma linguagem de script do lado do cliente (Exception Node.js). Você precisa de uma camada intermediária como a API RESTful para acessar os dados.
fonte
Você pode adicionar a conexão mysql usando o arquivo PHP. Abaixo está o exemplo de arquivo PHP.
fonte
Can JavaScript connect with MySQL?
.