linux下怎么连接mysql数据库一、启动mysql服务(1) rpm方式安装的mysql
-设置自动启动
#ntsysv --level 3
-手工启动
#service mysqld start
(2) 编译安装的mysql
-设置自动启动
#vi /etc/rc.d/rc.local
.......
/usr/local/mysql/bin/mysqld_safe
........
-手工启动
#/usr/local/mysql/bin/mysqld_safe
查看文章
mysql服务器(一)2009-06-15 11:18mysql服务器
一. 认识和安装mysql
1. 认识mysql
(1) mysql是一种网络数据库服务器产品
(2) mysql是开源的免费的
(3) mysql是关系型数据库管理系统,支持SQL.
(4) mysql无溢出漏洞
(5) mysql提供丰富的API
(6) mysql提供丰富的数据类型
(7) mysql具较强的移值性
2. 安装mysql软件
(1) rpm安装方式
#rpm -ivh perl-CGI....
perl-DBI....
perl-DBD-MySQL.....
mysq-....
mysql-server....
mysql-devel.....
(2) 编译安装方式
#groupadd mysql
#useradd -g mysql mysql
#tar -xzvf mysql-4.1.19.tar.gz
#cd mysql-4.1.19
#./configure --prefix=/usr/local/mysql
#make
#make install
#cp support-files/my-medium.cnf /etc/my.cnf
#cd /usr/local/mysql
#bin/mysql_install_db --user=mysql
#chown -R root .
#chown -R mysql var
#chgrp -R mysql .
3. 启动mysql服务
(1) rpm方式安装的mysql
-设置自动启动
#ntsysv --level 3
-手工启动
#service mysqld start
(2) 编译安装的mysql
-设置自动启动
#vi /etc/rc.d/rc.local
.......
/usr/local/mysql/bin/mysqld_safe
........
-手工启动
#/usr/local/mysql/bin/mysqld_safe
二、mysql的管理
1. 如何连接mysql服务器
(1) Linux客户机
#mysql [-h服务器地址] [-u用户名] [-p口令] [数据库名]
实例:
#mysql
mysql
#mysql -h192.168.3.1 -uadmin -plinux
mysql
(2) Windows客户机
-利用第三方mysql客户端软件
-利用浏览器连接(服务器必须安装web管理平台,如:phpmyadmin/webmin)
注:webmin的安装方法
#tar -xzvf webmin-1.25.tar.gz
#cd webmin-1.25
#./setup.sh
2. 数据库管理
(1) 认识mysql的数据
用sh文件登录mysql时,出现ERROR 2002 (HY000)错误转载:
方案5
摘要:解决不能通过mysql .sock连接MySQL问题 这个问题主要提示是 , 不能通过 '/tmp/mysql .sock'连到服务器,而php标准配置正是用过'/tmp/mysql .sock',但是一些mysql 安装方法 将 mysql .sock放在/var/lib/mysql .sock或者其他的什么地方,你可以通过修改/etc/my.cnf文件来修正它,打开文件,可以看到如下的东东:
[mysql d]
socket=/var/lib/mysql .sock
改一下就好了,但也会引起其他的问题,如mysql 程序连不上了,再加一点:
[mysql ]
socket=/tmp/mysql .sock
或者还可以通过修改php.ini中的配置来使php用其他的mysql .sock来连,这个大家自己去找找
或者用这样的方法:
ln -s /var/lib/mysql /mysql .sock /tmp/mysql .sock
成功了,就是这样ln -s /var/lib/mysql /mysql .sock /tmp/mysql .sock
OK!
如何写在Linux下写Shell脚本控制向mysql数据库里插数据?。縹~~着急~~~while(1){
$dbh = DBI-connect ($connection_string, $userid, $username);
$sth=$dbh-prepare(insert into table(....) values(....));
$sth-execute
sleep (300);
}
lilnux的mysql初次的密码哪个文件中连接mysql数据库,如何在shell中创建数据库,创建表 , 插入csv文件,读取mysql数据库,导出mysql数据库为xml或html文件 ,
并分析了核心语句 。本文介绍的方法适用于PostgreSQL,相对mysql而言 , shell 中读写PostgreSQL会更简单些 。
1. 连接mysql 数据库
shell中连接数据库的方法很简单,只需要指定用户名,密码,连接的数据库名称,然后通过重定向,输入mysql的语句 , 如下所示:
mysql -u USERNAME -p PASSWORD DATABASENAME EOF 2/dev/null
show databases;
EOF
但这并不是一个好办法,任何使用该脚本的用户都能看到该数据库用户的账号和密码,要解决这个问题 , 可以用mysql
数据库的一个特殊配置文件 。mysql 数据库使用$HOME/.my.cnf
文件来读取特殊的启动命令和设置 。其中一项设置是由该用户账户发起的mysql 会话的默认密码 。要在这个文件中设置默认密码,可以加入下面的内容:
[client]
password = 123456
然后,别忘了修改权限:
chmod 400.my.cnf
这样就可以通过脚本访问mysql数据库了 , 如下所示:
#!/bin/bash
MYSQL=`which mysql`
$MYSQL test -u rootEOF
show databases;
show tables;
select * from employees where salary4000;
EOF
2. 创建数据库
通过上面的方法连接数据库 , 再通过重定向输入mysql语句,shell中读写mysql基本就介绍完了 。只要把sql语句写对了,通过重定向执行即可,下面来看一个实例:
#!/bin/bash
##############################
# @file create_db_mysql.sh
# @brief create database and tables in mysql
# @author Mingxing LAI
# @version 0.1
# @date 2013-01-20
##############################
USER="root"
DATABASE="students"
TABLE="students"
######################
#crate database
mysql -u $USEREOF 2/dev/null
CREATE DATABASE $DATABASE
EOF
[ $? -eq 0 ]echo "created DB" || echo DB already exists
######################
#create table
mysql -u $USER $DATABASEEOF 2/dev/null
CREATE TABLE $TABLE(
id int,
name varchar(100),
mark int,
dept varchar(4)
);
EOF
[ $? -eq 0 ]echo "Created table students" || echo "Table students already exist"
######################
#delete data
mysql -u $USER $DATABASEEOF 2/dev/null
DELETE FROM $TABLE;
EOF
这个脚本比较简单,就是几条SQL语句,没什么好解释的,下面来看一下,如何读入csv 文件,然后插入到mysql数据库中 。
3. 插入csv 文件
上面创建了一个学生表,表中有学生的学号,姓名 , 成绩,系别,假设有一个csv文件,内容如下:
$cat data
1,Navin M,98,CS
2,Kavya N,70,CS
3,Nawaz O,80,CS
4,Hari S,80,EC
5,Alex M,50,EC
6,Neenu J,70,EC
7,Bob A,30,EC
8,Anu M,90,AE
9,Sruthi,89,AE
10,Andrew,89,AE
为了将csv 文件插入到数据库,我们需要逐行读入,然后给字符串加上双引号,最后生成语句如下:
insert into students VALUES(1, "Navin M", 98, "CS");
要解析csv 文件,最好的工具莫过于awk了,将域的分隔符指定为逗号-F,,awk就自动将各个域拆分出来了,然后在需要双引号的地方打印输出一个双引号 , 就能够轻松得到下面这样的数据:
1, "Navin M", 98, "CS"
awk 代码如下:
query=`echo $line | awk -F, '{ printf("%s,\"%s\",%s,\"%s\"", $1, $2, $3, $4)}'`
statement=`echo "INSERT INTO $TABLE VALUES($query);"`
echo $statement
当然了,你也可以用其他办法,不过,几乎没有比awk更简单的了,第2种方法如下:
oldIFS=$IFS
IFS=,
values=($line)
values[1]="\"`echo ${values[1]} | tr ' ' '#' `\""
values[3]="\"`echo ${values[3]}`\""
query=`echo ${values[@]} | tr ' #' ', '`
IFS=$oldIFS
statement=`echo "INSERT INTO $TABLE VALUES($query);"`
echo "$statement"
首先通过指定域分隔符,将csv文件解析成一个数组,然后将空格替换成一个特殊的符号"#"(因为后面的替换中,会一次性输出数组,而数组是用空格分隔各字段,我们要将分隔数组的空格替换成逗号,所以这里将数据中的空格替换成"#")
,给字符串加上双引号,最后再把空格替换成逗号 , 把"#"替换为空格 。这种方法真是让人抓狂,我第一次就没有看明白 , 尤其是为什么要将空格替换成"#" 。
完整的插入数据的程序如下:
#!/bin/bash
#
# @file write_to_db_mysql.sh
# @brief wirte data to database in mysql
# @author Mingxing LAI
# @version 0.1
# @date 2013-01-20
#
USER="root"
DATABASE="students"
TABLE="students"
if [ $# -ne 1 ]; then
echo $0 DATAFILE
echo
exit 2
fi
data=https://www.04ip.com/post/$1
whileread line;
do
#query=`echo $line | awk -F, '{ printf("%s,\"%s\",%s,\"%s\"", $1, $2, $3, $4)}'`
oldIFS=$IFS
IFS=,
values=($line)
values[1]="\"`echo ${values[1]} | tr ' ' '#' `\""
values[3]="\"`echo ${values[3]}`\""
query=`echo ${values[@]} | tr ' #' ', '`
IFS=$oldIFS
statement=`echo "INSERT INTO $TABLE VALUES($query);"`
#echo $statement
mysql -u $USER $DATABASEEOF
INSERT INTO $TABLE VALUES($query);
EOF
done$data
if [[ $? -eq 0 ]]; then
echo "Wrote data into DB"
fi
4. 读取数据
知道怎么在shell 中连接mysql ,也知道了怎么在shell中批量执行sql 语句,读取数据,就没有任何难度了 。
#!/bin/bash
#
# @file read_db_mysql.sh
# @brief read data from mysql
# @author Mingxing LAI
# @version 0.1
# @date 2013-01-20
#
USER="root"
DATABASE="students"
TABLE="students"
#用tail 去掉表头
depts=`mysql -u $USER $DATABASE EOF | tail -n2
SELECT DISTINCT dept FROM $TABLE;
EOF`
for d in $depts; do
echo Department: $d
result="`mysql -u $USER $DATABASEEOF
set @i:=0;
SELECT @i:=@i 1 as rank, name, mark FROM students WHERE dept="$d" ORDER BY mark DESC;
EOF`"
echo "$result"
echo
done
【Sh怎么连接mysql ssms连接mysql】我们还可以在mysql语句中 , 使用选项来控制数据的输出格式
-H 输出为html
-X 输出为xml
如下所示:
#!/bin/bash
USER="root"
DATABASE="students"
TABLE="students"
mysql -u $USER $DATABASE -HEOF
select * from $TABLE
EOF
html 格式的可读性比较差,输出效果如下:
TABLE BORDER=1TRTHid/THTHname/THTHmark/THTHdept/TH/TRTRTD1/TDTDNavin M/TDTD98/TDTDCS/TD/TRTRTD2/TDTD Kavya N/TDTD70/TDTDCS/TD/TRTRTD3/TDTD Nawaz O/TDTD80/TDTDCS/TD/TRTRTD4/TDTDHari S/TDTD80/TDTDEC/TD/TRTRTD5/TDTDAlex M/TDTD50/TDTDEC/TD/TRTRTD6/TDTDNeenu J/TDTD70/TDTDEC/TD/TRTRTD7/TDTDBob A/TDTD30/TDTDEC/TD/TRTRTD8/TDTDAnu M/TDTD90/TDTDAE/TD/TRTRTD9/TDTDSruthi/TDTD89/TDTDAE/TD/TRTRTD10/TDTDAndrew/TDTD89/TDTDAE/TD/TR/TABLE
可读性差也可以理解,因为人家觉得 , 你没必要修改么 , 直接以html形式展示数据就可以了 。
idnamemarkdept
1Navin M98CS
2Kavya N70CS
3Nawaz O80CS
4Hari S80EC
5Alex M50EC
6Neenu J70EC
7Bob A30EC
8Anu M90AE
9Sruthi89AE
10Andrew89AE
xml形式的数据显示就比较正常了 , 直接将上面的-H 换成-X,输出如下:
?xml version="1.0"?
resultset statement="select * from students" xmlns:xsi=""
row
field name="id"1/field
field name="name"Navin M/field
field name="mark"98/field
field name="dept"CS/field
/row
row
field name="id"2/field
field name="name" Kavya N/field
field name="mark"70/field
field name="dept"CS/field
/row
/resultset
关于Sh怎么连接mysql和ssms连接mysql的介绍到此就结束了 , 不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息 , 记得收藏关注本站 。
推荐阅读
- LOL手游直播边框素材图,英雄联盟直播边框
- js自动调用的函数,html调用js函数
- ppt如何设置可以演示,ppt设置技巧
- 网络被设置不能打开游戏,网络设置不能玩游戏
- mysql用户密码怎么修改成英文 mysql用户密码怎么修改
- java调度代码 java进程调度算法代码
- sap国家电网案例分析,国家电网erp
- 直播连线教学话术,直播连线互动
- VB.NET写阶乘代码 vb n的阶乘怎么编写