代码改变世界

关于MySql

2015-09-16 16:28  Evan.Pei  阅读(289)  评论(0编辑  收藏  举报

1.Mysql最开始是由瑞士的Mysql AB公司开发,后被Sun公司收购,再后面Sun被Oracle公司收购,所以Mysql属于Oracle公司。

2.Linx+Apache+Mysql+PHP 被誉为经典组合简称LAMP,或是Apache换成Nginx是LNMP。

3.MySql 开源,体积小,拥有成本低,目前有企业版与社区版。可以到mysql.com的 download中下载

4.Mysql适合中小型企业,中小型项目使用,处理千万级的数据轻松。

5.下载地址mysql.com。

6.Mysql使用 Mysql 5.6Command Line Client 编写命令。

7.或者使用Mysql workbench 可视化开发环境:下载地址:http://dev.mysql.com/downloads/workbench/

8.关于.net中链接MySql

 

     8.1在Mysql服务器运行Cmd到Mysql安装目录中的bin文件中去:cd..   cd file

   

   8.2然后运行mysql 登录mysql:

   

   root:用户

    8.3 登录成功后接着录入:设置外部访问权限

      mysql>GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'password' WITH GRANT OPTION;

          mysql>flush privileges;

 

      上面的意思是*.*代表所有数据库如果指定的话可以改成mydb.*

                            '%'这个的意思是所有其他电脑都可以访问mysql,如果想指定计算机可以改成‘192.168.*.*’你的ip.

           总的意思就是设置外部访问mysql数据库的权限可以指定被访问数据和访问者的电脑,也可完全放开。

    8.4 接下来是C#端:

     8.4.1将mysql.data.dll拷贝到.net项目bin中,并添加引用.

          8.4.2使用方法如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using MySql.Data.MySqlClient;

namespace WebApplication1
{
    public partial class ConnMysqlDB : System.Web.UI.Page
    {
        public string myConnectionString = "Database=evantestdb;Data Source=192.168.61.254;User Id=root;Password=123456";

        protected void Page_Load(object sender, EventArgs e)
        {
            string sql = "select * from employee";
            MySqlConnection con = new MySqlConnection(myConnectionString);
            MySqlCommand com = new MySqlCommand(sql,con);
            con.Open();
            MySqlDataReader dr=com.ExecuteReader();

            string a = "";
            while(dr.Read()){
                a += dr["Ename"].ToString()+"\n\n";
            }

            Response.Write(a);

        }
    }
}

  

 下面是MySQL的一些使用:

  

mysql -u root -p;//进入mysql
mysql>show variables like '%datadir%';//查询数据库存放路径
show databases://查询所有数据库
use testDB;//进入testDB数据库
show Tables;//查看所有表
show tables from dbname;//查看其它数据库中的所有表
describe tablename;//查看表结构
quit;//退出
create database dataName;//创建数据库
drop database dataName;//删除数据库包括表和数据 策底删除
alter table tableName rename to newName;//修改表名
rename table oldTableName to newName;//修改表名
alter table tableNme add email varchar(30) not null;//添加列
alter table tablename change id newid int(3);//将列名id修改成newid
alter table tablename drop cellName;//删除列

整数类型[从小到大]TinyInt,SmallInt,MediumInt,Int,Bigint
浮点类型 Float,Double,decimal
字符串Char,varcahr,text,blob
枚举类型Enum('Y','N')代表只能插入这两个字符
例如:Alter table tableName add newCell Enum('Y','N');
      INSERT INTO tableName values('Y')只能是Y和N

set类型Set('A','B','CD','EFG')可以同时插入多个用逗号隔开
 例如:Alter table tableName add newCell Set('A','B','CD','EFG');
      INSERT INTO tableName values('A,B,EFG')可以多个插入

日期时间 data(YYYY-MM-DD),time(HH:MM:SS),year(YYYY),
           datatime(YYYY-MM-DD HH:MM:SS),timestamp(YYYY-MM-DD HH:MM:SS)

关于自增长  MSsql中identity(1,1) MySql中 auto_increment
 例如:create table testTable(id int auto_increment,
       primary key(id)
       );
使用Unique保证唯一性 alter table tableName add unique(cellName);

delete from tableName;//删除表中的数据,但是自增长的列继续增长
truncate table tableName;//删除表中的数据,自增长的列从1开始

//least(1,2,3,0);//取最小值0
//greatest(1,2,3,0);//取最大值3
//rand();//随机
//round(1.12345,2);//四舍五入 保留2位小数
//truncate(1.1234,2);//保留2位,截断,不进行四舍五入
//avg();//平均
//sum()
//min()
//max()
//count()

//length();//长度
//lcase();//lower()//转小写
//upper();//大写
//strcmp();//比较大小
//position('a' in 'abc');//查找a的位置返回1
//replace('yes','y','hh');//将yes中的y替换成hh
//insert('yes',2,3,'hh');//在yes中从第2位开始插入hh
//concat('hello','world');//连接
//concat_ws(':','a','b');//结果是a:b
//left('hello',2);//取左边第几个字符right()
//lpad('abc',11,'z');//在左边用Z补齐到11位rpad();
//ltrim();//去左边空格Rtrim().trim()
//substring('abcdfsdfs',2,2);
//ascii('A');//去ascii值

//now();现在时间
//curtime();//只取当前时间不要日期
//curdata();//只取日期
//year('2012-02-12');取年moth()
//dayofyear('2012-02-23');一年中的第几天dayofweek()
//week('2015-1-12');//第几周
//hour('2015-09-15 17:27:09'),minute(),second();取时分秒
//date_add('2015-09-15 17:27:09',interval 3 month);添加3个月 day,
//date_sub();减去与上面相反
//SELECT TimesTampDiff(day, '2015-09-10 15:52:11',now());取相差天数
---关于加密
password('abc');//加密函数不可逆转
encrypt('abc','key');//加密函数不可逆转
encode('text','key1');//加密text
decode('cellName','key1');//解密encode()
insert into users(uname) values(aes_encrypt('text','key2'));//加密,这种比encode()加密的更复杂
select aes_decrypt(uname) from users;//解密
---逻辑
select if(10>2,'true','false');
select ifnull(1,'null');--如果不为空返回第一个参数,空返回第二个参数
select nullif(1,2);--如果两个参数相等返回null,不等返回第一个参数

select case when 1>0 then 'ok'
            when 2>2 then 'ok2'
            else 'abc' end;
select case 'green'
            when 'red' then 'ok'
            when 'green' then 'ok2'
            else 'abc' end;
			
---格式化
select date_format(now(),'yyyy-mm-dd');
select time_format('','')			
select inet_aton('192.168.10.58');--转换为长串数据例如是:434334233
select inet_ntoa(434334233);--转换成'192.168.10.58'
cast('99' as int);--转整数
convert('99',signed);
			
--------存储过程
delimiter $$  --界定符代表mysql碰到$$才结束 而不是;号
create procedure proc_1()
BEGIN
select * from employee;
END$$