第一招、mysql服务的启动和停止
net stop mysql net start mysql
第二招、登陆mysql
语法如下: mysql -u用户名 -p用户密码
键入命令mysql -uroot -p, 回车后提示你输入密码,输入12345,然后回车即可进入到mysql中了,mysql的提示符是:
mysql>
注意,如果是连接到另外的机器上,则需要加入一个参数-h机器IP
第三招、增加新用户
格式:grant 权限 on 数据库.* to 用户名@登录主机 identified by “密码”
如,增加一个用户user1密码为password1,让其可以在本机上登录, 并对所有数据库有查询、插入、修改、删除的权限。首先用以root用户连入mysql,然后键入以下命令:
grant select,insert,update,delete on *.* to user1@localhost Identified by "password1";
如果希望该用户能够在任何机器上登陆mysql,则将localhost改为”%”。
如果你不想user1有密码,可以再打一个命令将密码去掉。
grant select,insert,update,delete on mydb.* to user1@localhost identified by "";
第四招: 操作数据库
登录到mysql中,然后在mysql的提示符下运行下列命令,每个命令以分号结束。
1、 显示数据库列表。
show databases;
缺省有两个数据库:mysql和 test。 mysql库存放着mysql的系统和用户权限信息,我们改密码和新增用户,实际上就是对这个库进行操作。
2、 显示库中的数据表:
use mysql; show tables;
3、 显示数据表的结构:
describe 表名;
4、 建库与删库:
create database 库名; drop database 库名;
5、 建表:
use 库名; create table 表名(字段列表); drop table 表名;
6、 清空表中记录:
delete from 表名;
7、 显示表中的记录:
select * from 表名;
第五招、导出和导入数据
1. 导出数据:
mysqldump --opt test > mysql.test 即将数据库test数据库导出到mysql.test文件,后者是一个文本文件 如:mysqldump -u root -p123456 --databases dbname > mysql.dbname 就是把数据库dbname导出到文件mysql.dbname中。
2. 导入数据:
mysqlimport -u root -p123456 < mysql.dbname。
不用解释了吧。
3. 将文本数据导入数据库:
文本数据的字段数据之间用tab键隔开。
use test; load data local infile "文件名" into table 表名;
SQL常用命令使用方法:
(1) 数据记录筛选:
sql=”select * from 数据表 where 字段名=字段值 order by 字段名 [desc]”
sql=”select * from 数据表 where 字段名 like ‘%字段值%’ order by 字段名 [desc]”
sql=”select top 10 * from 数据表 where 字段名 order by 字段名 [desc]”
sql=”select * from 数据表 where 字段名 in (‘值1′,’值2′,’值3’)”
sql=”select * from 数据表 where 字段名 between 值1 and 值2″
(2) 更新数据记录:
sql=”update 数据表 set 字段名=字段值 where 条件表达式”
sql=”update 数据表 set 字段1=值1,字段2=值2 …… 字段n=值n where 条件表达式”
(3) 删除数据记录:
sql=”delete from 数据表 where 条件表达式”
sql=”delete from 数据表” (将数据表所有记录删除)
(4) 添加数据记录:
sql=”insert into 数据表 (字段1,字段2,字段3 …) values (值1,值2,值3 …)”
sql=”insert into 目标数据表 select * from 源数据表” (把源数据表的记录添加到目标数据表)
(5) 数据记录统计函数:
AVG(字段名) 得出一个表格栏平均值 COUNT(*|字段名) 对数据行数的统计或对某一栏有值的数据行数统计 MAX(字段名) 取得一个表格栏最大的值 MIN(字段名) 取得一个表格栏最小的值 SUM(字段名) 把数据栏的值相加
引用以上函数的方法:
sql="select sum(字段名) as 别名 from 数据表 where 条件表达式" set rs=conn.excute(sql)
用 rs(“别名”) 获取统的计值,其它函数运用同上。
(6) 数据表的建立和删除:
CREATE TABLE 数据表名称(字段1 类型1(长度),字段2 类型2(长度) …… )
例:CREATE TABLE tab01(name varchar(50),datetime default now())
DROP TABLE 数据表名称 (永久性删除一个数据表)
select from test.text where 1 表示所有栏目 test指数据库名text指表名 where指条件
Select remark as r id,uid from test.text where 指id uid 2栏显示 as 就是给栏目命名
select * from test.text where id>4 指ID大于4的都显示出来
select * from test.text where id<>4 指ID 不等于4的都出来
select * from test.text where id=1 指ID等于1的出来
select * from test.text where id in(1,3,5) 指找出ID为1 3 5的 not in()则相反
select * from test.text where uid like "%王%" 指UID里只要带王字的都出来 %王 表示什么王 ,王%表示 王什么。
select * from test.text where remark like "%学%" 指remark里带学的都出来
select * from test.text where id between 1 and 10 and uid like "%王%"表示ID 1-10 并且 UID带王字的出来
select * from test.text where id not between 1 and 4 指ID不在1-4里面的 出来
(1 and 2 表示满足1且满足2 1 or 2 表示满足1和满足2 )and or可以连接很多条件
select * from test.text group by remark 显示列出remark有多少类别 如图↓ 有5类 group by 就是分组命令
select * from test.text order by regdate asc 把regdate 按从小到大排列
ASC不打就是默认从小到大 DESC表示从大到小 如 order desc
select * from test.text order by regdate asc,id desc 这样就查询出日期从小到大 然后在满足日期的排列后 ID从大到小排列
select * from test.text limit 0,5 表示取5条记录 如果是3,6 那就是第4-第9条记录被取出 如图↓
如过只写一个6那就等于0,6
select * from test.text group by remark order by regdate limit 6 先分组 再排序 LIMIT放最后 这是语法不能颠倒。
select count(id) from test.text count()表示查询有多少条信息 这样根据表显示出10条
select max(regdate) from test.text max() 查询最大值 只能针对数字 包括日期 根据表显示出2008-10-22 14:41:30
select min(regdate)from test.text min() 查询最小值 只能针对数字 包括日期 根据表显示出2008-10-07 13:21:32
select avg(id) from test.text avg() 查询平均值 也只针对数字 包括日期 显示出5.5 如算平均分数
select sum(id) from test.text sum() 查询累计值 数字包括日期 显示出55 1+2+3+。。10=55 如算总分数
insert 插入语句
insert into
text(
id,
uid,
regdate,
remark)values(null,'ken',now(),'学生') 其中null就是没有 now()就是时间日期自动生成
字段的类型要设计好。特别注意!
Update 更改语句
Update 表名 set 字段=值 where 条件 LIMIT(可省略) update test.text set uid='kenchen' where id=11 意思是把ID是11的UID 改成kenchen
Delete 删除语句
Delete from 表命 where limit Delete from text where id=3 意思是把ID=3的信息条删除!