AngularJS SQL 获取数据
使用PHP从MySQL中获取数据:
- <!DOCTYPE html>
- <html>
- <head>
- <meta charset="utf-8">
- <script src="http://cdn.static.runoob.com/libs/angular.js/1.4.6/angular.min.js"></script>
- <style>
- table, th , td {
- border: 1px solid grey;
- border-collapse: collapse;
- padding: 5px;
- }
- table tr:nth-child(odd) {
- background-color: #f1f1f1;
- }
- table tr:nth-child(even) {
- background-color: #ffffff;
- }
- </style>
- </head>
- <body>
- <div ng-app="myApp" ng-controller="customersCtrl">
- <table>
- <tr ng-repeat="x in names">
- <td>{{ x.Name }}</td>
- <td>{{ x.Country }}</td>
- </tr>
- </table>
- </div>
- <script>
- var app = angular.module('myApp', []);
- app.controller('customersCtrl', function($scope, $http) {
- $http.get("/try/angularjs/data/Customers_MySQL.php")
- .success(function (response) {$scope.names = response.records;});
- });
- </script>
- </body>
- </html>
ASP.NET中执行SQL获取数据:
- <!DOCTYPE html>
- <html>
- <head>
- <meta charset="utf-8">
- <script src="http://cdn.static.runoob.com/libs/angular.js/1.4.6/angular.min.js"></script>
- <style>
- table, th , td {
- border: 1px solid grey;
- border-collapse: collapse;
- padding: 5px;
- }
- table tr:nth-child(odd) {
- background-color: #f1f1f1;
- }
- table tr:nth-child(even) {
- background-color: #ffffff;
- }
- </style>
- </head>
- <body>
- <div ng-app="myApp" ng-controller="customersCtrl">
- <table>
- <tr ng-repeat="x in names">
- <td>{{ x.Name }}</td>
- <td>{{ x.Country }}</td>
- </tr>
- </table>
- </div>
- <script>
- var app = angular.module('myApp', []);
- app.controller('customersCtrl', function($scope, $http) {
- $http.get("http://www.runoob.com/try/angularjs/data/Customers_SQL.aspx")
- .success(function (response) {$scope.names = response.records;});
- });
- </script>
- </body>
- </html>
服务端代码:
以下列出了列出了几种服务端代码类型:
- 使用 PHP 和 MySQL。返回 JSON。
- 使用 PHP 和 MS Access。返回 JSON。
- 使用 ASP.NET, VB, 及 MS Access。 返回 JSON。
- 使用 ASP.NET, Razor, 及 SQL Lite。 返回 JSON。
跨域HTTP请求:
如果你需要从不同的服务器(不同域名)上获取数据就需要使用跨域 HTTP 请求。
跨域请求在网页上非常常见。很多网页从不同服务器上载入 CSS, 图片,Js脚本等。
在现代浏览器中,为了数据的安全,所有请求被严格限制在同一域名下,如果需要调用不同站点的数据,需要通过跨域来解决。
以下的 PHP 代码运行使用的网站进行跨域访问。
- header("Access-Control-Allow-Origin: *");
更多跨域访问解决方案可参阅:PHP Ajax 跨域问题最佳解决方案(http://www.runoob.com/w3cnote/php-ajax-cross-border.html)。
1.PHP和MySQL代码示例:
- <?php
- header("Access-Control-Allow-Origin: *");
- header("Content-Type: application/json; charset=UTF-8");
- $conn = new mysqli("myServer", "myUser", "myPassword", "Northwind");
- $result = $conn->query("SELECT CompanyName, City, Country FROM Customers");
- $outp = "";
- while($rs = $result->fetch_array(MYSQLI_ASSOC)) {
- if ($outp != "") {$outp .= ",";}
- $outp .= '{"Name":"' . $rs["CompanyName"] . '",';
- $outp .= '"City":"' . $rs["City"] . '",';
- $outp .= '"Country":"'. $rs["Country"] . '"}';
- }
- $outp ='{"records":['.$outp.']}';
- $conn->close();
- echo($outp);
- ?>
2.PHP和MS Access代码示例:
- <?php
- header("Access-Control-Allow-Origin: *");
- header("Content-Type: application/json; charset=ISO-8859-1");
- $conn = new COM("ADODB.Connection");
- $conn->open("PROVIDER=Microsoft.Jet.OLEDB.4.0;Data Source=Northwind.mdb");
- $rs = $conn->execute("SELECT CompanyName, City, Country FROM Customers");
- $outp = "";
- while (!$rs->EOF) {
- if ($outp != "") {$outp .= ",";}
- $outp .= '{"Name":"' . $rs["CompanyName"] . '",';
- $outp .= '"City":"' . $rs["City"] . '",';
- $outp .= '"Country":"'. $rs["Country"] . '"}';
- $rs->MoveNext();
- }
- $outp ='{"records":['.$outp.']}';
- $conn->close();
- echo ($outp);
- ?>
3.ASP.NET,VB和MS Access示例代码:
- <%@ Import Namespace="System.IO"%>
- <%@ Import Namespace="System.Data"%>
- <%@ Import Namespace="System.Data.OleDb"%>
- <%
- Response.AppendHeader("Access-Control-Allow-Origin", "*")
- Response.AppendHeader("Content-type", "application/json")
- Dim conn As OleDbConnection
- Dim objAdapter As OleDbDataAdapter
- Dim objTable As DataTable
- Dim objRow As DataRow
- Dim objDataSet As New DataSet()
- Dim outp
- Dim c
- conn = New OledbConnection("Provider=Microsoft.Jet.OLEDB.4.0;data source=Northwind.mdb")
- objAdapter = New OledbDataAdapter("SELECT CompanyName, City, Country FROM Customers", conn)
- objAdapter.Fill(objDataSet, "myTable")
- objTable=objDataSet.Tables("myTable")
- outp = ""
- c = chr(34)
- for each x in objTable.Rows
- if outp <> "" then outp = outp & ","
- outp = outp & "{" & c & "Name" & c & ":" & c & x("CompanyName") & c & ","
- outp = outp & c & "City" & c & ":" & c & x("City") & c & ","
- outp = outp & c & "Country" & c & ":" & c & x("Country") & c & "}"
- next
- outp ="{" & c & "records" & c & ":[" & outp & "]}"
- response.write(outp)
- conn.close
- %>
4.ASP.NET,VB Razor和SQL Lite代码示例:
- @{
- Response.AppendHeader("Access-Control-Allow-Origin", "*")
- Response.AppendHeader("Content-type", "application/json")
- var db = Database.Open("Northwind");
- var query = db.Query("SELECT CompanyName, City, Country FROM Customers");
- var outp =""
- var c = chr(34)
- }
- @foreach(var row in query)
- {
- if outp <> "" then outp = outp + ","
- outp = outp + "{" + c + "Name" + c + ":" + c + @row.CompanyName + c + ","
- outp = outp + c + "City" + c + ":" + c + @row.City + c + ","
- outp = outp + c + "Country" + c + ":" + c + @row.Country + c + "}"
- }
- outp ="{" + c + "records" + c + ":[" + outp + "]}"
- @outp
AngularJS SQL 获取数据的更多相关文章
- Sql获取数据集中各类型中的最大值(最新值)
select * from ( SELECT t.*,ROW_NUMBER() over (partition by t.pid order by t.op_time desc) num ...
- Sql获取数据表字段说明
SELECT Sysobjects.name AS TABLE_NAME , syscolumns.Id , syscolumns.name AS COLUMN_NAME , systypes.nam ...
- 【10】AngularJS SQL
AngularJS SQL 使用 PHP 从 MySQL 中获取数据 <div ng-app="myApp" ng-controller="customersCtr ...
- AngularJS学习之旅—AngularJS SQL(十二)
一.使用 PHP 从 MySQL 中获取数据 <div ng-app="myApp" ng-controller="customersCtrl"> ...
- sql 根据指定条件获取一个字段批量获取数据插入另外一张表字段中+MD5加密
/****** Object: StoredProcedure [dbo].[getSplitValue] Script Date: 03/13/2014 13:58:12 ******/ SET A ...
- 如何用asp.net MVC框架、highChart库从sql server数据库获取数据动态生成柱状图
如何用asp.net MVC框架.highChart库从sql server数据库获取数据动态生成柱状图?效果大概是这样的,如图: 请问大侠这个这么实现呢?
- SQL Server 怎么在分页获取数据的同时获取到总记录数
SQL Server 获取数据的总记录数,有两种方式: 1.先分页获取数据,然后再查询一遍数据库获取到总数量 2.使用count(1) over()获取总记录数量 SELECT * FROM ( SE ...
- AngularJs从数据库获取数据并显示
哈哈,昨天下午和今天早上,花上一些时间,学习AngularJs,仅是粗略预览一下.很好,非常好. 由于手上有开发ASP.NET MVC环境,就在这测试下,去数据库获取数据并显示数据. 数据库表创建,添 ...
- 在MyBatis中查询数据、涉及多参数的数据访问操作、插入数据时获取数据自增长的id、关联表查询操作、动态SQL、关于配置MyBatis映射没有代码提示的解决方案
1. 单元测试 在单元测试中,每个测试方法都需要执行相同的前置代码和后置代码,则可以自定义2个方法,分别在这2个方法中执行前置代码和后置代码,并为这2个方法添加@Before和@After注解,然后, ...
随机推荐
- 微信小程序-关于post 过来服务器没有获取到数据问题
查看一下服务器接收的post 参数是以什么形式接收的 微信给出得demo 请求的方式是Json 参数传递的 所以如果服务器使用的from 表单形式接收数据需要更改微信小程序中的 header 将 he ...
- 【USACO 3.1】Score Inflation(完全背包)
完全背包. http://train.usaco.org/usacoprob2?a=3Srffjlf4QI&S=inflate /* TASK:inflate LANG:C++ URL: */ ...
- 【poj2065】 SETI
http://poj.org/problem?id=2065 (题目链接) 题意 题意半天看不懂..给你一个素数P(P<=30000)和一串长为n的字符串str[].字母'*'代表0,字母a-z ...
- bzoj 1065: [NOI2008] 奥运物流
1065: [NOI2008] 奥运物流 Description 2008北京奥运会即将开幕,举国上下都在为这一盛事做好准备.为了高效率.成功地举办奥运会,对物流系统 进行规划是必不可少的.物流系统由 ...
- 个人学习记录2:ajax跨域封装
/** * 跨域提交公用方法 * @param param 参数 * @param url 跨域的地址 * @param callFun 回调函数 callFun(data) */ function ...
- Apache与Tomcat服务器
Apache是世界使用排名第一的Web服务器软件.它可以运行在几乎所有广泛使用的计算机平台上,由于其跨平台和安全性被广泛使用,是最流行的Web服务器端软件之一.在Apache基金会里面Apache S ...
- Docker数据持久化与容器迁移
上节讲到当容器运行期间产生的数据是不会在写镜像里面的,重新用此镜像启动新的容器就会初始化镜像,会加一个全新的读写入层来保存数据.如果想做到数据持久化,Docker提供数据卷(Data volume)或 ...
- centos 7.0 编译安装php 5.6.7
编译安装php参考资料 MySQL PHP API http://dev.mysql.com/doc/apis-php/en/index.html nginx + php +mysql 最简单安装 官 ...
- 三列等高 css实现
实现这个三列等高 布局需要最外层的一个div wrap容器 里面有三个div容器 这个最外层div 需要移除隐藏 overflow:hidden; 关键点就是三列div 同时margin-botto ...
- Bash 中的 _ 是不是环境变量
首先,我们想到的会是 export(等价于 declare -x)命令: $ export | grep 'declare -x _=' 没有找到,那么结论就是 _ 不是环境变量?当然没那么简单,否则 ...