DotNet,PHP,Java的数据库连接代码大全(带演示代码)
C#数据库连接字符串
Web.config文件
<connectionStrings>
<!--SQLServer数据库连接-->
<add name="conn_test_sqlserver" connectionString="server=127.0.0.1;uid=testuser;pwd=testPwd;database=db_test;pooling=true;min pool size=10;max pool size=1024;connection lifetime=300;packet size=1000" providerName="System.Data.SqlClient"/>
<!--MySQL数据库连接-->
<add name="conn_test_mysql" connectionString="Data Source=127.0.0.1; Database=db_test; User Id=testuser;Password=testPwd; pooling=false; CharSet=utf8; Port=3306" providerName="MySql.Data.MySqlClient"/>
<!--SQLite数据库连接-->
<add name="conn_test_sqlite" connectionString="Data Source=|DataDirectory|\db_test.db3; Pooling=true; FailIfMissing=false" providerName="System.Data.SQLite" />
</connectionStrings>
<!-- 解决DbProviderFactories.GetFactory(ProviderName)出现的异常:“找不到请求的 .Net Framework Data Provider。可能没有安装。” -->
<system.data>
<DbProviderFactories>
<remove invariant="System.Data.SQLite"/>
<add name="SQLite Data Provider" invariant="System.Data.SQLite" description=".Net Framework Data Provider for SQLite" type="System.Data.SQLite.SQLiteFactory, System.Data.SQLite, Version=1.0.105.2, Culture=neutral, PublicKeyToken=db937bc2d44ff139" />
<remove invariant="MySQL Data Provider"/>
<add name="MySQL Data Provider" invariant="MySql.Data.MySqlClient" description=".Net Framework Data Provider for MySQL" type="MySql.Data.MySqlClient.MySqlClientFactory, MySql.Data, Version=6.9.9.0, Culture=neutral, PublicKeyToken=c5687fc88969c44d" />
</DbProviderFactories>
</system.data>
示例代码:
protected void Page_Load(object sender, EventArgs e)
{
try
{
object value = GetValue();
Response.Write(null==value?"Null":value);
}
catch (Exception ex)
{
Response.Write(ex.Message);
}
}
public object GetValue()
{
string connName = "con_test_mysql";
System.Configuration.ConnectionStringSettings connConf = System.Configuration.ConfigurationManager.ConnectionStrings[connName];
DbFactory dbFactory = new DbFactory(connConf.ProviderName, connConf.ConnectionString);
try
{
System.Data.Common.DbProviderFactory dbpf = System.Data.Common.DbProviderFactories.GetFactory(connConf.ProviderName);
using (System.Data.Common.DbConnection conn = dbpf.CreateConnection())
{
conn.ConnectionString = connConf.ConnectionString;
using (System.Data.Common.DbCommand cmd = conn.CreateCommand())
{
// cmd
string sqlstmt = "select remark from t_user where account=@account";
cmd.CommandText = sqlstmt;
cmd.CommandTimeout = ;
// params
System.Data.Common.DbParameter dbpara = cmd.CreateParameter();
dbpara.ParameterName = "@account";
dbpara.Value = "test@email.com";
dbpara.Size = ;
cmd.Parameters.Add(dbpara);
// execute
System.Data.Common.DbDataAdapter dbadp = dbpf.CreateDataAdapter();
dbadp.SelectCommand = cmd;
conn.Open();
DataTable dtResult = new DataTable();
dbadp.Fill(dtResult);
object value = null;
if (dtResult.Rows.Count > )
{
value = dtResult.Rows[][];
if (DBNull.Value == value)
{
value = null;
}
}
return value;
}
}
}
catch (Exception ex)
{
throw ex;
}
}
下载: CSharpDbConnectionDemo(DotNet数据库连接演示).zip
Java数据库连接字符串
// mysql
driver="com.mysql.jdbc.Driver";
url = "jdbc:mysql://localhost:3306/db_test?useUnicode=true&characterEncoding=UTF8";
conn = getConnection(driver,url, "user", "password");
System.out.println("与mysql数据库连接" + (null == conn ? "失败" : "成功"));
// sqlite
driver="SQLite.JDBCDriver";
url = "jdbc:sqlite:/C:/db_test.db3";
conn = getConnection(driver,url);
System.out.println("与sqlite数据库连接" + (null == conn ? "失败" : "成功"));
// sqlserver
driver="com.mysql.jdbc.Driver";
url = "jdbc:sqlserver://localhost:1433;DatabaseName=db_test";
conn = getConnection(driver,url, "user", "password");
System.out.println("与sql server数据库连接" + (null == conn ? "失败" : "成功"));
// oracle
driver="oracle.jdbc.driver.OracleDriver";
url = "jdbc:oracle:thin:@localhost:1521:orcl";
conn = getConnection(driver,url, "user", "password");
System.out.println("与oracle数据库连接" + (null == conn ? "失败" : "成功"));
JDBC连接数据库方法
public static Connection getConnection(String driver, String url, String user, String password) {
Connection conn = null;
try {
//初始化驱动包
Class.forName(driver);
conn = DriverManager.getConnection(url, user, password); } catch (Exception e) {
e.printStackTrace();
}
return conn;
}
下载:[jdbc_connection_demo(JDBC连接各种数据库演示).zip]
PHP_PDO数据库连接字符串
// PDO连接MySQL的DSN字符串 (需要打开php配置文件中的"extension=php_pdo_mysql.dll"选项)
mysql:dbname=db_test;host=127.0.0.1;port=3306;charset=utf8
// PDO连接SQLite的DSN字符串 (需要打开php配置文件中的"extension=php_pdo_sqlite.dll"选项)
sqlite:test_db.db3
// PDO通过ODBC连接SQL Server的DSN字符串 (需要打开php配置文件中的"extension=php_pdo_odbc.dll"选项)
odbc:Driver={SQL Server};Server=127.0.0.1,1433;Database=db_test;
// PDO连接SQL Server的DSN字符串(配置非常麻烦,建议使用ODBC方式。PHP5.3.6以上的版本中php_mssql.dll,php_pdo_mssql.dll都已经不见了,只有一个php_pdo_odbc.dll,所以最新最好的php连接mssql方法应该是使用ODBC的驱动模式。)
sqlsrv:Database=db_test;Server=127.0.0.1,1433
// PDO连接PostgreSQL的DSN字符串 (需要打开php配置文件中的"extension=php_pdo_pgsql.dll"选项)
pgsql:dbname=db_test;host=127.0.0.1;port=5432
// PDO连接Oracle的DSN字符串 (需要打开php配置文件中的"extension=php_pdo_oci.dll"选项)
oci:dbname=//127.0.0.1:5432/db_test
示例代码:
$dsn = 'mysql:dbname=db_test;host=127.0.0.1;port=3306;charset=utf8';
$pdo = new PDO($dsn, 'dbuser', 'dbpwd');
$stmt = $pdo->prepare('select id, name from t_user where user_name=:account');
$stmt->bindParam(':account', $account);
$stmt->execute();
while ($row = $stmt->fetch()) {
return $row;
}
/**
* 查询并返回数组
* <br />例如:
* <br />query('select COLUMN_NAME, IS_NULLABLE, DATA_TYPE, CHARACTER_MAXIMUM_LENGTH, NUMERIC_PRECISION, NUMERIC_SCALE, EXTRA, COLUMN_COMMENT from information_schema.columns WHERE TABLE_SCHEMA=:database AND TABLE_NAME=:table', ['database' => $dbname, 'table' => $tablename])
* @param string $sqlstmt
* @param array $params
* @return array
*/
function query($sqlstmt, $params = []) {
$dsn = 'mysql:host=127.0.0.1;port=3306;charset=utf8';
$pdo = new PDO($dsn, 'dbuser', 'dbpwd');
$stmt = $pdo->prepare($sqlstmt);
if ($params) {
$names = array_keys($params);
$values = array_values($params);
$i = count($names) - 1;
// 这里不能用foreach,参考bindParam陷阱(值参数是引用型变量):http://www.laruence.com/2012/10/16/2831.html
while ($i >= 0) {
$stmt->bindParam($names[$i], $values[$i]);
$i--;
}
}
$stmt->execute();
$out = [];
while ($row = $stmt->fetch()) {
$out[] = $row;
}
return $out;
}
下载:[pdo_dns_demo(PDO连接各种数据库演示).zip]
PHP官方DSN说明:http://php.net/manual/en/ref.pdo-odbc.connection.php
更多DSN连接字符串可以参考:http://www.connectionstrings.com/
版权声明:本文采用署名-非商业性使用-相同方式共享(CC BY-NC-SA 3.0 CN)国际许可协议进行许可,转载请注明作者及出处。 |
DotNet,PHP,Java的数据库连接代码大全(带演示代码)的更多相关文章
- 百度架构师带你进阶高级JAVA架构,让你快速从代码开发者成长为系统架构者
百度架构师带你进阶高级JAVA架构,让你快速从代码开发者成长为系统架构者 1.
- Java jdbc数据库连接池总结!(转)
1. 引言 近年来,随着Internet/Intranet建网技术的飞速发展和在世界范围内的迅速普及,计算机 应用程序已从传统的桌面应用转到Web应用.基于B/S(Browser/Server)架构的 ...
- HTML代码大全
1.html的简介* 什么是html?- HyperText Markup Language:超文本标记语言,网页语言** 超文本:超出文本的范畴,使用html可以轻松实现这样操作** 标记:html ...
- 软帝学院:一万字的Java基础知识总结大全(实用)
Java基础总结大全(实用) 一.基础知识: 1.JVM.JRE和JDK的区别: JVM(Java Virtual Machine):java虚拟机,用于保证java的跨平台的特性. java语言是跨 ...
- [转帖]java面试和笔试大全
java面试和笔试大全 https://www.cnblogs.com/linzheng/archive/2011/01/05/1926856.html 2.String是最基本的数据类型吗? 基本数 ...
- html常用代码大全
1.结构性定义 文件类型 <HTML></HTML> (放在档案的开头与结尾) 文件主题 <TITLE></TITLE> (必须放在「文头」区块内) 文 ...
- 《代码大全2》读书笔记 Week9
本周阅读了<代码大全2>第14章至第17章,这几章对我们熟悉的直线型代码.条件语句.循环语句和一些不常用的控制结构(如goto.try-catch结构)提出了一些使用建议,以下分享条件语句 ...
- php 基础代码大全(不断完善中)
下面是基础的PHP的代码,不断完善中~ //语法错误(syntax error)在语法分析阶段,源代码并未被执行,故不会有任何输出. /* [命名规则] */ 常量名 类常量建议全大写,单词间用下划线 ...
- 实用js代码大全
实用js代码大全 //过滤数字 <input type=text onkeypress="return event.keyCode>=48&&event.keyC ...
随机推荐
- git clone、git pull和git fetch的用法及区别
声明:码字不易,转载请注明出处,欢迎文章下方讨论交流.Git 常用命令速查表 最近在一个学习小组里学习AI的课程,我们所有的学习资料和homework都放在gitlab上.今天一个小队友从gitlab ...
- POWERDESIGNER生成的代码有引号
昨天在用powerdesigner画的一个导入ORACLE中.发现都带了双引号, 当时没在意,以为是分隔符.那想后要在ORACLE查询表是一定要输入双引号才能查询.. 后来才知道而这在oracle 中 ...
- Python 函数内省
函数内省(function introspection) 除了__doc__属性, 函数对象还有很多属性,对于下面的函数,可以使用dir()查看函数具有的属性: def factorial(n): r ...
- Python常用模块之hashlib
Python里面的hashlib模块提供了很多加密的算法,这里介绍一下hashlib的简单使用事例,用hashlib的md5算法加密数据 import hashlib hash = hashlib.m ...
- Beta发布——视频博客
1.视频链接 视频上传至优酷自频道,地址链接:http://v.youku.com/v_show/id_XMzkzNzAxNDk2OA==.html?spm=a2hzp.8244740.0.0 2.视 ...
- scrum立会报告+燃尽图(第二周第四次)
此作业要求参考: https://edu.cnblogs.com/campus/nenu/2018fall/homework/2249 一.小组介绍 组名:杨老师粉丝群 组长:乔静玉 组员:吴奕瑶.公 ...
- “Hello World!”团队第六周的第一次会议
今天是我们团队“Hello World!”团队第六周召开的第一次会议.博客内容: 一.会议时间 二.会议地点 三.会议成员 四.会议内容 五.Todo List 六.会议照片 七.燃尽图 一.会议时间 ...
- 《Linux内核与分析》第五周
20135130王川东 一.给MenuOS增加time和time-asm命令 命令:1.强制删除:rm menu -rf 2.克隆:git clone (后跟需要克隆数据所在的位置) 3.自动编译,自 ...
- Java中switch可以接收的数据类型
Java支持的数据类型有五种 他们分别是: byte.char.short.int.enum: 以上是JDK1.6以前的版本. JDK1.7时,又增加了String, public class Tes ...
- OOP 1.4 内联函数和重载函数函数参数缺省值
1.内联函数 存在的背景:函数调用存在开销(调用时候参数压栈,返回地址压栈:返回时从栈取出返回地址,跳转到返回地址.总共需要几条指令的开销).如果函数指令较少,调用多次,函数调用的开销占比大. 内联函 ...