关于MySql
2015-09-16 16:28 Evan.Pei 阅读(294) 评论(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使用方法如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 | 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的一些使用:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 | 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 $$ |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构