wins系统flask绑定mysql_flask如何连接mssql,网上大多是sqlite和mysql教程?

这个居然也冒出来,刨坟了。

我们不喜欢写原生SQL语句,那个写着费劲,日常开发时候,我们怎么CRUD数据库呢?一般使用ORM,对象关系映射(英语:Object Relational Mapping,简称ORM)。

主力使用的是python语言,那么python中最好用的ORM就是sqlalchemy。

一:连接参数

sqlalchemy使用 create_engine() 函数从URL生成一个数据库链接对象,URL遵循 RFC-1738标准。我也不懂。大概就是要有用户名,密码,地址,端口,数据库名,还有一些可选参数。一个标准的链接URL是这样的:

dialect+driver://username:password@host:port/database

dialect,是数据库类型,大概包括:sqlite, mysql, postgresql, oracle, or mssql.

driver,是使用的数据库API,驱动,连接包,随便叫什么吧。

username,用户名

password,密码

host,网络地址,可以用ip,域名,计算机名,当然是你能访问到的。

port,数据库端口。

databas,数据库名。

其实这些也就dialect和dirver需要解释。

二:连接sqlite3

1,驱动

sqlite3是个文件数据库,不需要什么驱动,或者说python内置了驱动。

2,标准连接参数

# sqlite:///

没有hostname

3,各种链接参数

# 相对路径,就是这个python文件同目录下foo.db

engine = create_engine('sqlite:///foo.db')

#绝对路径

#Unix/Mac下用四条表示

engine = create_engine('sqlite:absolute/path/to/foo.db')

#Windows下用三条///加盘符路径用两条\\

engine = create_engine('sqlite:///C:\\path\\to\\foo.db')

#Windows 也可以这么用三条///加盘符路径用一条\

engine = create_engine(r'sqlite:///C:\path\to\foo.db')

#数据库建在内存里。URI保持为空即可

engine = create_engine('sqlite://')

三:连接mysql(mariadb)

sqlalchemy默认使用mysql-python作为链接驱动,既default模式

选哪种驱动,就装哪个包。

1,default默认链接方式

engine = create_engine('mysql://scott:tiger@localhost/foo')

2,# mysql-python,声明使用mysql-python驱动

engine = create_engine('mysql+mysqldb://scott:tiger@localhost/foo')

3,MySQL-connector-python 声明使用MySQL-connector-python驱动(推荐使用)

engine = create_engine('mysql+mysqlconnector://scott:tiger@localhost/foo')

4,OurSQL 声明使用OurSQL驱动

engine = create_engine('mysql+oursql://scott:tiger@localhost/foo')

四:连接Microsoft SQL Server

sqlalchemy默认使用 pyodbc作为链接驱动。

1,pyodbc

engine = create_engine('mssql+pyodbc://scott:tiger@mydsn')

2,pymssql

engine = create_engine('mssql+pymssql://scott:tiger@hostname:port/dbname')

五:连接PostgreSQL

PostgreSQL默认使用 psycopg2作为链接驱动,既default模式

1, default

engine = create_engine('postgresql://scott:tiger@localhost/mydatabase')

2,psycopg2

engine = create_engine('postgresql+psycopg2://scott:tiger@localhost/mydatabase')

3, pg8000

engine = create_engine('postgresql+pg8000://scott:tiger@localhost/mydatabase')

六:连接Oracle

Oracle可能只有 cx_oracle一个驱动包,既default模式和声明模式一样。

1,default

engine = create_engine('oracle://scott:tiger@127.0.0.1:1521/sidname')

2,cx_oracle

engine = create_engine('oracle+cx_oracle://scott:tiger@tnsname')

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/454870.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

hdu 6086 -- Rikka with String(AC自动机 + 状压DP)

题目链接 Problem DescriptionAs we know, Rikka is poor at math. Yuta is worrying about this situation, so he gives Rikka some math tasks to practice. There is one of them:Yuta has n 01 strings si, and he wants to know the number of 01 antisymmetric strings …

课堂动手动脑问题

对于随机数,java通过Math.random()来实现,比如要得到一个随机数我们可以int a; a(int)Math.random();但对于随机数,它是从0到1之间的数,所以必须通过int把它转为整数&…

GNU/Linux下有多少是GNU的?

导读:一个葡萄牙的学生写了一篇文章 《How much GNU is there in GNU/Linux?》由酷壳网的陈皓整理编译为《GNU/Linux下有多少是GNU的》。这篇文章主要分布了今年4月份的Ubuntu Natty的Linux分发包。其主要是用代码行来做的分析,用两个饼图对比分析。 内…

便携式三星mysql_JDBC链接mysql - 三星蓝

package chp07;importjava.sql.Connection;importjava.sql.DriverManager;importjava.sql.ResultSet;importjava.sql.SQLException;importjava.sql.Statement;public classJDBC_Test {//创建静态全局变量staticConnection conn;staticStatement st;public static voidmain(Stri…

C++ 类、对象、class

一、对象初始化 1.不能在类声明中对数据成员初始化,因为类只是一个抽象类型,不占存储空间,无处容纳数据。 2.若某类的数据成员都是public,则可以像结构体一样初始化,如 Time t{12,21,04}; 若数据成员有priv…

Unity 富文本

参考链接&#xff1a;http://www.ceeger.com/Manual/StyledText.html 首先要说的是不仅仅ugui的text组件支持富文本&#xff0c;Debug.Log也是支持的 Debug.Log("<color#ffff00ff><b>爱生活</b></color> <color#00ffffff><b> 爱海澜&…

Web项目替换jar包中的文件的方法

经常遇到这样的问题&#xff0c;需要修改jar包中的方法。应该如何做&#xff1f; 1、有些很人性化的框架jar包&#xff0c;比如SpringSecurity&#xff0c;可以修改配置文件指定一个新建的类&#xff0c;让类实现Jar包中的对应的接口就好了。 2、大部分的jar包都不会有这么方便…

程序员技术练级攻略

导读&#xff1a;本文是由陈皓和他的一位朋友Mailper合作完成&#xff0c;原名叫《Build Your Programming Technical Skills》&#xff0c;本文分享了Mailper和作者个人的学习经历。每个程序员都希望自己能顺利的升级到高的层次&#xff0c;您不妨按照下面的方法去做。 前言 你…

Linux shell 之 提取文件名和目录名的一些方法

很多时候在使用Linux的shell时&#xff0c;我们都需要对文件名或目录名进行处理&#xff0c;通常的操作是由路径中提取出文件名&#xff0c;从路径中提取出目录名&#xff0c;提取文件后缀名等等。例如&#xff0c;从路径/dir1/dir2/file.txt中提取也文件名file.txt&#xff0c…

bzoj 2752: [HAOI2012]高速公路(road)

Description Y901高速公路是一条重要的交通纽带&#xff0c;政府部门建设初期的投入以及使用期间的养护费用都不低&#xff0c;因此政府在这条高速公路上设立了许多收费站。Y901高速公路是一条由N-1段路以及N个收费站组成的东西向的链&#xff0c;我们按照由西向东的顺序将收费…

搭建DNS主、从服务实验

此次我们的口号是&#xff1a;简单、有趣上手DNS服务博主是一个言出必行de好人&#xff0c;&#xff08;正经脸&#xff09;上次转载了有关DNS的基础介绍&#xff0c;此次我们来通过实验搭建DNS服务器从而更好的了解DNS搭建过程如何开始&#xff0c;且听我细细道来首先我们通常…

GDB中应该知道的几个调试方法

七、八年前写过一篇《用GDB调试程序》&#xff0c;于是&#xff0c;从那以后&#xff0c;很多朋友在MSN上以及给我发邮件询问我关于GDB的问题&#xff0c;一直到今天&#xff0c;还有人在问GDB的相关问题。这么多年来&#xff0c;有一些问题是大家反复在问的&#xff0c;一方面…

长沙java技术_长沙如何提高自身的Java技术

长沙如何提高自身的Java技术&#xff1f;Java自发行二十多年来&#xff0c;一直都是开发者的宠儿&#xff0c;在编程界的位置一直十分稳固。虽然Java人才需求量大&#xff0c;薪资水平高&#xff0c;但想要用Java语言胜任企业工作不容易。比如要成为一名Java架构师&#xff0c;…

strcpy与strcat函数原型

1.strcpy函数原型 char *my_strcpy(char *dest,const char *src) //const使在函数中不能修改*src其原先的值{   char *strDest dest; //保存原始的strDest   assert((dest!NULL)&&(src!NULL)); //检验参数&#xff0c;…

CCF 201312-4 有趣的数

试题编号&#xff1a;201312-4试题名称&#xff1a;有趣的数时间限制&#xff1a;1.0s内存限制&#xff1a;256.0MB问题描述&#xff1a; 问题描述我们把一个数称为有趣的&#xff0c;当且仅当&#xff1a;1. 它的数字只包含0, 1, 2, 3&#xff0c;且这四个数字都出现过至少一次…

java 代码重用_Java 代码重用:功能与上下文重用

我几乎不需要讨论为什么重用代码是有利的。代码重用通常使得程序开发更加快速&#xff0c;并使得 BUG 减少。一旦一段代码被封装和重用&#xff0c;那么只需要检查很少的一段代码即可确保程序的正确性。如果在整个应用程序中只需要在一个地方打开和关闭数据库连接&#xff0c;那…

GCC-3.4.6源代码学习笔记

大约4年前&#xff0c;我加入了GDNT - 北电网络在中国的合资企业&#xff0c;参与3G UMTS无线接入网的研发工作。与GCC有了第一次亲密的接触&#xff08;之前使用的是MS的VC&#xff09;。彼时&#xff0c;北电在其诸如&#xff0c;UMTS、CDMA、及自行开发的众多工具等项目中&a…

互联网

2019独角兽企业重金招聘Python工程师标准>>> 转载于:https://my.oschina.net/u/3127489/blog/1550726

GCC笔记 命令行分析

1984年&#xff0c;Richard Stallman发起了自由软件运动&#xff0c;GNU (Gnus Not Unix)项目应运而生&#xff0c;3年后&#xff0c;最初版的GCC横空出世&#xff0c;成为第一款可移植、可优化、支持ANSI C的开源C编译器。GCC最初的全名是GNU C Compiler,之后&#xff0c;随着…

java 反射用法_Java 反射的概念与使用

一&#xff0c;反射的概念对于一个人来说&#xff0c;了解自己的能力、本事、特点&#xff0c;对于他去干事创业来说&#xff0c;是很重要的。同样的&#xff0c;对于一门面向对象的语言来说&#xff0c;了解类(对象其实就是类的实现)本身也是重要的&#xff0c;可以在很多地方…