|
This depends on many things. Generally to get 1 record you use a where clause to filter the table. If the field you are filtering on does NOT have an index then a table scan is required until it finds the record. This is called art of database tuning. There a many books written on this subject.
Never underestimate the power of human stupidity
RAH
|
|
|
|
|
Check this[^]
I Love T-SQL
"Don't torture yourself,let the life to do it for you."
|
|
|
|
|
You should definitely look into this tool. I have used it to find out what is going on while my application is running. Also, when writing your SQL statements, you should avoid statements like "select * from myTable" you should only list the columns that are really required otherwise you will be sending more data than is necessary over the network.
My 2 cents.
David
|
|
|
|
|
Yes, all records of database are traversed.
"We can't solve problems by using the same kind of thinking we used when we created them"
|
|
|
|
|
SQL 2005 Standard SP1
I have these two queries I am trying to join into one result set; I have been struggling with this for days and get close but can not seem to get it correct.
Query 1:
select count(*) as 'Total Tickets Assigned' , location_name 'Cient'
from job_ticket j
inner join priority_type p on p.priority_type_id = j.priority_type_id
inner join tech t on t.client_id = j.assigned_tech_id
inner join location l on l.location_id = j.location_id
WHERE Report_Date >= DATEADD(dd,-7,CONVERT(DATETIME,CONVERT(CHAR(8),
GETDATE(),112))) AND
Report_Date < DATEADD(dd,1,CONVERT(DATETIME,CONVERT(CHAR(8),
GETDATE(),112)))
group by l.location_name
Query 2:
select count(*) as 'Total Closed for Range'
, location_name 'Cient'
from job_ticket j
inner join priority_type p on p.priority_type_id = j.priority_type_id
inner join tech t on t.client_id = j.assigned_tech_id
inner join location l on l.location_id = j.location_id
where (last_status_update_time >= DATEADD(dd,-7,CONVERT(DATETIME,CONVERT(CHAR(8),
GETDATE(),112))) AND
Report_Date < DATEADD(dd,1,CONVERT(DATETIME,CONVERT(CHAR(8),
GETDATE(),112))) ) and
status_type_id ='3'
group by l.location_name
basically all I need to get is the "count(*) as 'Total Closed for Range'" into query 2, however; I keep getting the total in each row rather than the total for each client.
Also I have been trying to send the results of the query out via email.....I know this should be simple but I keep getting errors on that as well.
Any help would be greatly appreciated.
Thanks,
Dennis
Regards,
Hulicat
modified on Wednesday, August 20, 2008 1:53 PM
|
|
|
|
|
If you want to have single query which output result same with your two querys then post your data of tables and result which you want to have from only single query.
Regards.
I Love T-SQL
"Don't torture yourself,let the life to do it for you."
|
|
|
|
|
I am posting here because I am unable to make the single query output correctly
I would like one result set looking like this:
'Total Tickets Assigned','Total Closed for Range', 'Client'
Regards,
Hulicat
|
|
|
|
|
If your queries return the correct data by themselves, then you should be able to join on a subquerys:
Select
total.Cient
,TotalTicketsAssigned
,TotalClosedForRange
From
(
select count(*) as 'TotalTicketsAssigned' , location_name 'Cient'
from job_ticket j
inner join priority_type p on p.priority_type_id = j.priority_type_id
inner join tech t on t.client_id = j.assigned_tech_id
inner join location l on l.location_id = j.location_id
WHERE Report_Date >= DATEADD(dd,-7,CONVERT(DATETIME,CONVERT(CHAR(8),
GETDATE(),112))) AND
Report_Date < DATEADD(dd,1,CONVERT(DATETIME,CONVERT(CHAR(8),
GETDATE(),112)))
group by l.location_name
) total
Left Join
(
select count(*) as 'TotalClosedforRange'
, location_name 'Cient'
from job_ticket j
inner join priority_type p on p.priority_type_id = j.priority_type_id
inner join tech t on t.client_id = j.assigned_tech_id
inner join location l on l.location_id = j.location_id
where (last_status_update_time >= DATEADD(dd,-7,CONVERT(DATETIME,CONVERT(CHAR(8),
GETDATE(),112))) AND
Report_Date < DATEADD(dd,1,CONVERT(DATETIME,CONVERT(CHAR(8),
GETDATE(),112))) ) and
status_type_id ='3'
group by l.location_name
) Closed on
total.Cient = closed.Cient
|
|
|
|
|
Thank for that; it gived me two errors one on line 11 and one on 23 the last.
1st error on 11 is a syntax error near ")"
2nd error is on line 23 the last is error near "closed"
Heere it is revised a bit...this one is tuff for me thanks for the help!!!
Select total.Client,TotalTicketsAssigned,
TotalClosedForRangeFrom select count(*) as
'TotalTicketsAssigned' , location_name
'Client'from job_ticket jinner join priority_type p
on p.priority_type_id = j.priority_type_idinner join
tech t on t.client_id = j.assigned_tech_idinner join
location l on l.location_id = j.location_id WHERE Report_Date
>= DATEADD(dd,-7,CONVERT(DATETIME,CONVERT(CHAR(8),GETDATE(),112)))
AND Report_Date
< DATEADD(dd,1,CONVERT(DATETIME,CONVERT(CHAR(8),GETDATE(),112)))
group by l.location_name)
total.client
Left Join (select count(*)
as 'TotalClosedforRange', location_name 'Client'from
job_ticket jinner join priority_type p on p.priority_type_id =
j.priority_type_idinner join tech t on t.client_id =
j.assigned_tech_idinner join location l on l.location_id =
j.location_id where (last_status_update_time >=
DATEADD(dd,-7,CONVERT(DATETIME,CONVERT(CHAR(8),GETDATE(),112)))
AND Report_Date < DATEADD(dd,1,CONVERT(DATETIME,CONVERT(CHAR(8),
GETDATE(),112))) ) and status_type_id ='3'
group by l.location_name)
Closed on total.Client = closed.Client
Regards,
Hulicat
|
|
|
|
|
I copied and pasted the two queries you supplied into the join sub-query syntax, so the line 11 one is something from the query you supplied (and I'm guessing the second one is resulting from the first error).
To try to clear things up for you, here's a simple structure of a sub-query join:
Select
<select list>
From
(
<query 1>
) q1
Join
(
<query 2>
) q2 on
<join list>
<other clauses (probably will not have any here)>
The select must use the names assigned to the columns, so if you have Select Name, Date as OpenDate; then you would need to use Name for name (because the name was not changed) and OpenDate for the original column Date.
If you think of the two queries as tables, it might make the concept easier to grasp. If the above query was written from tables, it would be Select * From Table1 q1 Join Table2 q2 on ...
Hope that helps.
|
|
|
|
|
Thanks for that!!!
You made it crystal clear and I have it working now!!
Omce again thanks for taking the time to teach and give an example of perspective...
That will really help me moving forward.
Thanks and Regards,
Dennis
Regards,
Hulicat
|
|
|
|
|
need help on something i have this
Dim SQLIinsert As String = "UPDATE httpuser SET credits= " + -1 + "' WHERE username='" + My.Settings.Username + "'"
what i need is to decrease the column credits by 1 but it this i get -1 in the database.
can someone explain whats wrong? ive searched but im almost ready to quit.
thanks in advance
ive posted the same on vb.net because i guess this question envolves both parts
|
|
|
|
|
"UPDATE httpuser SET credits=credits -1 WHERE username='" + My.Settings.Username + "'"
But be aware from SQL Injections, take a read about it.
I Love T-SQL
"Don't torture yourself,let the life to do it for you."
|
|
|
|
|
thanks
|
|
|
|
|
You are welcome.
I Love T-SQL
"Don't torture yourself,let the life to do it for you."
|
|
|
|
|
hi Guys,
I have been working with Oracle till now and recently moved to SQL Server.
In oracle we have packages, which is an effective way of organizing our stored procs.
In sql server I am seeing all procedures under one folder at same level.
Is there any way to organize or group together procedures in SQL server?
Thanks
Keep DotNetting!!
GeekFromIndia
|
|
|
|
|
|
Hi...im a newbie in MySQL...hope you guys can help me...
Im going to upload an image or file to MySQL database,
the question is..what data type am I going to set for my image field?
thanks..
|
|
|
|
|
Blob, which stands for Binary large object.
|
|
|
|
|
Hi!
I have worked with a DB programming, but this is the first time that I actually build a database on my own.
Here is a short description of the task: I need to store the list of small businesses, each of them has some fields, like "Company name", "Address", "Phone", etc. However, I also need to store the working schedule for these businesses and that is something that I don't know how to implement.
The problem is that businesses in my country often have different working hours and lunch breaks, for example.
Monday - Friday: 10.00 - 19.00 , lunch break 13.00-14.00
Saturday: 10.00-16.00, lunch break 12.30-13.30;
Sunday: OFF
Because of the variety of the companies, I'd like to be able to take care of such instances.
So far I came up with idea of using a table, which stores the schedule in 28 different columns (time of work start + time of work end + time of lunch start + time of lunch end) * 7 days = 28 columns.
I was wondering if someone has done something similar before and can give me an advice on this.
Thanks for help
|
|
|
|
|
I would suggest to accomplish this by using relational tables.
Have a table with the business info, and then give the business an Id number.
Create a table that has BusinessId,Day, TimeWorkStart, TimeWorkEnd, TimeLunchStart, TimeLunchEnd (or whatever you want to call them).
The BusinessID would be the foreign key that would refer to the Business info table. To get the schedule, you would need to join up on the BusinessId of both tables.
The way you listed above could be one approach (and I've seen similar things done in program), but you might come to a point where the design restricts you from adding additional schedules without storing a bunch of duplicate data.
Also less data is being stored. If your table has 28 columns, but only has, say Monday and Tuesday workdays, then there are 20 unused columns.
|
|
|
|
|
Thanks a lot for your help! I really appreciate it.
I liked your idea, but once I started to implement it, I've come up with a "joined" solution, that combines the advantages of yours and mine approaches. Here is the idea.
Although, there is a big variety of businesses in my city, many of them share the same schedule. Therefore, I think it would be better to create a table "Schedules", which will contain the list of all schedules, that the businesses use. This way, each of 24/7 shops in my database will contain only an ID for appropriate 24/7 schedule, therefore, I will avoid lots of duplication. And, if I meet some odd schedule, I can just add it into the table with the schedules.
If you find any faults in this idea, or have some suggestions - I'll appreciate that.
Once again, thanks for time&effort
|
|
|
|
|
Something that might happen in the future is that a business might need to have 2 types of schedules, causing duplicate data in the business table on every column but ScheduleId.
You could "map" BusinessId's to SchedulesId's in a view, so you might have tables like:
BusinessID, Name, ...
ScheduleId, Day, StartTime, EndTime
Mapping Table: BusinessId, ScheduleId (with a unique index on BusinessId, ScheduleID so you don't dupe data)
Then have a view
Select ...<br />
From MappingTable m<br />
Join ...
But if you have a business rule similar to one business can have one schedule per day, then I think your Joined solution will work fine.
|
|
|
|
|
I have a doubt on Foreign key column. I understand that a Foregin key column can hold NULL values (meaning it need not be required always), but can it hold invalid data in it?
That is, it is holding the ROW_ID of another table where that record is not available. Will it throw an error or it will accept the invalid entry?
|
|
|
|
|
Foreign key is used to ensure data integrity. If you want to allow invalid entries, I cannot see the point in using foreign key.
|
|
|
|
|